| Cost | $0.191 |
| Total elapsed time | 2m26s |
| LLM inference time | 1m32s |
| Command execution time | 54s |
| Commands executed | 20 |
All details >
| Attempt ID | efw1rw1pzilv4 | Attempt group | run-16-09-22-05 |
| Revision | fb5c74bd2fee | AWS Instance | m8i.2xlarge |
| Start time | 2025-09-16T21:33:44.836Z | End time | 2025-09-16T21:36:11.889Z |
| Task | jq-static-musl | Environment | ubuntu-22.04-amd64 |
| Model | | OpenRouter slug | google/gemini-2.5-pro |
| Temperature | 1 | Explicit prompt caching | false |
| User msg after tool call | false | Max tool calls | 100 |
| Total timeout seconds | 1200 | Single command timeout | 600 |
| Cost | $0.191 | Duration | 2m26s |
| LLM inference time | 1m32s | Command execution time | 54s |
| Final context tokens | 21,258 | Total output tokens | 6,830 |
| Output reasoning tokens | 4,936 | Messages | 43 |
| Assistant messages | 21 | User messages | 1 |
| System messages | 1 | Commands executed | 20 |
jq 1.8.1 is a command-line JSON utility for viewing and transforming JSON.
Project link: github.com/jqlang/jq
Task:
Compile and install statically-linked jq to a specific location. The binary must use musl C library (not the standard glibc).
Difficulties:
musl toolchain setup, avoiding glibc-only assumptions.
Environment:
Ubuntu 22.04 on amd64, with internet access.
You are a package-building specialist operating a Ubuntu 22.04 bash shell via one tool: run_terminal_cmd.
The current working directory of every run_terminal_cmd is /home/peter.
Execution rules:
- Always pass non-interactive flags for any command that could prompt (e.g., -y, --yes, DEBIAN_FRONTEND=noninteractive).
- Don't include any newlines in the command.
- You can use sudo.
If you encounter any errors or issues while doing the user's request, you must fix them and continue the task.
At the end verify you did the user request correctly.
You are given jq v1.8.1 source code at /home/peter/jq.tar.gz. Please compile the jq package using musl as the C standard library and install it to /home/peter/result. Create a symlink from /home/peter/result/jq to the compiled jq binary. The binary must be statically linked and must use musl (not glibc).
Show reasoning
Defining Compilation Strategy
I've started to formulate a plan for compiling jq. First, I need to extract the source archive. Next, I'll configure the build environment to use musl-gcc, specifying the output directory, and ensuring static linking. After that, I should run the build process. Finally, a check for the compiled binary.
Formulating Build Commands
I'm now fleshing out the build commands. First, I'll install musl-tools. Next, I will extract the source. Then, the configure command needs flags for musl-gcc, the output directory, and static linking. I'm also including a potential LDFLAGS setting. After that, make and make install, followed by symlink creation. Finally, file verification.
Outlining Initial Steps
I've decided to focus on the foundational steps. Installing musl-tools comes first. Then I'll extract the source archive, and then the configuration phase. I need to specify compiler, output directory, and static linking options within the configure command. I'm leaning towards also including the LDFLAGS="-static" flag to make absolutely sure of the static build.
compile-bench> sudo apt-get update && sudo DEBIAN_FRONTEND=noninteractive apt-get install -y musl-tools
0% [Working]
Get:1 http://security.ubuntu.com/ubuntu jammy-security InRelease [129 kB]
0% [Connecting to archive.ubuntu.com (185.125.190.83)] [1 InRelease 14.2 kB/129
0% [Waiting for headers]
0% [Waiting for headers]
Hit:2 http://archive.ubuntu.com/ubuntu jammy InRelease
0% [Waiting for headers]
Get:3 http://security.ubuntu.com/ubuntu jammy-security/restricted amd64 Packages [5441 kB]
0% [Waiting for headers] [3 Packages 6999 B/5441 kB 0%]
0% [Waiting for headers] [3 Packages 197 kB/5441 kB 4%]
Get:4 http://archive.ubuntu.com/ubuntu jammy-updates InRelease [128 kB]
0% [4 InRelease 11.3 kB/128 kB 9%] [3 Packages 824 kB/5441 kB 15%]
0% [4 InRelease 15.6 kB/128 kB 12%]
0% [3 Packages store 0 B] [4 InRelease 15.6 kB/128 kB 12%] [Waiting for headers
Get:5 http://security.ubuntu.com/ubuntu jammy-security/universe amd64 Packages [1274 kB]
0% [3 Packages store 0 B] [4 InRelease 18.5 kB/128 kB 14%] [5 Packages 65.2 kB/
0% [3 Packages store 0 B] [4 InRelease 21.4 kB/128 kB 17%]
Get:6 http://security.ubuntu.com/ubuntu jammy-security/multiverse amd64 Packages [80.3 kB]
0% [3 Packages store 0 B] [4 InRelease 21.4 kB/128 kB 17%] [6 Packages 36.5 kB/
0% [3 Packages store 0 B] [4 InRelease 21.4 kB/128 kB 17%]
Get:7 http://security.ubuntu.com/ubuntu jammy-security/main amd64 Packages [3311 kB]
0% [3 Packages store 0 B] [4 InRelease 21.4 kB/128 kB 17%] [7 Packages 21.5 kB/
0% [3 Packages store 0 B] [4 InRelease 30.1 kB/128 kB 24%]
0% [4 InRelease 79.3 kB/128 kB 62%]
0% [5 Packages store 0 B] [4 InRelease 79.3 kB/128 kB 62%]
0% [4 InRelease 102 kB/128 kB 80%]
0% [6 Packages store 0 B] [4 InRelease 102 kB/128 kB 80%]
0% [4 InRelease 105 kB/128 kB 82%]
0% [7 Packages store 0 B] [4 InRelease 105 kB/128 kB 82%]
0% [7 Packages store 0 B] [Waiting for headers]
0% [7 Packages store 0 B] [Waiting for headers]
0% [Waiting for headers]
Get:8 http://archive.ubuntu.com/ubuntu jammy-backports InRelease [127 kB]
0% [8 InRelease 2588 B/127 kB 2%]
[command output truncated]
ckage lists... 71%
Reading package lists... 71%
Reading package lists... 72%
Reading package lists... 72%
Reading package lists... 72%
Reading package lists... 72%
Reading package lists... 72%
Reading package lists... 72%
Reading package lists... 81%
Reading package lists... 81%
Reading package lists... 96%
Reading package lists... 96%
Reading package lists... 99%
Reading package lists... 99%
Reading package lists... 99%
Reading package lists... 99%
Reading package lists... Done
Building dependency tree... 0%
Building dependency tree... 0%
Building dependency tree... 50%
Building dependency tree... 50%
Building dependency tree... Done
Reading state information... 0%
Reading state information... 1%
Reading state information... Done
The following additional packages will be installed:
musl musl-dev
Recommended packages:
linux-musl-dev
The following NEW packages will be installed:
musl musl-dev musl-tools
0 upgraded, 3 newly installed, 0 to remove and 0 not upgraded.
Need to get 1018 kB of archives.
After this operation, 4100 kB of additional disk space will be used.
0% [Working]
Get:1 http://archive.ubuntu.com/ubuntu jammy/universe amd64 musl amd64 1.2.2-4 [407 kB]
1% [1 musl 14.2 kB/407 kB 3%]
39% [Waiting for headers]
Get:2 http://archive.ubuntu.com/ubuntu jammy/universe amd64 musl-dev amd64 1.2.2-4 [605 kB]
40% [2 musl-dev 11.3 kB/605 kB 2%]
Get:3 http://archive.ubuntu.com/ubuntu jammy/universe amd64 musl-tools amd64 1.2.2-4 [5520 B]
93% [3 musl-tools 747 B/5520 B 14%]
100% [Working]
Fetched 1018 kB in 1s (1125 kB/s)
debconf: delaying package configuration, since apt-utils is not installed
Selecting previously unselected package musl:amd64.
(Reading database ...
(Reading database ... 5%
(Reading database ... 10%
(Reading database ... 15%
(Reading database ... 20%
(Reading database ... 25%
(Reading database ... 30%
(Reading database ... 35%
(Reading database ... 40%
(Reading database ... 45%
(Reading database ... 50%
(Reading database ... 55%
(Reading database ... 60%
(Reading database ... 65%
(Reading database ... 70%
(Reading database ... 75%
(Reading database ... 80%
(Reading database ... 85%
(Reading database ... 90%
(Reading database ... 95%
(Reading database ... 100%
(Reading database ... 10711 files and directories currently installed.)
Preparing to unpack .../musl_1.2.2-4_amd64.deb ...
Unpacking musl:amd64 (1.2.2-4) ...
Selecting previously unselected package musl-dev:amd64.
Preparing to unpack .../musl-dev_1.2.2-4_amd64.deb ...
Unpacking musl-dev:amd64 (1.2.2-4) ...
Selecting previously unselected package musl-tools.
Preparing to unpack .../musl-tools_1.2.2-4_amd64.deb ...
Unpacking musl-tools (1.2.2-4) ...
Setting up musl:amd64 (1.2.2-4) ...
Setting up musl-dev:amd64 (1.2.2-4) ...
Setting up musl-tools (1.2.2-4) ...
↓ 41 lines
0% [Working] Get:1 http://security.ubuntu.com/ubuntu jammy-security InRelease [129 kB] 0% [Connecting to archive.ubuntu.com (185.125.190.83)] [1 InRelease 14.2 kB/129 0% [Waiting for headers] 0% [Waiting for headers] Hit:2 http://archive.ubuntu.com/ubuntu jammy InRelease 0% [Waiting for headers] Get:3 http://security.ubuntu.com/ubuntu jammy-security/restricted amd64 Packages [5441 kB] 0% [Waiting for headers] [3 Packages 6999 B/5441 kB 0%] 0% [Waiting for headers] [3 Packages 197 kB/5441 kB 4%] Get:4 http://archive.ubuntu.com/ubuntu jammy-updates InRelease [128 kB] 0% [4 InRelease 11.3 kB/128 kB 9%] [3 Packages 824 kB/5441 kB 15%] 0% [4 InRelease 15.6 kB/128 kB 12%] 0% [3 Packages store 0 B] [4 InRelease 15.6 kB/128 kB 12%] [Waiting for headers Get:5 http://security.ubuntu.com/ubuntu jammy-security/universe amd64 Packages [1274 kB] 0% [3 Packages store 0 B] [4 InRelease 18.5 kB/128 kB 14%] [5 Packages 65.2 kB/ 0% [3 Packages store 0 B] [4 InRelease 21.4 kB/128 kB 17%] Get:6 http://security.ubuntu.com/ubuntu jammy-security/multiverse amd64 Packages [80.3 kB] 0% [3 Packages store 0 B] [4 InRelease 21.4 kB/128 kB 17%] [6 Packages 36.5 kB/ 0% [3 Packages store 0 B] [4 InRelease 21.4 kB/128 kB 17%] Get:7 http://security.ubuntu.com/ubuntu jammy-security/main amd64 Packages [3311 kB] 0% [3 Packages store 0 B] [4 InRelease 21.4 kB/128 kB 17%] [7 Packages 21.5 kB/ 0% [3 Packages store 0 B] [4 InRelease 30.1 kB/128 kB 24%] 0% [4 InRelease 79.3 kB/128 kB 62%] 0% [5 Packages store 0 B] [4 InRelease 79.3 kB/128 kB 62%] 0% [4 InRelease 102 kB/128 kB 80%] 0% [6 Packages store 0 B] [4 InRelease 102 kB/128 kB 80%] 0% [4 InRelease 105 kB/128 kB 82%] 0% [7 Packages store 0 B] [4 InRelease 105 kB/128 kB 82%] 0% [7 Packages store 0 B] [Waiting for headers] 0% [7 Packages store 0 B] [Waiting for headers] 0% [Waiting for headers] Get:8 http://archive.ubuntu.com/ubuntu jammy-backports InRelease [127 kB] 0% [8 InRelease 2588 B/127 kB 2%] [command output truncated] ckage lists... 71% Reading package lists... 71% Reading package lists... 72% Reading package lists... 72% Reading package lists... 72% Reading package lists... 72% Reading package lists... 72% Reading package lists... 72% Reading package lists... 81% Reading package lists... 81% Reading package lists... 96% Reading package lists... 96% Reading package lists... 99% Reading package lists... 99% Reading package lists... 99% Reading package lists... 99% Reading package lists... Done Building dependency tree... 0% Building dependency tree... 0% Building dependency tree... 50% Building dependency tree... 50% Building dependency tree... Done Reading state information... 0% Reading state information... 1% Reading state information... Done The following additional packages will be installed: musl musl-dev Recommended packages: linux-musl-dev The following NEW packages will be installed: musl musl-dev musl-tools 0 upgraded, 3 newly installed, 0 to remove and 0 not upgraded. Need to get 1018 kB of archives. After this operation, 4100 kB of additional disk space will be used. 0% [Working] Get:1 http://archive.ubuntu.com/ubuntu jammy/universe amd64 musl amd64 1.2.2-4 [407 kB] 1% [1 musl 14.2 kB/407 kB 3%] 39% [Waiting for headers] Get:2 http://archive.ubuntu.com/ubuntu jammy/universe amd64 musl-dev amd64 1.2.2-4 [605 kB] 40% [2 musl-dev 11.3 kB/605 kB 2%] Get:3 http://archive.ubuntu.com/ubuntu jammy/universe amd64 musl-tools amd64 1.2.2-4 [5520 B] 93% [3 musl-tools 747 B/5520 B 14%] 100% [Working] Fetched 1018 kB in 1s (1125 kB/s) debconf: delaying package configuration, since apt-utils is not installed Selecting previously unselected package musl:amd64. (Reading database ... (Reading database ... 5% (Reading database ... 10% (Reading database ... 15% (Reading database ... 20% (Reading database ... 25% (Reading database ... 30% (Reading database ... 35% (Reading database ... 40% (Reading database ... 45% (Reading database ... 50% (Reading database ... 55% (Reading database ... 60% (Reading database ... 65% (Reading database ... 70% (Reading database ... 75% (Reading database ... 80% (Reading database ... 85% (Reading database ... 90% (Reading database ... 95% (Reading database ... 100% (Reading database ... 10711 files and directories currently installed.) Preparing to unpack .../musl_1.2.2-4_amd64.deb ... Unpacking musl:amd64 (1.2.2-4) ... Selecting previously unselected package musl-dev:amd64. Preparing to unpack .../musl-dev_1.2.2-4_amd64.deb ... Unpacking musl-dev:amd64 (1.2.2-4) ... Selecting previously unselected package musl-tools. Preparing to unpack .../musl-tools_1.2.2-4_amd64.deb ... Unpacking musl-tools (1.2.2-4) ... Setting up musl:amd64 (1.2.2-4) ... Setting up musl-dev:amd64 (1.2.2-4) ... Setting up musl-tools (1.2.2-4) ...
Show reasoning
Examining Build Parameters
I'm currently analyzing the user's requirements for building jq. It seems they need a statically linked musl-based binary, placed in a specific directory, and a symlink created. I'm now considering the best approach for incorporating these constraints into the compilation process.
Implementing the Extraction
I've successfully extracted the jq source archive to /home/peter/jq-*. Now, I'm focusing on the configuration step. I'm planning on using the --disable-shared and --enable-static flags. Also, I have determined to use --with-oniguruma=builtin for the oniguruma dependency and set appropriate LDFLAGS.
Defining Extraction Strategy
I've decided on extracting the archive, then addressing the build configuration. Specifically, the extraction will utilize tar -xzf jq.tar.gz. Following extraction, I'll need to identify the extracted directory name to proceed with the build configuration.
[empty output]
Show reasoning
Analyzing Compilation Strategy
I've decided to focus on the build environment first. Installing musl-tools seems critical. I need to ensure I can use musl-gcc to compile jq. This should allow me to statically link the binary, which is the goal. Now, I'm figuring out if there's anything else I need to set up.
Constructing Configuration Commands
I'm now formulating the exact command to configure the build. I'll navigate to the extracted source directory, which I expect is jq-1.8.1. Then, I'll run the configure script, setting the compiler to musl-gcc. I'll enable static linking with --enable-static and direct the installation to /home/peter/result using --prefix. Finally, I must ensure I understand the configure script's output.
Planning the Build Process
I'm now formulating the command line execution plan. First, I'll extract the tarball, then navigate into the extracted source directory, jq-1.8.1. Next, I'll execute the configuration command, setting the compiler to musl-gcc, enabling static linking, and specifying the installation prefix. Finally, I need to verify the extracted directory's name and confirm the configure command is successful.
jq-1.8.1 jq.tar.gz
Show reasoning
Examining Compilation Options
I'm currently focusing on the compilation parameters for jq. I need to make sure that musl is correctly used, and that the resulting binary is statically linked. Right now I'm looking into installing musl-tools to get the musl-gcc wrapper. I think that's my next step.
Planning Configuration Commands
I've moved on to the configuration phase. I'm going to execute ./configure now, and I need to make sure to include the appropriate flags. These will set the installation directory to /home/peter/result, specify musl-gcc for compilation, and tell the linker to statically link the binary. Next, I'll execute the make step.
compile-bench> cd jq-1.8.1 && ./configure --prefix=/home/peter/result CC=musl-gcc LDFLAGS=-static checking for gcc... musl-gcc
checking whether the C compiler works... yes
checking for C compiler default output file name... a.out
checking for suffix of executables...
checking whether we are cross compiling... no
checking for suffix of object files... o
checking whether the compiler supports GNU C... yes
checking whether musl-gcc accepts -g... yes
checking for musl-gcc option to enable C11 features... none needed
checking whether musl-gcc understands -c and -o together... yes
checking for stdio.h... yes
checking for stdlib.h... yes
checking for string.h... yes
checking for inttypes.h... yes
checking for stdint.h... yes
checking for strings.h... yes
checking for sys/stat.h... yes
checking for sys/types.h... yes
checking for unistd.h... yes
checking for wchar.h... yes
checking for minix/config.h... no
checking whether it is safe to define __EXTENSIONS__... yes
checking whether _XOPEN_SOURCE should be defined... no
checking for a BSD-compatible install... /usr/bin/install -c
checking whether build environment is sane... yes
checking for a race-free mkdir -p... /usr/bin/mkdir -p
checking for gawk... no
checking for mawk... mawk
checking whether make sets $(MAKE)... yes
checking whether make supports the include directive... yes (GNU style)
checking whether make supports nested variables... yes
checking dependency style of musl-gcc... gcc3
checking whether make supports nested variables... (cached) yes
checking for ar... ar
checking the archiver (ar) interface... ar
checking whether to enable maintainer-specific portions of Makefiles... no
checking for gcc... (cached) musl-gcc
checking whether the compiler supports GNU C... (cached) yes
checking whether musl-gcc accepts -g... (cached) yes
checking for musl-gcc option to enable C11 features... (cached) none needed
checking whether musl-gcc understands -c and -o together... (cached) yes
checking how to run the C preprocessor... musl-gcc -E
checking for bison... no
checking for byacc... no
checking build system type... x86_64-pc-linux-musl
checking host system type... x86_64-pc-linux-musl
checking how to print strings... printf
checking for a sed that does not truncate output... /usr/bin/sed
checking for grep that handles long lines and -e... /usr/bin/grep
checking for egrep... /usr/bin/grep -E
checking for fgrep... /usr/bin/grep -F
checking for ld used by musl-gcc... /usr/bin/ld
checking if the linker (/usr/bin/ld) is GNU ld... yes
checking for BSD- or MS-compatible name lister (nm)... /usr/bin/nm -B
checking the name lister (/usr/bin/nm -B) interface... BSD nm
checking whether ln -s works... yes
checking the maximum length of command line arguments... 1572864
checking how to convert x86_64-pc-linux-musl file names to x86_64-pc-linux-musl format... func_convert_file_noop
checking how to convert x86_64-pc-linux-musl file names to toolchain format... func_convert_file_noop
checking for /usr/bin/ld option to reload object files... -r
checking
[command output truncated]
cking whether ln -s works... yes
checking the maximum length of command line arguments... 1572864
checking how to convert x86_64-pc-linux-gnu file names to x86_64-pc-linux-gnu format... func_convert_file_noop
checking how to convert x86_64-pc-linux-gnu file names to toolchain format... func_convert_file_noop
checking for /usr/bin/ld option to reload object files... -r
checking for file... file
checking for objdump... objdump
checking how to recognize dependent libraries... pass_all
checking for dlltool... no
checking how to associate runtime and link libraries... printf %s\n
checking for ar... ar
checking for archiver @FILE support... @
checking for strip... strip
checking for ranlib... ranlib
checking command to parse /usr/bin/nm -B output from musl-gcc object... ok
checking for sysroot... no
checking for a working dd... /usr/bin/dd
checking how to truncate binary pipes... /usr/bin/dd bs=4096 count=1
checking for mt... no
checking if : is a manifest tool... no
checking for stdio.h... yes
checking for stdlib.h... yes
checking for string.h... yes
checking for inttypes.h... yes
checking for stdint.h... yes
checking for strings.h... yes
checking for sys/stat.h... yes
checking for sys/types.h... yes
checking for unistd.h... yes
checking for dlfcn.h... yes
checking for objdir... .libs
checking if musl-gcc supports -fno-rtti -fno-exceptions... no
checking for musl-gcc option to produce PIC... -fPIC -DPIC
checking if musl-gcc PIC flag -fPIC -DPIC works... yes
checking if musl-gcc static flag -static works... yes
checking if musl-gcc supports -c -o file.o... yes
checking if musl-gcc supports -c -o file.o... (cached) yes
checking whether the musl-gcc linker (/usr/bin/ld -m elf_x86_64) supports shared libraries... yes
checking whether -lc should be explicitly linked in... no
checking dynamic linker characteristics... GNU/Linux ld.so
checking how to hardcode library paths into programs... immediate
checking whether stripping libraries is possible... yes
checking if libtool supports shared libraries... yes
checking whether to build shared libraries... yes
checking whether to build static libraries... yes
checking whether make sets $(MAKE)... (cached) yes
checking for sys/time.h... yes
checking for unistd.h... (cached) yes
checking for sys/times.h... yes
checking size of int... 4
checking size of long... 8
checking size of long long... 8
checking size of void*... 8
checking for size_t... yes
checking for working alloca.h... yes
checking for alloca... yes
checking that generated files are newer than configure... done
configure: creating ./config.status
config.status: creating Makefile
config.status: creating src/Makefile
config.status: creating test/Makefile
config.status: creating sample/Makefile
config.status: creating onig-config
config.status: creating src/config.h
config.status: executing depfiles commands
config.status: executing libtool commands
config.status: executing default commands
↓ 130 lines
checking for gcc... musl-gcc checking whether the C compiler works... yes checking for C compiler default output file name... a.out checking for suffix of executables... checking whether we are cross compiling... no checking for suffix of object files... o checking whether the compiler supports GNU C... yes checking whether musl-gcc accepts -g... yes checking for musl-gcc option to enable C11 features... none needed checking whether musl-gcc understands -c and -o together... yes checking for stdio.h... yes checking for stdlib.h... yes checking for string.h... yes checking for inttypes.h... yes checking for stdint.h... yes checking for strings.h... yes checking for sys/stat.h... yes checking for sys/types.h... yes checking for unistd.h... yes checking for wchar.h... yes checking for minix/config.h... no checking whether it is safe to define __EXTENSIONS__... yes checking whether _XOPEN_SOURCE should be defined... no checking for a BSD-compatible install... /usr/bin/install -c checking whether build environment is sane... yes checking for a race-free mkdir -p... /usr/bin/mkdir -p checking for gawk... no checking for mawk... mawk checking whether make sets $(MAKE)... yes checking whether make supports the include directive... yes (GNU style) checking whether make supports nested variables... yes checking dependency style of musl-gcc... gcc3 checking whether make supports nested variables... (cached) yes checking for ar... ar checking the archiver (ar) interface... ar checking whether to enable maintainer-specific portions of Makefiles... no checking for gcc... (cached) musl-gcc checking whether the compiler supports GNU C... (cached) yes checking whether musl-gcc accepts -g... (cached) yes checking for musl-gcc option to enable C11 features... (cached) none needed checking whether musl-gcc understands -c and -o together... (cached) yes checking how to run the C preprocessor... musl-gcc -E checking for bison... no checking for byacc... no checking build system type... x86_64-pc-linux-musl checking host system type... x86_64-pc-linux-musl checking how to print strings... printf checking for a sed that does not truncate output... /usr/bin/sed checking for grep that handles long lines and -e... /usr/bin/grep checking for egrep... /usr/bin/grep -E checking for fgrep... /usr/bin/grep -F checking for ld used by musl-gcc... /usr/bin/ld checking if the linker (/usr/bin/ld) is GNU ld... yes checking for BSD- or MS-compatible name lister (nm)... /usr/bin/nm -B checking the name lister (/usr/bin/nm -B) interface... BSD nm checking whether ln -s works... yes checking the maximum length of command line arguments... 1572864 checking how to convert x86_64-pc-linux-musl file names to x86_64-pc-linux-musl format... func_convert_file_noop checking how to convert x86_64-pc-linux-musl file names to toolchain format... func_convert_file_noop checking for /usr/bin/ld option to reload object files... -r checking [command output truncated] cking whether ln -s works... yes checking the maximum length of command line arguments... 1572864 checking how to convert x86_64-pc-linux-gnu file names to x86_64-pc-linux-gnu format... func_convert_file_noop checking how to convert x86_64-pc-linux-gnu file names to toolchain format... func_convert_file_noop checking for /usr/bin/ld option to reload object files... -r checking for file... file checking for objdump... objdump checking how to recognize dependent libraries... pass_all checking for dlltool... no checking how to associate runtime and link libraries... printf %s\n checking for ar... ar checking for archiver @FILE support... @ checking for strip... strip checking for ranlib... ranlib checking command to parse /usr/bin/nm -B output from musl-gcc object... ok checking for sysroot... no checking for a working dd... /usr/bin/dd checking how to truncate binary pipes... /usr/bin/dd bs=4096 count=1 checking for mt... no checking if : is a manifest tool... no checking for stdio.h... yes checking for stdlib.h... yes checking for string.h... yes checking for inttypes.h... yes checking for stdint.h... yes checking for strings.h... yes checking for sys/stat.h... yes checking for sys/types.h... yes checking for unistd.h... yes checking for dlfcn.h... yes checking for objdir... .libs checking if musl-gcc supports -fno-rtti -fno-exceptions... no checking for musl-gcc option to produce PIC... -fPIC -DPIC checking if musl-gcc PIC flag -fPIC -DPIC works... yes checking if musl-gcc static flag -static works... yes checking if musl-gcc supports -c -o file.o... yes checking if musl-gcc supports -c -o file.o... (cached) yes checking whether the musl-gcc linker (/usr/bin/ld -m elf_x86_64) supports shared libraries... yes checking whether -lc should be explicitly linked in... no checking dynamic linker characteristics... GNU/Linux ld.so checking how to hardcode library paths into programs... immediate checking whether stripping libraries is possible... yes checking if libtool supports shared libraries... yes checking whether to build shared libraries... yes checking whether to build static libraries... yes checking whether make sets $(MAKE)... (cached) yes checking for sys/time.h... yes checking for unistd.h... (cached) yes checking for sys/times.h... yes checking size of int... 4 checking size of long... 8 checking size of long long... 8 checking size of void*... 8 checking for size_t... yes checking for working alloca.h... yes checking for alloca... yes checking that generated files are newer than configure... done configure: creating ./config.status config.status: creating Makefile config.status: creating src/Makefile config.status: creating test/Makefile config.status: creating sample/Makefile config.status: creating onig-config config.status: creating src/config.h config.status: executing depfiles commands config.status: executing libtool commands config.status: executing default commands
Show reasoning
Planning the Compilation
I've confirmed that musl-tools is installed, which grants me access to musl-gcc. Now I must figure out the exact compilation flags needed for jq to link statically and target the specified directory. I'll also need to check any dependencies.
Progressing the Build Steps
I've successfully extracted the source code and configured the build using the provided parameters, including the --prefix, CC, and LDFLAGS flags. I'm now prepared to execute the make command to compile the code. After that, I will proceed with installation and the creation of the symlink as specified.
Beginning the Compilation Phase
I'm now running the make command to build jq within the extracted source directory. Then I will proceed with make install. I'll remember to create the necessary symbolic link as the final step, after verifying the installation of the compiled binary in the correct location.
compile-bench> cd jq-1.8.1 && make mkdir -p src
GEN src/builtin.inc
mkdir -p src
GEN src/config_opts.inc
mkdir -p src
GEN src/version.h
make all-recursive
make[1]: Entering directory '/home/peter/jq-1.8.1'
Making all in vendor/oniguruma
make[2]: Entering directory '/home/peter/jq-1.8.1/vendor/oniguruma'
Making all in src
make[3]: Entering directory '/home/peter/jq-1.8.1/vendor/oniguruma/src'
make all-am
make[4]: Entering directory '/home/peter/jq-1.8.1/vendor/oniguruma/src'
/bin/bash ../libtool --tag=CC --mode=compile musl-gcc -DHAVE_CONFIG_H -I. -I.. -Wall -g -O2 -MT regparse.lo -MD -MP -MF .deps/regparse.Tpo -c -o regparse.lo regparse.c
libtool: compile: musl-gcc -DHAVE_CONFIG_H -I. -I.. -Wall -g -O2 -MT regparse.lo -MD -MP -MF .deps/regparse.Tpo -c regparse.c -fPIC -DPIC -o .libs/regparse.o
libtool: compile: musl-gcc -DHAVE_CONFIG_H -I. -I.. -Wall -g -O2 -MT regparse.lo -MD -MP -MF .deps/regparse.Tpo -c regparse.c -o regparse.o >/dev/null 2>&1
mv -f .deps/regparse.Tpo .deps/regparse.Plo
/bin/bash ../libtool --tag=CC --mode=compile musl-gcc -DHAVE_CONFIG_H -I. -I.. -Wall -g -O2 -MT regcomp.lo -MD -MP -MF .deps/regcomp.Tpo -c -o regcomp.lo regcomp.c
libtool: compile: musl-gcc -DHAVE_CONFIG_H -I. -I.. -Wall -g -O2 -MT regcomp.lo -MD -MP -MF .deps/regcomp.Tpo -c regcomp.c -fPIC -DPIC -o .libs/regcomp.o
libtool: compile: musl-gcc -DHAVE_CONFIG_H -I. -I.. -Wall -g -O2 -MT regcomp.lo -MD -MP -MF .deps/regcomp.Tpo -c regcomp.c -o regcomp.o >/dev/null 2>&1
mv -f .deps/regcomp.Tpo .deps/regcomp.Plo
/bin/bash ../libtool --tag=CC --mode=compile musl-gcc -DHAVE_CONFIG_H -I. -I.. -Wall -g -O2 -MT regexec.lo -MD -MP -MF .deps/regexec.Tpo -c -o regexec.lo regexec.c
libtool: compile: musl-gcc -DHAVE_CONFIG_H -I. -I.. -Wall -g -O2 -MT regexec.lo -MD -MP -MF .deps/regexec.Tpo -c regexec.c -fPIC -DPIC -o .libs/regexec.o
libtool: compile: musl-gcc -DHAVE_CONFIG_H -I. -I.. -Wall -g -O2 -MT regexec.lo -MD -MP -MF .deps/regexec.Tpo -c regexec.c -o regexec.o >/dev/null 2>&1
mv -f .deps/regexec.Tpo .deps/regexec.Plo
/bin/bash ../libtool --tag=CC --mode=compile musl-gcc -DHAVE_CONFIG_H -I. -I.. -Wall -g -O2 -MT regenc.lo -MD -MP -MF .deps/regenc.Tpo -c -o regenc.lo regenc.c
libtool: compile: musl-gcc -DHAVE_CONFIG_H -I. -I.. -Wall -g -O2 -MT regenc.lo -MD -MP -MF .deps/regenc.Tpo -c regenc.c -fPIC -DPIC -o .libs/regenc.o
libtool: compile: musl-gcc -DHAVE_CONFIG_H -I. -I.. -Wall -g -O2 -MT regenc.lo -MD -MP -MF .deps/regenc.Tpo -c regenc.c -o regenc.o >/dev/null 2>&1
mv -f .deps/regenc.Tpo .deps/regenc.Plo
/bin/bash ../libtool --tag=CC --mode=compile musl-gcc -DHAVE_CONFIG_H -I. -I.. -Wall -g -O2 -MT regerror.lo -MD -MP -MF .deps/regerror.Tpo -c -o regerror.lo regerror.c
libtool: compile: musl-gcc -DHAVE_CONFIG_H -I. -I.. -Wall -g -O2 -MT regerror.lo -MD -MP -MF .deps/regerror.Tpo -c regerror.c -fPIC -DPIC -o .libs/regerror.o
libtool: compile: musl-gcc -DHAVE_CONFIG_H -I. -I.. -Wall -g -O2 -MT regerror
[command output truncated]
sjis.lo sjis_prop.lo iso8859_1.lo iso8859_2.lo iso8859_3.lo iso8859_4.lo iso8859_5.lo iso8859_6.lo iso8859_7.lo iso8859_8.lo iso8859_9.lo iso8859_10.lo iso8859_11.lo iso8859_13.lo iso8859_14.lo iso8859_15.lo iso8859_16.lo euc_tw.lo euc_kr.lo big5.lo gb18030.lo koi8_r.lo cp1251.lo onig_init.lo
libtool: link: ar cr .libs/libonig.a regparse.o regcomp.o regexec.o regenc.o regerror.o regext.o regsyntax.o regtrav.o regversion.o st.o reggnu.o unicode.o unicode_unfold_key.o unicode_fold1_key.o unicode_fold2_key.o unicode_fold3_key.o ascii.o utf8.o utf16_be.o utf16_le.o utf32_be.o utf32_le.o euc_jp.o euc_jp_prop.o sjis.o sjis_prop.o iso8859_1.o iso8859_2.o iso8859_3.o iso8859_4.o iso8859_5.o iso8859_6.o iso8859_7.o iso8859_8.o iso8859_9.o iso8859_10.o iso8859_11.o iso8859_13.o iso8859_14.o iso8859_15.o iso8859_16.o euc_tw.o euc_kr.o big5.o gb18030.o koi8_r.o cp1251.o onig_init.o
libtool: link: ranlib .libs/libonig.a
libtool: link: ( cd ".libs" && rm -f "libonig.la" && ln -s "../libonig.la" "libonig.la" )
make[4]: Leaving directory '/home/peter/jq-1.8.1/vendor/oniguruma/src'
make[3]: Leaving directory '/home/peter/jq-1.8.1/vendor/oniguruma/src'
Making all in test
make[3]: Entering directory '/home/peter/jq-1.8.1/vendor/oniguruma/test'
make[3]: Nothing to be done for 'all'.
make[3]: Leaving directory '/home/peter/jq-1.8.1/vendor/oniguruma/test'
Making all in sample
make[3]: Entering directory '/home/peter/jq-1.8.1/vendor/oniguruma/sample'
make[3]: Nothing to be done for 'all'.
make[3]: Leaving directory '/home/peter/jq-1.8.1/vendor/oniguruma/sample'
make[3]: Entering directory '/home/peter/jq-1.8.1/vendor/oniguruma'
sed -e 's,[@]datadir[@],/home/peter/result/share,g' -e 's,[@]datarootdir[@],/home/peter/result/share,g' -e 's,[@]PACKAGE_VERSION[@],6.9.10,g' -e 's,[@]prefix[@],/home/peter/result,g' -e 's,[@]exec_prefix[@],/home/peter/result,g' -e 's,[@]libdir[@],/home/peter/result/lib,g' -e 's,[@]includedir[@],/home/peter/result/include,g' < ./oniguruma.pc.in > oniguruma.pc
make[3]: Leaving directory '/home/peter/jq-1.8.1/vendor/oniguruma'
make[2]: Leaving directory '/home/peter/jq-1.8.1/vendor/oniguruma'
make[2]: Entering directory '/home/peter/jq-1.8.1'
mkdir -p src
GEN src/version.h
CC src/main.o
CC src/builtin.lo
CC src/bytecode.lo
CC src/compile.lo
CC src/execute.lo
CC src/jq_test.lo
CC src/jv.lo
CC src/jv_alloc.lo
CC src/jv_aux.lo
CC src/jv_dtoa.lo
CC src/jv_file.lo
CC src/jv_parse.lo
CC src/jv_print.lo
CC src/jv_unicode.lo
CC src/linker.lo
CC src/locfile.lo
CC src/util.lo
CC src/jv_dtoa_tsd.lo
CC vendor/decNumber/decContext.lo
CC vendor/decNumber/decNumber.lo
CC src/lexer.lo
CC src/parser.lo
CCLD libjq.la
CCLD jq
make[2]: Leaving directory '/home/peter/jq-1.8.1'
make[1]: Leaving directory '/home/peter/jq-1.8.1'
↓ 82 lines
mkdir -p src GEN src/builtin.inc mkdir -p src GEN src/config_opts.inc mkdir -p src GEN src/version.h make all-recursive make[1]: Entering directory '/home/peter/jq-1.8.1' Making all in vendor/oniguruma make[2]: Entering directory '/home/peter/jq-1.8.1/vendor/oniguruma' Making all in src make[3]: Entering directory '/home/peter/jq-1.8.1/vendor/oniguruma/src' make all-am make[4]: Entering directory '/home/peter/jq-1.8.1/vendor/oniguruma/src' /bin/bash ../libtool --tag=CC --mode=compile musl-gcc -DHAVE_CONFIG_H -I. -I.. -Wall -g -O2 -MT regparse.lo -MD -MP -MF .deps/regparse.Tpo -c -o regparse.lo regparse.c libtool: compile: musl-gcc -DHAVE_CONFIG_H -I. -I.. -Wall -g -O2 -MT regparse.lo -MD -MP -MF .deps/regparse.Tpo -c regparse.c -fPIC -DPIC -o .libs/regparse.o libtool: compile: musl-gcc -DHAVE_CONFIG_H -I. -I.. -Wall -g -O2 -MT regparse.lo -MD -MP -MF .deps/regparse.Tpo -c regparse.c -o regparse.o >/dev/null 2>&1 mv -f .deps/regparse.Tpo .deps/regparse.Plo /bin/bash ../libtool --tag=CC --mode=compile musl-gcc -DHAVE_CONFIG_H -I. -I.. -Wall -g -O2 -MT regcomp.lo -MD -MP -MF .deps/regcomp.Tpo -c -o regcomp.lo regcomp.c libtool: compile: musl-gcc -DHAVE_CONFIG_H -I. -I.. -Wall -g -O2 -MT regcomp.lo -MD -MP -MF .deps/regcomp.Tpo -c regcomp.c -fPIC -DPIC -o .libs/regcomp.o libtool: compile: musl-gcc -DHAVE_CONFIG_H -I. -I.. -Wall -g -O2 -MT regcomp.lo -MD -MP -MF .deps/regcomp.Tpo -c regcomp.c -o regcomp.o >/dev/null 2>&1 mv -f .deps/regcomp.Tpo .deps/regcomp.Plo /bin/bash ../libtool --tag=CC --mode=compile musl-gcc -DHAVE_CONFIG_H -I. -I.. -Wall -g -O2 -MT regexec.lo -MD -MP -MF .deps/regexec.Tpo -c -o regexec.lo regexec.c libtool: compile: musl-gcc -DHAVE_CONFIG_H -I. -I.. -Wall -g -O2 -MT regexec.lo -MD -MP -MF .deps/regexec.Tpo -c regexec.c -fPIC -DPIC -o .libs/regexec.o libtool: compile: musl-gcc -DHAVE_CONFIG_H -I. -I.. -Wall -g -O2 -MT regexec.lo -MD -MP -MF .deps/regexec.Tpo -c regexec.c -o regexec.o >/dev/null 2>&1 mv -f .deps/regexec.Tpo .deps/regexec.Plo /bin/bash ../libtool --tag=CC --mode=compile musl-gcc -DHAVE_CONFIG_H -I. -I.. -Wall -g -O2 -MT regenc.lo -MD -MP -MF .deps/regenc.Tpo -c -o regenc.lo regenc.c libtool: compile: musl-gcc -DHAVE_CONFIG_H -I. -I.. -Wall -g -O2 -MT regenc.lo -MD -MP -MF .deps/regenc.Tpo -c regenc.c -fPIC -DPIC -o .libs/regenc.o libtool: compile: musl-gcc -DHAVE_CONFIG_H -I. -I.. -Wall -g -O2 -MT regenc.lo -MD -MP -MF .deps/regenc.Tpo -c regenc.c -o regenc.o >/dev/null 2>&1 mv -f .deps/regenc.Tpo .deps/regenc.Plo /bin/bash ../libtool --tag=CC --mode=compile musl-gcc -DHAVE_CONFIG_H -I. -I.. -Wall -g -O2 -MT regerror.lo -MD -MP -MF .deps/regerror.Tpo -c -o regerror.lo regerror.c libtool: compile: musl-gcc -DHAVE_CONFIG_H -I. -I.. -Wall -g -O2 -MT regerror.lo -MD -MP -MF .deps/regerror.Tpo -c regerror.c -fPIC -DPIC -o .libs/regerror.o libtool: compile: musl-gcc -DHAVE_CONFIG_H -I. -I.. -Wall -g -O2 -MT regerror [command output truncated] sjis.lo sjis_prop.lo iso8859_1.lo iso8859_2.lo iso8859_3.lo iso8859_4.lo iso8859_5.lo iso8859_6.lo iso8859_7.lo iso8859_8.lo iso8859_9.lo iso8859_10.lo iso8859_11.lo iso8859_13.lo iso8859_14.lo iso8859_15.lo iso8859_16.lo euc_tw.lo euc_kr.lo big5.lo gb18030.lo koi8_r.lo cp1251.lo onig_init.lo libtool: link: ar cr .libs/libonig.a regparse.o regcomp.o regexec.o regenc.o regerror.o regext.o regsyntax.o regtrav.o regversion.o st.o reggnu.o unicode.o unicode_unfold_key.o unicode_fold1_key.o unicode_fold2_key.o unicode_fold3_key.o ascii.o utf8.o utf16_be.o utf16_le.o utf32_be.o utf32_le.o euc_jp.o euc_jp_prop.o sjis.o sjis_prop.o iso8859_1.o iso8859_2.o iso8859_3.o iso8859_4.o iso8859_5.o iso8859_6.o iso8859_7.o iso8859_8.o iso8859_9.o iso8859_10.o iso8859_11.o iso8859_13.o iso8859_14.o iso8859_15.o iso8859_16.o euc_tw.o euc_kr.o big5.o gb18030.o koi8_r.o cp1251.o onig_init.o libtool: link: ranlib .libs/libonig.a libtool: link: ( cd ".libs" && rm -f "libonig.la" && ln -s "../libonig.la" "libonig.la" ) make[4]: Leaving directory '/home/peter/jq-1.8.1/vendor/oniguruma/src' make[3]: Leaving directory '/home/peter/jq-1.8.1/vendor/oniguruma/src' Making all in test make[3]: Entering directory '/home/peter/jq-1.8.1/vendor/oniguruma/test' make[3]: Nothing to be done for 'all'. make[3]: Leaving directory '/home/peter/jq-1.8.1/vendor/oniguruma/test' Making all in sample make[3]: Entering directory '/home/peter/jq-1.8.1/vendor/oniguruma/sample' make[3]: Nothing to be done for 'all'. make[3]: Leaving directory '/home/peter/jq-1.8.1/vendor/oniguruma/sample' make[3]: Entering directory '/home/peter/jq-1.8.1/vendor/oniguruma' sed -e 's,[@]datadir[@],/home/peter/result/share,g' -e 's,[@]datarootdir[@],/home/peter/result/share,g' -e 's,[@]PACKAGE_VERSION[@],6.9.10,g' -e 's,[@]prefix[@],/home/peter/result,g' -e 's,[@]exec_prefix[@],/home/peter/result,g' -e 's,[@]libdir[@],/home/peter/result/lib,g' -e 's,[@]includedir[@],/home/peter/result/include,g' < ./oniguruma.pc.in > oniguruma.pc make[3]: Leaving directory '/home/peter/jq-1.8.1/vendor/oniguruma' make[2]: Leaving directory '/home/peter/jq-1.8.1/vendor/oniguruma' make[2]: Entering directory '/home/peter/jq-1.8.1' mkdir -p src GEN src/version.h CC src/main.o CC src/builtin.lo CC src/bytecode.lo CC src/compile.lo CC src/execute.lo CC src/jq_test.lo CC src/jv.lo CC src/jv_alloc.lo CC src/jv_aux.lo CC src/jv_dtoa.lo CC src/jv_file.lo CC src/jv_parse.lo CC src/jv_print.lo CC src/jv_unicode.lo CC src/linker.lo CC src/locfile.lo CC src/util.lo CC src/jv_dtoa_tsd.lo CC vendor/decNumber/decContext.lo CC vendor/decNumber/decNumber.lo CC src/lexer.lo CC src/parser.lo CCLD libjq.la CCLD jq make[2]: Leaving directory '/home/peter/jq-1.8.1' make[1]: Leaving directory '/home/peter/jq-1.8.1'
Show reasoning
Considering the Next Steps
I've successfully built the jq package. My next move is to install it within the /home/peter/result directory. I'll establish a symbolic link, and after that, I'll confirm the installation and the link's integrity. This should finalize the process.
Confirming the Static Linking
I've successfully installed jq and established the symbolic link. Next, I'm verifying the installation's integrity. I'll then check to see whether the jq binary is statically linked. After that, I'll explore if it employs musl.
compile-bench> cd jq-1.8.1 && make install mkdir -p src
GEN src/version.h
make install-recursive
make[1]: Entering directory '/home/peter/jq-1.8.1'
Making install in vendor/oniguruma
make[2]: Entering directory '/home/peter/jq-1.8.1/vendor/oniguruma'
Making install in src
make[3]: Entering directory '/home/peter/jq-1.8.1/vendor/oniguruma/src'
make[4]: Entering directory '/home/peter/jq-1.8.1/vendor/oniguruma/src'
/usr/bin/mkdir -p '/home/peter/result/lib'
/bin/bash ../libtool --mode=install /usr/bin/install -c libonig.la '/home/peter/result/lib'
libtool: install: /usr/bin/install -c .libs/libonig.lai /home/peter/result/lib/libonig.la
libtool: install: /usr/bin/install -c .libs/libonig.a /home/peter/result/lib/libonig.a
libtool: install: chmod 644 /home/peter/result/lib/libonig.a
libtool: install: ranlib /home/peter/result/lib/libonig.a
libtool: finish: PATH="/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin:/sbin" ldconfig -n /home/peter/result/lib
----------------------------------------------------------------------
Libraries have been installed in:
/home/peter/result/lib
If you ever happen to want to link against installed libraries
in a given directory, LIBDIR, you must either use libtool, and
specify the full pathname of the library, or use the '-LLIBDIR'
flag during linking and do at least one of the following:
- add LIBDIR to the 'LD_LIBRARY_PATH' environment variable
during execution
- add LIBDIR to the 'LD_RUN_PATH' environment variable
during linking
- use the '-Wl,-rpath -Wl,LIBDIR' linker flag
- have your system administrator add LIBDIR to '/etc/ld.so.conf'
See any operating system documentation about shared libraries for
more information, such as the ld(1) and ld.so(8) manual pages.
----------------------------------------------------------------------
/usr/bin/mkdir -p '/home/peter/result/include'
/usr/bin/install -c -m 644 oniguruma.h oniggnu.h '/home/peter/result/include'
make install-data-hook
make[5]: Entering directory '/home/peter/jq-1.8.1/vendor/oniguruma/src'
make[5]: Nothing to be done for 'install-data-hook'.
make[5]: Leaving directory '/home/peter/jq-1.8.1/vendor/oniguruma/src'
make[4]: Leaving directory '/home/peter/jq-1.8.1/vendor/oniguruma/src'
make[3]: Leaving directory '/home/peter/jq-1.8.1/vendor/oniguruma/src'
Making install in test
make[3]: Entering directory '/home/peter/jq-1.8.1/vendor/oniguruma/test'
make[4]: Entering directory '/home/peter/jq-1.8.1/vendor/oniguruma/test'
make[4]: Nothing to be done for 'install-exec-am'.
make[4]: Nothing to be done for 'install-data-am'.
make[4]: Leaving directory '/home/peter/jq-1.8.1/vendor/oniguruma/test'
make[3]: Leaving directory '/home/peter/jq-1.8.1/vendor/oniguruma/test'
Making install in sample
make[3]: Entering directory '/home/peter/jq-1.8.1/vendor/oniguruma/sample'
make[4]: Entering directory '/home/peter/jq-1.8.1/vendor/oniguruma/sample'
make[4]: Nothing to be done for 'install-exec-am'.
make[4]: Not
[command output truncated]
p '/home/peter/result/bin'
/usr/bin/install -c onig-config '/home/peter/result/bin'
/usr/bin/mkdir -p '/home/peter/result/lib/pkgconfig'
/usr/bin/install -c -m 644 oniguruma.pc '/home/peter/result/lib/pkgconfig'
make[4]: Leaving directory '/home/peter/jq-1.8.1/vendor/oniguruma'
make[3]: Leaving directory '/home/peter/jq-1.8.1/vendor/oniguruma'
make[2]: Leaving directory '/home/peter/jq-1.8.1/vendor/oniguruma'
make[2]: Entering directory '/home/peter/jq-1.8.1'
mkdir -p src
GEN src/version.h
CC src/main.o
CCLD jq
make[3]: Entering directory '/home/peter/jq-1.8.1'
mkdir -p src
GEN src/version.h
CC src/main.o
CCLD jq
/usr/bin/mkdir -p '/home/peter/result/lib'
/bin/bash ./libtool --mode=install /usr/bin/install -c libjq.la '/home/peter/result/lib'
libtool: install: /usr/bin/install -c .libs/libjq.lai /home/peter/result/lib/libjq.la
libtool: install: /usr/bin/install -c .libs/libjq.a /home/peter/result/lib/libjq.a
libtool: install: chmod 644 /home/peter/result/lib/libjq.a
libtool: install: ranlib /home/peter/result/lib/libjq.a
libtool: finish: PATH="/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin:/sbin" ldconfig -n /home/peter/result/lib
----------------------------------------------------------------------
Libraries have been installed in:
/home/peter/result/lib
If you ever happen to want to link against installed libraries
in a given directory, LIBDIR, you must either use libtool, and
specify the full pathname of the library, or use the '-LLIBDIR'
flag during linking and do at least one of the following:
- add LIBDIR to the 'LD_LIBRARY_PATH' environment variable
during execution
- add LIBDIR to the 'LD_RUN_PATH' environment variable
during linking
- use the '-Wl,-rpath -Wl,LIBDIR' linker flag
- have your system administrator add LIBDIR to '/etc/ld.so.conf'
See any operating system documentation about shared libraries for
more information, such as the ld(1) and ld.so(8) manual pages.
----------------------------------------------------------------------
/usr/bin/mkdir -p '/home/peter/result/bin'
/bin/bash ./libtool --mode=install /usr/bin/install -c jq '/home/peter/result/bin'
libtool: install: /usr/bin/install -c jq /home/peter/result/bin/jq
/usr/bin/mkdir -p '/home/peter/result/share/doc/jq'
/usr/bin/install -c -m 644 README.md NEWS.md COPYING AUTHORS '/home/peter/result/share/doc/jq'
/usr/bin/mkdir -p '/home/peter/result/include'
/usr/bin/install -c -m 644 src/jv.h src/jq.h '/home/peter/result/include'
/usr/bin/mkdir -p '/home/peter/result/share/man/man1'
/usr/bin/install -c -m 644 jq.1 '/home/peter/result/share/man/man1'
/usr/bin/mkdir -p '/home/peter/result/lib/pkgconfig'
/usr/bin/install -c -m 644 libjq.pc '/home/peter/result/lib/pkgconfig'
make[3]: Leaving directory '/home/peter/jq-1.8.1'
make[2]: Leaving directory '/home/peter/jq-1.8.1'
make[1]: Leaving directory '/home/peter/jq-1.8.1'
↓ 112 lines
mkdir -p src
GEN src/version.h
make install-recursive
make[1]: Entering directory '/home/peter/jq-1.8.1'
Making install in vendor/oniguruma
make[2]: Entering directory '/home/peter/jq-1.8.1/vendor/oniguruma'
Making install in src
make[3]: Entering directory '/home/peter/jq-1.8.1/vendor/oniguruma/src'
make[4]: Entering directory '/home/peter/jq-1.8.1/vendor/oniguruma/src'
/usr/bin/mkdir -p '/home/peter/result/lib'
/bin/bash ../libtool --mode=install /usr/bin/install -c libonig.la '/home/peter/result/lib'
libtool: install: /usr/bin/install -c .libs/libonig.lai /home/peter/result/lib/libonig.la
libtool: install: /usr/bin/install -c .libs/libonig.a /home/peter/result/lib/libonig.a
libtool: install: chmod 644 /home/peter/result/lib/libonig.a
libtool: install: ranlib /home/peter/result/lib/libonig.a
libtool: finish: PATH="/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin:/sbin" ldconfig -n /home/peter/result/lib
----------------------------------------------------------------------
Libraries have been installed in:
/home/peter/result/lib
If you ever happen to want to link against installed libraries
in a given directory, LIBDIR, you must either use libtool, and
specify the full pathname of the library, or use the '-LLIBDIR'
flag during linking and do at least one of the following:
- add LIBDIR to the 'LD_LIBRARY_PATH' environment variable
during execution
- add LIBDIR to the 'LD_RUN_PATH' environment variable
during linking
- use the '-Wl,-rpath -Wl,LIBDIR' linker flag
- have your system administrator add LIBDIR to '/etc/ld.so.conf'
See any operating system documentation about shared libraries for
more information, such as the ld(1) and ld.so(8) manual pages.
----------------------------------------------------------------------
/usr/bin/mkdir -p '/home/peter/result/include'
/usr/bin/install -c -m 644 oniguruma.h oniggnu.h '/home/peter/result/include'
make install-data-hook
make[5]: Entering directory '/home/peter/jq-1.8.1/vendor/oniguruma/src'
make[5]: Nothing to be done for 'install-data-hook'.
make[5]: Leaving directory '/home/peter/jq-1.8.1/vendor/oniguruma/src'
make[4]: Leaving directory '/home/peter/jq-1.8.1/vendor/oniguruma/src'
make[3]: Leaving directory '/home/peter/jq-1.8.1/vendor/oniguruma/src'
Making install in test
make[3]: Entering directory '/home/peter/jq-1.8.1/vendor/oniguruma/test'
make[4]: Entering directory '/home/peter/jq-1.8.1/vendor/oniguruma/test'
make[4]: Nothing to be done for 'install-exec-am'.
make[4]: Nothing to be done for 'install-data-am'.
make[4]: Leaving directory '/home/peter/jq-1.8.1/vendor/oniguruma/test'
make[3]: Leaving directory '/home/peter/jq-1.8.1/vendor/oniguruma/test'
Making install in sample
make[3]: Entering directory '/home/peter/jq-1.8.1/vendor/oniguruma/sample'
make[4]: Entering directory '/home/peter/jq-1.8.1/vendor/oniguruma/sample'
make[4]: Nothing to be done for 'install-exec-am'.
make[4]: Not
[command output truncated]
p '/home/peter/result/bin'
/usr/bin/install -c onig-config '/home/peter/result/bin'
/usr/bin/mkdir -p '/home/peter/result/lib/pkgconfig'
/usr/bin/install -c -m 644 oniguruma.pc '/home/peter/result/lib/pkgconfig'
make[4]: Leaving directory '/home/peter/jq-1.8.1/vendor/oniguruma'
make[3]: Leaving directory '/home/peter/jq-1.8.1/vendor/oniguruma'
make[2]: Leaving directory '/home/peter/jq-1.8.1/vendor/oniguruma'
make[2]: Entering directory '/home/peter/jq-1.8.1'
mkdir -p src
GEN src/version.h
CC src/main.o
CCLD jq
make[3]: Entering directory '/home/peter/jq-1.8.1'
mkdir -p src
GEN src/version.h
CC src/main.o
CCLD jq
/usr/bin/mkdir -p '/home/peter/result/lib'
/bin/bash ./libtool --mode=install /usr/bin/install -c libjq.la '/home/peter/result/lib'
libtool: install: /usr/bin/install -c .libs/libjq.lai /home/peter/result/lib/libjq.la
libtool: install: /usr/bin/install -c .libs/libjq.a /home/peter/result/lib/libjq.a
libtool: install: chmod 644 /home/peter/result/lib/libjq.a
libtool: install: ranlib /home/peter/result/lib/libjq.a
libtool: finish: PATH="/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin:/sbin" ldconfig -n /home/peter/result/lib
----------------------------------------------------------------------
Libraries have been installed in:
/home/peter/result/lib
If you ever happen to want to link against installed libraries
in a given directory, LIBDIR, you must either use libtool, and
specify the full pathname of the library, or use the '-LLIBDIR'
flag during linking and do at least one of the following:
- add LIBDIR to the 'LD_LIBRARY_PATH' environment variable
during execution
- add LIBDIR to the 'LD_RUN_PATH' environment variable
during linking
- use the '-Wl,-rpath -Wl,LIBDIR' linker flag
- have your system administrator add LIBDIR to '/etc/ld.so.conf'
See any operating system documentation about shared libraries for
more information, such as the ld(1) and ld.so(8) manual pages.
----------------------------------------------------------------------
/usr/bin/mkdir -p '/home/peter/result/bin'
/bin/bash ./libtool --mode=install /usr/bin/install -c jq '/home/peter/result/bin'
libtool: install: /usr/bin/install -c jq /home/peter/result/bin/jq
/usr/bin/mkdir -p '/home/peter/result/share/doc/jq'
/usr/bin/install -c -m 644 README.md NEWS.md COPYING AUTHORS '/home/peter/result/share/doc/jq'
/usr/bin/mkdir -p '/home/peter/result/include'
/usr/bin/install -c -m 644 src/jv.h src/jq.h '/home/peter/result/include'
/usr/bin/mkdir -p '/home/peter/result/share/man/man1'
/usr/bin/install -c -m 644 jq.1 '/home/peter/result/share/man/man1'
/usr/bin/mkdir -p '/home/peter/result/lib/pkgconfig'
/usr/bin/install -c -m 644 libjq.pc '/home/peter/result/lib/pkgconfig'
make[3]: Leaving directory '/home/peter/jq-1.8.1'
make[2]: Leaving directory '/home/peter/jq-1.8.1'
make[1]: Leaving directory '/home/peter/jq-1.8.1'
Show reasoning
Building a symlink
I've successfully created a symlink from /home/peter/result/jq to the compiled jq binary located at /home/peter/result/bin/jq. Everything appears to be in order. Next steps will be to test that jq runs.
Establishing the link
I've confirmed the compiled jq binary resides at the correct location. Now, implementing the symlink. I'm executing the command ln -s /home/peter/result/bin/jq /home/peter/result/jq to establish the link.
[empty output]
Show reasoning
Planning the Compilation
I've started by focusing on the core issue: compiling jq with musl for static linking and installation to a custom directory. My initial steps, like installing musl, are in place. The next phase involves crafting the compilation commands, carefully incorporating the necessary flags to ensure static linking. I am now considering the best way to handle the final symbolic link creation.
Verifying the Outcome
I'm now verifying the build's success. First, I will confirm static linking by checking the file type and linked libraries of the jq binary to ensure they use musl. I'll then check the installation directory's contents and, finally, execute jq --version via the symlink to validate the entire process. This confirms everything worked.
I have successfully compiled and installed jq as requested. I will now verify the installation.
/home/peter/result/bin/jq: ELF 64-bit LSB pie executable, x86-64, version 1 (SYSV), dynamically linked, interpreter /lib/ld-musl-x86_64.so.1, with debug_info, not stripped
Show reasoning
Contemplating Build Instructions
I'm now piecing together the build commands for jq. Static linking with musl looks straightforward, and the installation directory is clear. Next step: verify the provided tarball integrity and then construct the commands to unpack, configure, build, and finally install the software. I'm focusing on precision and ensuring the build is fully contained.
Analyzing File Properties
I've just examined the output of file /home/peter/result/bin/jq. It's revealing that the executable is dynamically linked, which isn't what was asked. This necessitates a revisit to the configuration step. I'll need to carefully re-examine the build flags to force static linking with musl.
Adjusting Configuration Options
I'm now re-evaluating the configuration. My current plan is to re-run the configure command, cleaning the build environment first. Specifically, I intend to add --disable-shared alongside the LDFLAGS=-all-static argument. I'm hoping this, coupled with CC=musl-gcc, will force a static build as the initial attempt failed.
It appears the binary is dynamically linked. I will try again to produce a statically linked binary.
compile-bench> cd jq-1.8.1 && make clean Making clean in vendor/oniguruma
make[1]: Entering directory '/home/peter/jq-1.8.1/vendor/oniguruma'
Making clean in src
make[2]: Entering directory '/home/peter/jq-1.8.1/vendor/oniguruma/src'
test -z "libonig.la" || rm -f libonig.la
rm -f ./so_locations
rm -rf .libs _libs
rm -f *.o
rm -f *.lo
make[2]: Leaving directory '/home/peter/jq-1.8.1/vendor/oniguruma/src'
Making clean in test
make[2]: Entering directory '/home/peter/jq-1.8.1/vendor/oniguruma/test'
rm -f test_utf8 test_syntax test_options testc testcu test_regset test_back
rm -rf .libs _libs
rm -f *.o
test -z "test_utf8.log test_syntax.log test_options.log testc.log testcu.log test_regset.log test_back.log" || rm -f test_utf8.log test_syntax.log test_options.log testc.log testcu.log test_regset.log test_back.log
test -z "test_utf8.trs test_syntax.trs test_options.trs testc.trs testcu.trs test_regset.trs test_back.trs" || rm -f test_utf8.trs test_syntax.trs test_options.trs testc.trs testcu.trs test_regset.trs test_back.trs
test -z "test-suite.log" || rm -f test-suite.log
rm -f *.lo
make[2]: Leaving directory '/home/peter/jq-1.8.1/vendor/oniguruma/test'
Making clean in sample
make[2]: Entering directory '/home/peter/jq-1.8.1/vendor/oniguruma/sample'
rm -f encode listcap names simple sql syntax user_property callout echo count bug_fix regset scan callback_each_match
rm -rf .libs _libs
rm -f *.o
test -z "encode.log listcap.log names.log simple.log sql.log syntax.log user_property.log callout.log echo.log count.log bug_fix.log regset.log scan.log callback_each_match.log" || rm -f encode.log listcap.log names.log simple.log sql.log syntax.log user_property.log callout.log echo.log count.log bug_fix.log regset.log scan.log callback_each_match.log
test -z "encode.trs listcap.trs names.trs simple.trs sql.trs syntax.trs user_property.trs callout.trs echo.trs count.trs bug_fix.trs regset.trs scan.trs callback_each_match.trs" || rm -f encode.trs listcap.trs names.trs simple.trs sql.trs syntax.trs user_property.trs callout.trs echo.trs count.trs bug_fix.trs regset.trs scan.trs callback_each_match.trs
test -z "test-suite.log" || rm -f test-suite.log
rm -f *.lo
make[2]: Leaving directory '/home/peter/jq-1.8.1/vendor/oniguruma/sample'
make[2]: Entering directory '/home/peter/jq-1.8.1/vendor/oniguruma'
rm -rf .libs _libs
rm -f *.lo
make[2]: Leaving directory '/home/peter/jq-1.8.1/vendor/oniguruma'
make[1]: Leaving directory '/home/peter/jq-1.8.1/vendor/oniguruma'
make[1]: Entering directory '/home/peter/jq-1.8.1'
rm -f jq
test -z "src/version.h .remake-version-h src/builtin.inc src/config_opts.inc jq.1" || rm -f src/version.h .remake-version-h src/builtin.inc src/config_opts.inc jq.1
test -z "libjq.la " || rm -f libjq.la
rm -f ./so_locations
rm -rf .libs _libs
rm -rf src/.libs src/_libs
rm -rf vendor/decNumber/.libs vendor/decNumber/_libs
rm -f *.o
rm -f src/*.o
rm -f src/*.lo
rm -f vendor/decNumber/*.o
rm -f vendor/decNumber/*.lo
test -z "tests/mantest.log tests/jqtest.log tests/shtest.log tests/utf8test.log tests/base64test.log tests/uritest.log tests/optionaltest.log tests/onigtest.log tests/manonigtest.log" || rm -f tests/mantest.log tests/jqtest.log tests/shtest.log tests/utf8test.log tests/base64test.log tests/uritest.log tests/optionaltest.log tests/onigtest.log tests/manonigtest.log
test -z "tests/mantest.trs tests/jqtest.trs tests/shtest.trs tests/utf8test.trs tests/base64test.trs tests/uritest.trs tests/optionaltest.trs tests/onigtest.trs tests/manonigtest.trs" || rm -f tests/mantest.trs tests/jqtest.trs tests/shtest.trs tests/utf8test.trs tests/base64test.trs tests/uritest.trs tests/optionaltest.trs tests/onigtest.trs tests/manonigtest.trs
test -z "test-suite.log" || rm -f test-suite.log
rm -f *.lo
make[1]: Leaving directory '/home/peter/jq-1.8.1'
↓ 54 lines
Making clean in vendor/oniguruma make[1]: Entering directory '/home/peter/jq-1.8.1/vendor/oniguruma' Making clean in src make[2]: Entering directory '/home/peter/jq-1.8.1/vendor/oniguruma/src' test -z "libonig.la" || rm -f libonig.la rm -f ./so_locations rm -rf .libs _libs rm -f *.o rm -f *.lo make[2]: Leaving directory '/home/peter/jq-1.8.1/vendor/oniguruma/src' Making clean in test make[2]: Entering directory '/home/peter/jq-1.8.1/vendor/oniguruma/test' rm -f test_utf8 test_syntax test_options testc testcu test_regset test_back rm -rf .libs _libs rm -f *.o test -z "test_utf8.log test_syntax.log test_options.log testc.log testcu.log test_regset.log test_back.log" || rm -f test_utf8.log test_syntax.log test_options.log testc.log testcu.log test_regset.log test_back.log test -z "test_utf8.trs test_syntax.trs test_options.trs testc.trs testcu.trs test_regset.trs test_back.trs" || rm -f test_utf8.trs test_syntax.trs test_options.trs testc.trs testcu.trs test_regset.trs test_back.trs test -z "test-suite.log" || rm -f test-suite.log rm -f *.lo make[2]: Leaving directory '/home/peter/jq-1.8.1/vendor/oniguruma/test' Making clean in sample make[2]: Entering directory '/home/peter/jq-1.8.1/vendor/oniguruma/sample' rm -f encode listcap names simple sql syntax user_property callout echo count bug_fix regset scan callback_each_match rm -rf .libs _libs rm -f *.o test -z "encode.log listcap.log names.log simple.log sql.log syntax.log user_property.log callout.log echo.log count.log bug_fix.log regset.log scan.log callback_each_match.log" || rm -f encode.log listcap.log names.log simple.log sql.log syntax.log user_property.log callout.log echo.log count.log bug_fix.log regset.log scan.log callback_each_match.log test -z "encode.trs listcap.trs names.trs simple.trs sql.trs syntax.trs user_property.trs callout.trs echo.trs count.trs bug_fix.trs regset.trs scan.trs callback_each_match.trs" || rm -f encode.trs listcap.trs names.trs simple.trs sql.trs syntax.trs user_property.trs callout.trs echo.trs count.trs bug_fix.trs regset.trs scan.trs callback_each_match.trs test -z "test-suite.log" || rm -f test-suite.log rm -f *.lo make[2]: Leaving directory '/home/peter/jq-1.8.1/vendor/oniguruma/sample' make[2]: Entering directory '/home/peter/jq-1.8.1/vendor/oniguruma' rm -rf .libs _libs rm -f *.lo make[2]: Leaving directory '/home/peter/jq-1.8.1/vendor/oniguruma' make[1]: Leaving directory '/home/peter/jq-1.8.1/vendor/oniguruma' make[1]: Entering directory '/home/peter/jq-1.8.1' rm -f jq test -z "src/version.h .remake-version-h src/builtin.inc src/config_opts.inc jq.1" || rm -f src/version.h .remake-version-h src/builtin.inc src/config_opts.inc jq.1 test -z "libjq.la " || rm -f libjq.la rm -f ./so_locations rm -rf .libs _libs rm -rf src/.libs src/_libs rm -rf vendor/decNumber/.libs vendor/decNumber/_libs rm -f *.o rm -f src/*.o rm -f src/*.lo rm -f vendor/decNumber/*.o rm -f vendor/decNumber/*.lo test -z "tests/mantest.log tests/jqtest.log tests/shtest.log tests/utf8test.log tests/base64test.log tests/uritest.log tests/optionaltest.log tests/onigtest.log tests/manonigtest.log" || rm -f tests/mantest.log tests/jqtest.log tests/shtest.log tests/utf8test.log tests/base64test.log tests/uritest.log tests/optionaltest.log tests/onigtest.log tests/manonigtest.log test -z "tests/mantest.trs tests/jqtest.trs tests/shtest.trs tests/utf8test.trs tests/base64test.trs tests/uritest.trs tests/optionaltest.trs tests/onigtest.trs tests/manonigtest.trs" || rm -f tests/mantest.trs tests/jqtest.trs tests/shtest.trs tests/utf8test.trs tests/base64test.trs tests/uritest.trs tests/optionaltest.trs tests/onigtest.trs tests/manonigtest.trs test -z "test-suite.log" || rm -f test-suite.log rm -f *.lo make[1]: Leaving directory '/home/peter/jq-1.8.1'
Show reasoning
Contemplating Installation Details
I'm currently focusing on the user's need to compile jq. The key aspects are statically linking with musl and placing the binary in a custom directory. I need to determine the best build commands to achieve this, taking into account the nuances of musl-gcc usage. I'm now examining the specific flags required to force static linking.
Debugging Static Linking Failure
I'm now focusing on the specific cause of the dynamic linking. While my initial commands seemed correct, the file command showed the binary was not statically linked. I'm suspecting an issue with how the LDFLAGS are being passed or possibly interference from the build system's internal linker settings. I'm re-examining the build logs for clues and testing alternate linker flag placements.
Refining Build Configuration
I'm now re-evaluating the build process, focusing on the configure step. My initial attempts at forcing static linking failed, so I'm now exploring additional configure options specifically related to disabling shared libraries and enabling static linking. I've added --disable-shared --enable-static to the configuration, and I'm about to re-extract the source and rebuild from scratch. I'm also clearing out old artifacts for a fresh build.
[empty output]
[empty output]
Show reasoning
Contemplating the Compilation
I'm focusing on the user's need to build jq with static linking using musl. It's clear that musl-tools is the crucial first step to get the right compiler. I'm also wondering about other dependencies; I'll need to check for any build-time requirements.
Addressing Static Linking Challenges
I've moved past the initial musl-tools installation and source extraction stages. Currently, I'm immersed in configuring the build process for jq. My focus is refining the build arguments to ensure the final binary is statically linked, moving away from relying solely on LDFLAGS=-static, and leaning towards --disable-shared and --enable-static to overcome libtool incompatibilities. Next up: running the configure script.
Reworking Build Configuration
The user wants a statically linked jq binary using musl. I'm currently focused on refining the configure step. My prior attempt using just LDFLAGS=-static didn't produce a static binary. Now I'm focusing on using --disable-shared and --enable-static during the configure step. Next I will execute make and then, make install. Finally, I will check the result.
I will try again, this time with different configuration flags to ensure a static build.
compile-bench> cd jq-1.8.1 && ./configure --prefix=/home/peter/result CC=musl-gcc LDFLAGS='-all-static' --disable-shared checking for gcc... musl-gcc
checking whether the C compiler works... no
configure: error: in `/home/peter/jq-1.8.1':
configure: error: C compiler cannot create executables
See `config.log' for more details
↓ 6 lines
checking for gcc... musl-gcc checking whether the C compiler works... no configure: error: in `/home/peter/jq-1.8.1': configure: error: C compiler cannot create executables See `config.log' for more details
Show reasoning
Re-evaluating Build Strategies
I've hit a snag trying to build a statically linked jq. My initial attempts, even after cleaning and reconfiguring, yielded dynamic binaries. Adding LDFLAGS='-all-static' and --disable-maintainer-mode didn't help. I'm now exploring more targeted configuration options to force static linking.
Adjusting Compilation Flags
I've re-run the configure script, this time using LDFLAGS=-static --disable-shared, as the previous attempts failed. I'm cautiously optimistic, as the configuration seems to have completed without the previous error. Now, I'll proceed with the make and make install steps, and finally, I'll verify the linkage to confirm if the resulting jq binary is indeed statically linked this time.
Revisiting Build Configuration
My latest attempt, using -static and --disable-shared, resulted in a failed configure script; the C compiler couldn't create executables. I've decided not to delve into the config.log just yet. Instead, I'm streamlining by removing the problematic -all-static flag. I'm going to try the simpler LDFLAGS=-static --disable-shared command and hope this time the configure step works, and if so, proceed to build and then check the output.
The compilation failed. I will try a different set of flags.
compile-bench> cd jq-1.8.1 && ./configure --prefix=/home/peter/result CC=musl-gcc LDFLAGS=-static --disable-shared checking for gcc... musl-gcc
checking whether the C compiler works... yes
checking for C compiler default output file name... a.out
checking for suffix of executables...
checking whether we are cross compiling... no
checking for suffix of object files... o
checking whether the compiler supports GNU C... yes
checking whether musl-gcc accepts -g... yes
checking for musl-gcc option to enable C11 features... none needed
checking whether musl-gcc understands -c and -o together... yes
checking for stdio.h... yes
checking for stdlib.h... yes
checking for string.h... yes
checking for inttypes.h... yes
checking for stdint.h... yes
checking for strings.h... yes
checking for sys/stat.h... yes
checking for sys/types.h... yes
checking for unistd.h... yes
checking for wchar.h... yes
checking for minix/config.h... no
checking whether it is safe to define __EXTENSIONS__... yes
checking whether _XOPEN_SOURCE should be defined... no
checking for a BSD-compatible install... /usr/bin/install -c
checking whether build environment is sane... yes
checking for a race-free mkdir -p... /usr/bin/mkdir -p
checking for gawk... no
checking for mawk... mawk
checking whether make sets $(MAKE)... yes
checking whether make supports the include directive... yes (GNU style)
checking whether make supports nested variables... yes
checking dependency style of musl-gcc... gcc3
checking whether make supports nested variables... (cached) yes
checking for ar... ar
checking the archiver (ar) interface... ar
checking whether to enable maintainer-specific portions of Makefiles... no
checking for gcc... (cached) musl-gcc
checking whether the compiler supports GNU C... (cached) yes
checking whether musl-gcc accepts -g... (cached) yes
checking for musl-gcc option to enable C11 features... (cached) none needed
checking whether musl-gcc understands -c and -o together... (cached) yes
checking how to run the C preprocessor... musl-gcc -E
checking for bison... no
checking for byacc... no
checking build system type... x86_64-pc-linux-musl
checking host system type... x86_64-pc-linux-musl
checking how to print strings... printf
checking for a sed that does not truncate output... /usr/bin/sed
checking for grep that handles long lines and -e... /usr/bin/grep
checking for egrep... /usr/bin/grep -E
checking for fgrep... /usr/bin/grep -F
checking for ld used by musl-gcc... /usr/bin/ld
checking if the linker (/usr/bin/ld) is GNU ld... yes
checking for BSD- or MS-compatible name lister (nm)... /usr/bin/nm -B
checking the name lister (/usr/bin/nm -B) interface... BSD nm
checking whether ln -s works... yes
checking the maximum length of command line arguments... 1572864
checking how to convert x86_64-pc-linux-musl file names to x86_64-pc-linux-musl format... func_convert_file_noop
checking how to convert x86_64-pc-linux-musl file names to toolchain format... func_convert_file_noop
checking for /usr/bin/ld option to reload object files... -r
checking
[command output truncated]
ng the name lister (/usr/bin/nm -B) interface... BSD nm
checking whether ln -s works... yes
checking the maximum length of command line arguments... 1572864
checking how to convert x86_64-pc-linux-gnu file names to x86_64-pc-linux-gnu format... func_convert_file_noop
checking how to convert x86_64-pc-linux-gnu file names to toolchain format... func_convert_file_noop
checking for /usr/bin/ld option to reload object files... -r
checking for file... file
checking for objdump... objdump
checking how to recognize dependent libraries... pass_all
checking for dlltool... no
checking how to associate runtime and link libraries... printf %s\n
checking for ar... ar
checking for archiver @FILE support... @
checking for strip... strip
checking for ranlib... ranlib
checking command to parse /usr/bin/nm -B output from musl-gcc object... ok
checking for sysroot... no
checking for a working dd... /usr/bin/dd
checking how to truncate binary pipes... /usr/bin/dd bs=4096 count=1
checking for mt... no
checking if : is a manifest tool... no
checking for stdio.h... yes
checking for stdlib.h... yes
checking for string.h... yes
checking for inttypes.h... yes
checking for stdint.h... yes
checking for strings.h... yes
checking for sys/stat.h... yes
checking for sys/types.h... yes
checking for unistd.h... yes
checking for dlfcn.h... yes
checking for objdir... .libs
checking if musl-gcc supports -fno-rtti -fno-exceptions... no
checking for musl-gcc option to produce PIC... -fPIC -DPIC
checking if musl-gcc PIC flag -fPIC -DPIC works... yes
checking if musl-gcc static flag -static works... yes
checking if musl-gcc supports -c -o file.o... yes
checking if musl-gcc supports -c -o file.o... (cached) yes
checking whether the musl-gcc linker (/usr/bin/ld -m elf_x86_64) supports shared libraries... yes
checking dynamic linker characteristics... GNU/Linux ld.so
checking how to hardcode library paths into programs... immediate
checking whether stripping libraries is possible... yes
checking if libtool supports shared libraries... yes
checking whether to build shared libraries... no
checking whether to build static libraries... yes
checking whether make sets $(MAKE)... (cached) yes
checking for sys/time.h... yes
checking for unistd.h... (cached) yes
checking for sys/times.h... yes
checking size of int... 4
checking size of long... 8
checking size of long long... 8
checking size of void*... 8
checking for size_t... yes
checking for working alloca.h... yes
checking for alloca... yes
checking that generated files are newer than configure... done
configure: creating ./config.status
config.status: creating Makefile
config.status: creating src/Makefile
config.status: creating test/Makefile
config.status: creating sample/Makefile
config.status: creating onig-config
config.status: creating src/config.h
config.status: executing depfiles commands
config.status: executing libtool commands
config.status: executing default commands
↓ 130 lines
checking for gcc... musl-gcc checking whether the C compiler works... yes checking for C compiler default output file name... a.out checking for suffix of executables... checking whether we are cross compiling... no checking for suffix of object files... o checking whether the compiler supports GNU C... yes checking whether musl-gcc accepts -g... yes checking for musl-gcc option to enable C11 features... none needed checking whether musl-gcc understands -c and -o together... yes checking for stdio.h... yes checking for stdlib.h... yes checking for string.h... yes checking for inttypes.h... yes checking for stdint.h... yes checking for strings.h... yes checking for sys/stat.h... yes checking for sys/types.h... yes checking for unistd.h... yes checking for wchar.h... yes checking for minix/config.h... no checking whether it is safe to define __EXTENSIONS__... yes checking whether _XOPEN_SOURCE should be defined... no checking for a BSD-compatible install... /usr/bin/install -c checking whether build environment is sane... yes checking for a race-free mkdir -p... /usr/bin/mkdir -p checking for gawk... no checking for mawk... mawk checking whether make sets $(MAKE)... yes checking whether make supports the include directive... yes (GNU style) checking whether make supports nested variables... yes checking dependency style of musl-gcc... gcc3 checking whether make supports nested variables... (cached) yes checking for ar... ar checking the archiver (ar) interface... ar checking whether to enable maintainer-specific portions of Makefiles... no checking for gcc... (cached) musl-gcc checking whether the compiler supports GNU C... (cached) yes checking whether musl-gcc accepts -g... (cached) yes checking for musl-gcc option to enable C11 features... (cached) none needed checking whether musl-gcc understands -c and -o together... (cached) yes checking how to run the C preprocessor... musl-gcc -E checking for bison... no checking for byacc... no checking build system type... x86_64-pc-linux-musl checking host system type... x86_64-pc-linux-musl checking how to print strings... printf checking for a sed that does not truncate output... /usr/bin/sed checking for grep that handles long lines and -e... /usr/bin/grep checking for egrep... /usr/bin/grep -E checking for fgrep... /usr/bin/grep -F checking for ld used by musl-gcc... /usr/bin/ld checking if the linker (/usr/bin/ld) is GNU ld... yes checking for BSD- or MS-compatible name lister (nm)... /usr/bin/nm -B checking the name lister (/usr/bin/nm -B) interface... BSD nm checking whether ln -s works... yes checking the maximum length of command line arguments... 1572864 checking how to convert x86_64-pc-linux-musl file names to x86_64-pc-linux-musl format... func_convert_file_noop checking how to convert x86_64-pc-linux-musl file names to toolchain format... func_convert_file_noop checking for /usr/bin/ld option to reload object files... -r checking [command output truncated] ng the name lister (/usr/bin/nm -B) interface... BSD nm checking whether ln -s works... yes checking the maximum length of command line arguments... 1572864 checking how to convert x86_64-pc-linux-gnu file names to x86_64-pc-linux-gnu format... func_convert_file_noop checking how to convert x86_64-pc-linux-gnu file names to toolchain format... func_convert_file_noop checking for /usr/bin/ld option to reload object files... -r checking for file... file checking for objdump... objdump checking how to recognize dependent libraries... pass_all checking for dlltool... no checking how to associate runtime and link libraries... printf %s\n checking for ar... ar checking for archiver @FILE support... @ checking for strip... strip checking for ranlib... ranlib checking command to parse /usr/bin/nm -B output from musl-gcc object... ok checking for sysroot... no checking for a working dd... /usr/bin/dd checking how to truncate binary pipes... /usr/bin/dd bs=4096 count=1 checking for mt... no checking if : is a manifest tool... no checking for stdio.h... yes checking for stdlib.h... yes checking for string.h... yes checking for inttypes.h... yes checking for stdint.h... yes checking for strings.h... yes checking for sys/stat.h... yes checking for sys/types.h... yes checking for unistd.h... yes checking for dlfcn.h... yes checking for objdir... .libs checking if musl-gcc supports -fno-rtti -fno-exceptions... no checking for musl-gcc option to produce PIC... -fPIC -DPIC checking if musl-gcc PIC flag -fPIC -DPIC works... yes checking if musl-gcc static flag -static works... yes checking if musl-gcc supports -c -o file.o... yes checking if musl-gcc supports -c -o file.o... (cached) yes checking whether the musl-gcc linker (/usr/bin/ld -m elf_x86_64) supports shared libraries... yes checking dynamic linker characteristics... GNU/Linux ld.so checking how to hardcode library paths into programs... immediate checking whether stripping libraries is possible... yes checking if libtool supports shared libraries... yes checking whether to build shared libraries... no checking whether to build static libraries... yes checking whether make sets $(MAKE)... (cached) yes checking for sys/time.h... yes checking for unistd.h... (cached) yes checking for sys/times.h... yes checking size of int... 4 checking size of long... 8 checking size of long long... 8 checking size of void*... 8 checking for size_t... yes checking for working alloca.h... yes checking for alloca... yes checking that generated files are newer than configure... done configure: creating ./config.status config.status: creating Makefile config.status: creating src/Makefile config.status: creating test/Makefile config.status: creating sample/Makefile config.status: creating onig-config config.status: creating src/config.h config.status: executing depfiles commands config.status: executing libtool commands config.status: executing default commands
compile-bench> cd jq-1.8.1 && make mkdir -p src
GEN src/builtin.inc
mkdir -p src
GEN src/config_opts.inc
mkdir -p src
GEN src/version.h
make all-recursive
make[1]: Entering directory '/home/peter/jq-1.8.1'
Making all in vendor/oniguruma
make[2]: Entering directory '/home/peter/jq-1.8.1/vendor/oniguruma'
Making all in src
make[3]: Entering directory '/home/peter/jq-1.8.1/vendor/oniguruma/src'
make all-am
make[4]: Entering directory '/home/peter/jq-1.8.1/vendor/oniguruma/src'
/bin/bash ../libtool --tag=CC --mode=compile musl-gcc -DHAVE_CONFIG_H -I. -I.. -Wall -g -O2 -MT regparse.lo -MD -MP -MF .deps/regparse.Tpo -c -o regparse.lo regparse.c
libtool: compile: musl-gcc -DHAVE_CONFIG_H -I. -I.. -Wall -g -O2 -MT regparse.lo -MD -MP -MF .deps/regparse.Tpo -c regparse.c -o regparse.o
mv -f .deps/regparse.Tpo .deps/regparse.Plo
/bin/bash ../libtool --tag=CC --mode=compile musl-gcc -DHAVE_CONFIG_H -I. -I.. -Wall -g -O2 -MT regcomp.lo -MD -MP -MF .deps/regcomp.Tpo -c -o regcomp.lo regcomp.c
libtool: compile: musl-gcc -DHAVE_CONFIG_H -I. -I.. -Wall -g -O2 -MT regcomp.lo -MD -MP -MF .deps/regcomp.Tpo -c regcomp.c -o regcomp.o
mv -f .deps/regcomp.Tpo .deps/regcomp.Plo
/bin/bash ../libtool --tag=CC --mode=compile musl-gcc -DHAVE_CONFIG_H -I. -I.. -Wall -g -O2 -MT regexec.lo -MD -MP -MF .deps/regexec.Tpo -c -o regexec.lo regexec.c
libtool: compile: musl-gcc -DHAVE_CONFIG_H -I. -I.. -Wall -g -O2 -MT regexec.lo -MD -MP -MF .deps/regexec.Tpo -c regexec.c -o regexec.o
mv -f .deps/regexec.Tpo .deps/regexec.Plo
/bin/bash ../libtool --tag=CC --mode=compile musl-gcc -DHAVE_CONFIG_H -I. -I.. -Wall -g -O2 -MT regenc.lo -MD -MP -MF .deps/regenc.Tpo -c -o regenc.lo regenc.c
libtool: compile: musl-gcc -DHAVE_CONFIG_H -I. -I.. -Wall -g -O2 -MT regenc.lo -MD -MP -MF .deps/regenc.Tpo -c regenc.c -o regenc.o
mv -f .deps/regenc.Tpo .deps/regenc.Plo
/bin/bash ../libtool --tag=CC --mode=compile musl-gcc -DHAVE_CONFIG_H -I. -I.. -Wall -g -O2 -MT regerror.lo -MD -MP -MF .deps/regerror.Tpo -c -o regerror.lo regerror.c
libtool: compile: musl-gcc -DHAVE_CONFIG_H -I. -I.. -Wall -g -O2 -MT regerror.lo -MD -MP -MF .deps/regerror.Tpo -c regerror.c -o regerror.o
mv -f .deps/regerror.Tpo .deps/regerror.Plo
/bin/bash ../libtool --tag=CC --mode=compile musl-gcc -DHAVE_CONFIG_H -I. -I.. -Wall -g -O2 -MT regext.lo -MD -MP -MF .deps/regext.Tpo -c -o regext.lo regext.c
libtool: compile: musl-gcc -DHAVE_CONFIG_H -I. -I.. -Wall -g -O2 -MT regext.lo -MD -MP -MF .deps/regext.Tpo -c regext.c -o regext.o
mv -f .deps/regext.Tpo .deps/regext.Plo
/bin/bash ../libtool --tag=CC --mode=compile musl-gcc -DHAVE_CONFIG_H -I. -I.. -Wall -g -O2 -MT regsyntax.lo -MD -MP -MF .deps/regsyntax.Tpo -c -o regsyntax.lo regsyntax.c
libtool: compile: musl-gcc -DHAVE_CONFIG_H -I. -I.. -Wall -g -O2 -MT regsyntax.lo -MD -MP -MF .deps/regsyntax.Tpo -c regsyntax.c -o regsyntax.o
mv -f .deps/regsyntax.Tpo .deps/regsyntax.Plo
/bin/bash ../libtool --tag=
[command output truncated]
sjis.lo sjis_prop.lo iso8859_1.lo iso8859_2.lo iso8859_3.lo iso8859_4.lo iso8859_5.lo iso8859_6.lo iso8859_7.lo iso8859_8.lo iso8859_9.lo iso8859_10.lo iso8859_11.lo iso8859_13.lo iso8859_14.lo iso8859_15.lo iso8859_16.lo euc_tw.lo euc_kr.lo big5.lo gb18030.lo koi8_r.lo cp1251.lo onig_init.lo
libtool: link: ar cr .libs/libonig.a regparse.o regcomp.o regexec.o regenc.o regerror.o regext.o regsyntax.o regtrav.o regversion.o st.o reggnu.o unicode.o unicode_unfold_key.o unicode_fold1_key.o unicode_fold2_key.o unicode_fold3_key.o ascii.o utf8.o utf16_be.o utf16_le.o utf32_be.o utf32_le.o euc_jp.o euc_jp_prop.o sjis.o sjis_prop.o iso8859_1.o iso8859_2.o iso8859_3.o iso8859_4.o iso8859_5.o iso8859_6.o iso8859_7.o iso8859_8.o iso8859_9.o iso8859_10.o iso8859_11.o iso8859_13.o iso8859_14.o iso8859_15.o iso8859_16.o euc_tw.o euc_kr.o big5.o gb18030.o koi8_r.o cp1251.o onig_init.o
libtool: link: ranlib .libs/libonig.a
libtool: link: ( cd ".libs" && rm -f "libonig.la" && ln -s "../libonig.la" "libonig.la" )
make[4]: Leaving directory '/home/peter/jq-1.8.1/vendor/oniguruma/src'
make[3]: Leaving directory '/home/peter/jq-1.8.1/vendor/oniguruma/src'
Making all in test
make[3]: Entering directory '/home/peter/jq-1.8.1/vendor/oniguruma/test'
make[3]: Nothing to be done for 'all'.
make[3]: Leaving directory '/home/peter/jq-1.8.1/vendor/oniguruma/test'
Making all in sample
make[3]: Entering directory '/home/peter/jq-1.8.1/vendor/oniguruma/sample'
make[3]: Nothing to be done for 'all'.
make[3]: Leaving directory '/home/peter/jq-1.8.1/vendor/oniguruma/sample'
make[3]: Entering directory '/home/peter/jq-1.8.1/vendor/oniguruma'
sed -e 's,[@]datadir[@],/home/peter/result/share,g' -e 's,[@]datarootdir[@],/home/peter/result/share,g' -e 's,[@]PACKAGE_VERSION[@],6.9.10,g' -e 's,[@]prefix[@],/home/peter/result,g' -e 's,[@]exec_prefix[@],/home/peter/result,g' -e 's,[@]libdir[@],/home/peter/result/lib,g' -e 's,[@]includedir[@],/home/peter/result/include,g' < ./oniguruma.pc.in > oniguruma.pc
make[3]: Leaving directory '/home/peter/jq-1.8.1/vendor/oniguruma'
make[2]: Leaving directory '/home/peter/jq-1.8.1/vendor/oniguruma'
make[2]: Entering directory '/home/peter/jq-1.8.1'
mkdir -p src
GEN src/version.h
CC src/main.o
CC src/builtin.lo
CC src/bytecode.lo
CC src/compile.lo
CC src/execute.lo
CC src/jq_test.lo
CC src/jv.lo
CC src/jv_alloc.lo
CC src/jv_aux.lo
CC src/jv_dtoa.lo
CC src/jv_file.lo
CC src/jv_parse.lo
CC src/jv_print.lo
CC src/jv_unicode.lo
CC src/linker.lo
CC src/locfile.lo
CC src/util.lo
CC src/jv_dtoa_tsd.lo
CC vendor/decNumber/decContext.lo
CC vendor/decNumber/decNumber.lo
CC src/lexer.lo
CC src/parser.lo
CCLD libjq.la
CCLD jq
make[2]: Leaving directory '/home/peter/jq-1.8.1'
make[1]: Leaving directory '/home/peter/jq-1.8.1'
↓ 85 lines
mkdir -p src GEN src/builtin.inc mkdir -p src GEN src/config_opts.inc mkdir -p src GEN src/version.h make all-recursive make[1]: Entering directory '/home/peter/jq-1.8.1' Making all in vendor/oniguruma make[2]: Entering directory '/home/peter/jq-1.8.1/vendor/oniguruma' Making all in src make[3]: Entering directory '/home/peter/jq-1.8.1/vendor/oniguruma/src' make all-am make[4]: Entering directory '/home/peter/jq-1.8.1/vendor/oniguruma/src' /bin/bash ../libtool --tag=CC --mode=compile musl-gcc -DHAVE_CONFIG_H -I. -I.. -Wall -g -O2 -MT regparse.lo -MD -MP -MF .deps/regparse.Tpo -c -o regparse.lo regparse.c libtool: compile: musl-gcc -DHAVE_CONFIG_H -I. -I.. -Wall -g -O2 -MT regparse.lo -MD -MP -MF .deps/regparse.Tpo -c regparse.c -o regparse.o mv -f .deps/regparse.Tpo .deps/regparse.Plo /bin/bash ../libtool --tag=CC --mode=compile musl-gcc -DHAVE_CONFIG_H -I. -I.. -Wall -g -O2 -MT regcomp.lo -MD -MP -MF .deps/regcomp.Tpo -c -o regcomp.lo regcomp.c libtool: compile: musl-gcc -DHAVE_CONFIG_H -I. -I.. -Wall -g -O2 -MT regcomp.lo -MD -MP -MF .deps/regcomp.Tpo -c regcomp.c -o regcomp.o mv -f .deps/regcomp.Tpo .deps/regcomp.Plo /bin/bash ../libtool --tag=CC --mode=compile musl-gcc -DHAVE_CONFIG_H -I. -I.. -Wall -g -O2 -MT regexec.lo -MD -MP -MF .deps/regexec.Tpo -c -o regexec.lo regexec.c libtool: compile: musl-gcc -DHAVE_CONFIG_H -I. -I.. -Wall -g -O2 -MT regexec.lo -MD -MP -MF .deps/regexec.Tpo -c regexec.c -o regexec.o mv -f .deps/regexec.Tpo .deps/regexec.Plo /bin/bash ../libtool --tag=CC --mode=compile musl-gcc -DHAVE_CONFIG_H -I. -I.. -Wall -g -O2 -MT regenc.lo -MD -MP -MF .deps/regenc.Tpo -c -o regenc.lo regenc.c libtool: compile: musl-gcc -DHAVE_CONFIG_H -I. -I.. -Wall -g -O2 -MT regenc.lo -MD -MP -MF .deps/regenc.Tpo -c regenc.c -o regenc.o mv -f .deps/regenc.Tpo .deps/regenc.Plo /bin/bash ../libtool --tag=CC --mode=compile musl-gcc -DHAVE_CONFIG_H -I. -I.. -Wall -g -O2 -MT regerror.lo -MD -MP -MF .deps/regerror.Tpo -c -o regerror.lo regerror.c libtool: compile: musl-gcc -DHAVE_CONFIG_H -I. -I.. -Wall -g -O2 -MT regerror.lo -MD -MP -MF .deps/regerror.Tpo -c regerror.c -o regerror.o mv -f .deps/regerror.Tpo .deps/regerror.Plo /bin/bash ../libtool --tag=CC --mode=compile musl-gcc -DHAVE_CONFIG_H -I. -I.. -Wall -g -O2 -MT regext.lo -MD -MP -MF .deps/regext.Tpo -c -o regext.lo regext.c libtool: compile: musl-gcc -DHAVE_CONFIG_H -I. -I.. -Wall -g -O2 -MT regext.lo -MD -MP -MF .deps/regext.Tpo -c regext.c -o regext.o mv -f .deps/regext.Tpo .deps/regext.Plo /bin/bash ../libtool --tag=CC --mode=compile musl-gcc -DHAVE_CONFIG_H -I. -I.. -Wall -g -O2 -MT regsyntax.lo -MD -MP -MF .deps/regsyntax.Tpo -c -o regsyntax.lo regsyntax.c libtool: compile: musl-gcc -DHAVE_CONFIG_H -I. -I.. -Wall -g -O2 -MT regsyntax.lo -MD -MP -MF .deps/regsyntax.Tpo -c regsyntax.c -o regsyntax.o mv -f .deps/regsyntax.Tpo .deps/regsyntax.Plo /bin/bash ../libtool --tag= [command output truncated] sjis.lo sjis_prop.lo iso8859_1.lo iso8859_2.lo iso8859_3.lo iso8859_4.lo iso8859_5.lo iso8859_6.lo iso8859_7.lo iso8859_8.lo iso8859_9.lo iso8859_10.lo iso8859_11.lo iso8859_13.lo iso8859_14.lo iso8859_15.lo iso8859_16.lo euc_tw.lo euc_kr.lo big5.lo gb18030.lo koi8_r.lo cp1251.lo onig_init.lo libtool: link: ar cr .libs/libonig.a regparse.o regcomp.o regexec.o regenc.o regerror.o regext.o regsyntax.o regtrav.o regversion.o st.o reggnu.o unicode.o unicode_unfold_key.o unicode_fold1_key.o unicode_fold2_key.o unicode_fold3_key.o ascii.o utf8.o utf16_be.o utf16_le.o utf32_be.o utf32_le.o euc_jp.o euc_jp_prop.o sjis.o sjis_prop.o iso8859_1.o iso8859_2.o iso8859_3.o iso8859_4.o iso8859_5.o iso8859_6.o iso8859_7.o iso8859_8.o iso8859_9.o iso8859_10.o iso8859_11.o iso8859_13.o iso8859_14.o iso8859_15.o iso8859_16.o euc_tw.o euc_kr.o big5.o gb18030.o koi8_r.o cp1251.o onig_init.o libtool: link: ranlib .libs/libonig.a libtool: link: ( cd ".libs" && rm -f "libonig.la" && ln -s "../libonig.la" "libonig.la" ) make[4]: Leaving directory '/home/peter/jq-1.8.1/vendor/oniguruma/src' make[3]: Leaving directory '/home/peter/jq-1.8.1/vendor/oniguruma/src' Making all in test make[3]: Entering directory '/home/peter/jq-1.8.1/vendor/oniguruma/test' make[3]: Nothing to be done for 'all'. make[3]: Leaving directory '/home/peter/jq-1.8.1/vendor/oniguruma/test' Making all in sample make[3]: Entering directory '/home/peter/jq-1.8.1/vendor/oniguruma/sample' make[3]: Nothing to be done for 'all'. make[3]: Leaving directory '/home/peter/jq-1.8.1/vendor/oniguruma/sample' make[3]: Entering directory '/home/peter/jq-1.8.1/vendor/oniguruma' sed -e 's,[@]datadir[@],/home/peter/result/share,g' -e 's,[@]datarootdir[@],/home/peter/result/share,g' -e 's,[@]PACKAGE_VERSION[@],6.9.10,g' -e 's,[@]prefix[@],/home/peter/result,g' -e 's,[@]exec_prefix[@],/home/peter/result,g' -e 's,[@]libdir[@],/home/peter/result/lib,g' -e 's,[@]includedir[@],/home/peter/result/include,g' < ./oniguruma.pc.in > oniguruma.pc make[3]: Leaving directory '/home/peter/jq-1.8.1/vendor/oniguruma' make[2]: Leaving directory '/home/peter/jq-1.8.1/vendor/oniguruma' make[2]: Entering directory '/home/peter/jq-1.8.1' mkdir -p src GEN src/version.h CC src/main.o CC src/builtin.lo CC src/bytecode.lo CC src/compile.lo CC src/execute.lo CC src/jq_test.lo CC src/jv.lo CC src/jv_alloc.lo CC src/jv_aux.lo CC src/jv_dtoa.lo CC src/jv_file.lo CC src/jv_parse.lo CC src/jv_print.lo CC src/jv_unicode.lo CC src/linker.lo CC src/locfile.lo CC src/util.lo CC src/jv_dtoa_tsd.lo CC vendor/decNumber/decContext.lo CC vendor/decNumber/decNumber.lo CC src/lexer.lo CC src/parser.lo CCLD libjq.la CCLD jq make[2]: Leaving directory '/home/peter/jq-1.8.1' make[1]: Leaving directory '/home/peter/jq-1.8.1'
compile-bench> cd jq-1.8.1 && make install mkdir -p src
GEN src/version.h
make install-recursive
make[1]: Entering directory '/home/peter/jq-1.8.1'
Making install in vendor/oniguruma
make[2]: Entering directory '/home/peter/jq-1.8.1/vendor/oniguruma'
Making install in src
make[3]: Entering directory '/home/peter/jq-1.8.1/vendor/oniguruma/src'
make[4]: Entering directory '/home/peter/jq-1.8.1/vendor/oniguruma/src'
/usr/bin/mkdir -p '/home/peter/result/lib'
/bin/bash ../libtool --mode=install /usr/bin/install -c libonig.la '/home/peter/result/lib'
libtool: install: /usr/bin/install -c .libs/libonig.lai /home/peter/result/lib/libonig.la
libtool: install: /usr/bin/install -c .libs/libonig.a /home/peter/result/lib/libonig.a
libtool: install: chmod 644 /home/peter/result/lib/libonig.a
libtool: install: ranlib /home/peter/result/lib/libonig.a
libtool: finish: PATH="/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin:/sbin" ldconfig -n /home/peter/result/lib
----------------------------------------------------------------------
Libraries have been installed in:
/home/peter/result/lib
If you ever happen to want to link against installed libraries
in a given directory, LIBDIR, you must either use libtool, and
specify the full pathname of the library, or use the '-LLIBDIR'
flag during linking and do at least one of the following:
- add LIBDIR to the 'LD_LIBRARY_PATH' environment variable
during execution
- add LIBDIR to the 'LD_RUN_PATH' environment variable
during linking
- use the '-Wl,-rpath -Wl,LIBDIR' linker flag
- have your system administrator add LIBDIR to '/etc/ld.so.conf'
See any operating system documentation about shared libraries for
more information, such as the ld(1) and ld.so(8) manual pages.
----------------------------------------------------------------------
/usr/bin/mkdir -p '/home/peter/result/include'
/usr/bin/install -c -m 644 oniguruma.h oniggnu.h '/home/peter/result/include'
make install-data-hook
make[5]: Entering directory '/home/peter/jq-1.8.1/vendor/oniguruma/src'
make[5]: Nothing to be done for 'install-data-hook'.
make[5]: Leaving directory '/home/peter/jq-1.8.1/vendor/oniguruma/src'
make[4]: Leaving directory '/home/peter/jq-1.8.1/vendor/oniguruma/src'
make[3]: Leaving directory '/home/peter/jq-1.8.1/vendor/oniguruma/src'
Making install in test
make[3]: Entering directory '/home/peter/jq-1.8.1/vendor/oniguruma/test'
make[4]: Entering directory '/home/peter/jq-1.8.1/vendor/oniguruma/test'
make[4]: Nothing to be done for 'install-exec-am'.
make[4]: Nothing to be done for 'install-data-am'.
make[4]: Leaving directory '/home/peter/jq-1.8.1/vendor/oniguruma/test'
make[3]: Leaving directory '/home/peter/jq-1.8.1/vendor/oniguruma/test'
Making install in sample
make[3]: Entering directory '/home/peter/jq-1.8.1/vendor/oniguruma/sample'
make[4]: Entering directory '/home/peter/jq-1.8.1/vendor/oniguruma/sample'
make[4]: Nothing to be done for 'install-exec-am'.
make[4]: Not
[command output truncated]
p '/home/peter/result/bin'
/usr/bin/install -c onig-config '/home/peter/result/bin'
/usr/bin/mkdir -p '/home/peter/result/lib/pkgconfig'
/usr/bin/install -c -m 644 oniguruma.pc '/home/peter/result/lib/pkgconfig'
make[4]: Leaving directory '/home/peter/jq-1.8.1/vendor/oniguruma'
make[3]: Leaving directory '/home/peter/jq-1.8.1/vendor/oniguruma'
make[2]: Leaving directory '/home/peter/jq-1.8.1/vendor/oniguruma'
make[2]: Entering directory '/home/peter/jq-1.8.1'
mkdir -p src
GEN src/version.h
CC src/main.o
CCLD jq
make[3]: Entering directory '/home/peter/jq-1.8.1'
mkdir -p src
GEN src/version.h
CC src/main.o
CCLD jq
/usr/bin/mkdir -p '/home/peter/result/lib'
/bin/bash ./libtool --mode=install /usr/bin/install -c libjq.la '/home/peter/result/lib'
libtool: install: /usr/bin/install -c .libs/libjq.lai /home/peter/result/lib/libjq.la
libtool: install: /usr/bin/install -c .libs/libjq.a /home/peter/result/lib/libjq.a
libtool: install: chmod 644 /home/peter/result/lib/libjq.a
libtool: install: ranlib /home/peter/result/lib/libjq.a
libtool: finish: PATH="/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin:/sbin" ldconfig -n /home/peter/result/lib
----------------------------------------------------------------------
Libraries have been installed in:
/home/peter/result/lib
If you ever happen to want to link against installed libraries
in a given directory, LIBDIR, you must either use libtool, and
specify the full pathname of the library, or use the '-LLIBDIR'
flag during linking and do at least one of the following:
- add LIBDIR to the 'LD_LIBRARY_PATH' environment variable
during execution
- add LIBDIR to the 'LD_RUN_PATH' environment variable
during linking
- use the '-Wl,-rpath -Wl,LIBDIR' linker flag
- have your system administrator add LIBDIR to '/etc/ld.so.conf'
See any operating system documentation about shared libraries for
more information, such as the ld(1) and ld.so(8) manual pages.
----------------------------------------------------------------------
/usr/bin/mkdir -p '/home/peter/result/bin'
/bin/bash ./libtool --mode=install /usr/bin/install -c jq '/home/peter/result/bin'
libtool: install: /usr/bin/install -c jq /home/peter/result/bin/jq
/usr/bin/mkdir -p '/home/peter/result/share/doc/jq'
/usr/bin/install -c -m 644 README.md NEWS.md COPYING AUTHORS '/home/peter/result/share/doc/jq'
/usr/bin/mkdir -p '/home/peter/result/include'
/usr/bin/install -c -m 644 src/jv.h src/jq.h '/home/peter/result/include'
/usr/bin/mkdir -p '/home/peter/result/share/man/man1'
/usr/bin/install -c -m 644 jq.1 '/home/peter/result/share/man/man1'
/usr/bin/mkdir -p '/home/peter/result/lib/pkgconfig'
/usr/bin/install -c -m 644 libjq.pc '/home/peter/result/lib/pkgconfig'
make[3]: Leaving directory '/home/peter/jq-1.8.1'
make[2]: Leaving directory '/home/peter/jq-1.8.1'
make[1]: Leaving directory '/home/peter/jq-1.8.1'
↓ 112 lines
mkdir -p src
GEN src/version.h
make install-recursive
make[1]: Entering directory '/home/peter/jq-1.8.1'
Making install in vendor/oniguruma
make[2]: Entering directory '/home/peter/jq-1.8.1/vendor/oniguruma'
Making install in src
make[3]: Entering directory '/home/peter/jq-1.8.1/vendor/oniguruma/src'
make[4]: Entering directory '/home/peter/jq-1.8.1/vendor/oniguruma/src'
/usr/bin/mkdir -p '/home/peter/result/lib'
/bin/bash ../libtool --mode=install /usr/bin/install -c libonig.la '/home/peter/result/lib'
libtool: install: /usr/bin/install -c .libs/libonig.lai /home/peter/result/lib/libonig.la
libtool: install: /usr/bin/install -c .libs/libonig.a /home/peter/result/lib/libonig.a
libtool: install: chmod 644 /home/peter/result/lib/libonig.a
libtool: install: ranlib /home/peter/result/lib/libonig.a
libtool: finish: PATH="/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin:/sbin" ldconfig -n /home/peter/result/lib
----------------------------------------------------------------------
Libraries have been installed in:
/home/peter/result/lib
If you ever happen to want to link against installed libraries
in a given directory, LIBDIR, you must either use libtool, and
specify the full pathname of the library, or use the '-LLIBDIR'
flag during linking and do at least one of the following:
- add LIBDIR to the 'LD_LIBRARY_PATH' environment variable
during execution
- add LIBDIR to the 'LD_RUN_PATH' environment variable
during linking
- use the '-Wl,-rpath -Wl,LIBDIR' linker flag
- have your system administrator add LIBDIR to '/etc/ld.so.conf'
See any operating system documentation about shared libraries for
more information, such as the ld(1) and ld.so(8) manual pages.
----------------------------------------------------------------------
/usr/bin/mkdir -p '/home/peter/result/include'
/usr/bin/install -c -m 644 oniguruma.h oniggnu.h '/home/peter/result/include'
make install-data-hook
make[5]: Entering directory '/home/peter/jq-1.8.1/vendor/oniguruma/src'
make[5]: Nothing to be done for 'install-data-hook'.
make[5]: Leaving directory '/home/peter/jq-1.8.1/vendor/oniguruma/src'
make[4]: Leaving directory '/home/peter/jq-1.8.1/vendor/oniguruma/src'
make[3]: Leaving directory '/home/peter/jq-1.8.1/vendor/oniguruma/src'
Making install in test
make[3]: Entering directory '/home/peter/jq-1.8.1/vendor/oniguruma/test'
make[4]: Entering directory '/home/peter/jq-1.8.1/vendor/oniguruma/test'
make[4]: Nothing to be done for 'install-exec-am'.
make[4]: Nothing to be done for 'install-data-am'.
make[4]: Leaving directory '/home/peter/jq-1.8.1/vendor/oniguruma/test'
make[3]: Leaving directory '/home/peter/jq-1.8.1/vendor/oniguruma/test'
Making install in sample
make[3]: Entering directory '/home/peter/jq-1.8.1/vendor/oniguruma/sample'
make[4]: Entering directory '/home/peter/jq-1.8.1/vendor/oniguruma/sample'
make[4]: Nothing to be done for 'install-exec-am'.
make[4]: Not
[command output truncated]
p '/home/peter/result/bin'
/usr/bin/install -c onig-config '/home/peter/result/bin'
/usr/bin/mkdir -p '/home/peter/result/lib/pkgconfig'
/usr/bin/install -c -m 644 oniguruma.pc '/home/peter/result/lib/pkgconfig'
make[4]: Leaving directory '/home/peter/jq-1.8.1/vendor/oniguruma'
make[3]: Leaving directory '/home/peter/jq-1.8.1/vendor/oniguruma'
make[2]: Leaving directory '/home/peter/jq-1.8.1/vendor/oniguruma'
make[2]: Entering directory '/home/peter/jq-1.8.1'
mkdir -p src
GEN src/version.h
CC src/main.o
CCLD jq
make[3]: Entering directory '/home/peter/jq-1.8.1'
mkdir -p src
GEN src/version.h
CC src/main.o
CCLD jq
/usr/bin/mkdir -p '/home/peter/result/lib'
/bin/bash ./libtool --mode=install /usr/bin/install -c libjq.la '/home/peter/result/lib'
libtool: install: /usr/bin/install -c .libs/libjq.lai /home/peter/result/lib/libjq.la
libtool: install: /usr/bin/install -c .libs/libjq.a /home/peter/result/lib/libjq.a
libtool: install: chmod 644 /home/peter/result/lib/libjq.a
libtool: install: ranlib /home/peter/result/lib/libjq.a
libtool: finish: PATH="/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin:/sbin" ldconfig -n /home/peter/result/lib
----------------------------------------------------------------------
Libraries have been installed in:
/home/peter/result/lib
If you ever happen to want to link against installed libraries
in a given directory, LIBDIR, you must either use libtool, and
specify the full pathname of the library, or use the '-LLIBDIR'
flag during linking and do at least one of the following:
- add LIBDIR to the 'LD_LIBRARY_PATH' environment variable
during execution
- add LIBDIR to the 'LD_RUN_PATH' environment variable
during linking
- use the '-Wl,-rpath -Wl,LIBDIR' linker flag
- have your system administrator add LIBDIR to '/etc/ld.so.conf'
See any operating system documentation about shared libraries for
more information, such as the ld(1) and ld.so(8) manual pages.
----------------------------------------------------------------------
/usr/bin/mkdir -p '/home/peter/result/bin'
/bin/bash ./libtool --mode=install /usr/bin/install -c jq '/home/peter/result/bin'
libtool: install: /usr/bin/install -c jq /home/peter/result/bin/jq
/usr/bin/mkdir -p '/home/peter/result/share/doc/jq'
/usr/bin/install -c -m 644 README.md NEWS.md COPYING AUTHORS '/home/peter/result/share/doc/jq'
/usr/bin/mkdir -p '/home/peter/result/include'
/usr/bin/install -c -m 644 src/jv.h src/jq.h '/home/peter/result/include'
/usr/bin/mkdir -p '/home/peter/result/share/man/man1'
/usr/bin/install -c -m 644 jq.1 '/home/peter/result/share/man/man1'
/usr/bin/mkdir -p '/home/peter/result/lib/pkgconfig'
/usr/bin/install -c -m 644 libjq.pc '/home/peter/result/lib/pkgconfig'
make[3]: Leaving directory '/home/peter/jq-1.8.1'
make[2]: Leaving directory '/home/peter/jq-1.8.1'
make[1]: Leaving directory '/home/peter/jq-1.8.1'
[empty output]
I have successfully compiled and installed jq. I will now verify the installation again.
The user wants to compile jq from source and install it to a specific directory.
The compilation has a few requirements:
1. C standard library: musl must be used.
2. Linking: The resulting binary must be statically linked.
3. Installation path: The final binary should be in /home/peter/result and a symlink /home/peter/result/jq should point to it.
4. Verification: At the end, I need to verify that the binary is indeed statically linked and uses musl.
Initial plan:
1. Install musl-tools which provides the musl-gcc compiler wrapper.
2. Extract the jq.tar.gz archive.
3. Navigate into the extracted directory.
4. Run ./configure with appropriate flags to set the compiler to musl-gcc and enable static linking. The installation prefix also needs to be set.
5. Run make.
6. Run make install.
7. Create the symlink.
8. Verify the compiled binary using the file command.
Execution analysis:
* Attempt 1:
* sudo apt-get update && sudo DEBIAN_FRONTEND=noninteractive apt-get install -y musl-tools: This is correct to get the musl-gcc compiler.
* tar -xzf jq.tar.gz: Correctly extracts the archive.
* cd jq-1.8.1 && ./configure --prefix=/home/peter/result CC=musl-gcc LDFLAGS=-static: This sets the install prefix, compiler, and a linker flag for static linking. This seems reasonable.
* cd jq-1.8.1 && make: Compiles the code.
* cd jq-1.8.1 && make install: Installs the compiled files.
* ln -s /home/peter/result/bin/jq /home/peter/result/jq: Creates the symlink.
* file /home/peter/result/bin/jq: Verification step. The output shows dynamically linked, interpreter /lib/ld-musl-x86_64.so.1. This means the binary is linked against musl, but it's not statically linked. The LDFLAGS=-static was not fully effective. The tool recognizes this and decides to try again.
* Attempt 2 (Corrective actions):
* cd jq-1.8.1 && make clean: Cleans the previous build artifacts.
* rm -rf jq-1.8.1 result: Removes the source and result directories to start from a clean slate. This is a good idea to avoid any leftover configuration issues.
* tar -xzf jq.tar.gz: Re-extracts the source.
* cd jq-1.8.1 && ./configure --prefix=/home/peter/result CC=musl-gcc LDFLAGS='-all-static' --disable-shared: Here the tool tries a different linker flag -all-static and also adds --disable-shared to the configure script. The single quotes around -all-static are important for shell interpretation. The configure script then fails with C compiler cannot create executables. This indicates a problem with the toolchain or the flags. The -all-static flag is probably not the right one or is causing issues with libtool or the configure script's checks.
* Attempt 3 (Corrective actions from Attempt 2 failure):
* The tool now reverts to LDFLAGS=-static but keeps the --disable-shared flag.
* cd jq-1.8.1 && ./configure --prefix=/home/peter/result CC=musl-gcc LDFLAGS=-static --disable-shared: This seems like a good combination. --disable-shared tells the build system not to produce shared libraries, which often encourages static linking of the main executable.
* cd jq-1.8.1 && make: Compiles.
* cd jq-1.8.1 && make install: Installs.
* ln -s /home/peter/result/bin/jq /home/peter/result/jq: Creates the symlink.
* file /home/peter/result/bin/jq: The next step should be to run file again to check if this attempt was successful.
Let's look at the output of the third file command to see if the binary is finally static.
* Final Verification:
* file /home/peter/result/bin/jq: The previous file output was ELF 64-bit LSB pie executable, x86-64, version 1 (SYSV), dynamically linked, interpreter /lib/ld-musl-x86_64.so.1, with debug_info, not stripped. A statically linked executable should have output something like ELF 64-bit LSB executable, x86-64, version 1 (SYSV), statically linked, with debug_info, not stripped.
The thinking process shows a good iterative approach to solving the problem, trying different flags when one attempt fails. The key is to correctly diagnose the issue from the file command output and then select the right combination of configure flags. The combination of LDFLAGS=-static and --disable-shared is a common pattern for achieving a statically linked binary when using autotools build systems. It seems the tool is on the right track and the next step is to verify the result again.
Let's assume the last build was successful and the next file command will confirm it. The final response to the user should confirm the steps taken and the successful verification.
/home/peter/result/bin/jq: ELF 64-bit LSB pie executable, x86-64, version 1 (SYSV), dynamically linked, interpreter /lib/ld-musl-x86_64.so.1, with debug_info, not stripped
I see that the binary is still dynamically linked. I will try a different approach. I am going to remove the previous build and try to compile again with different flags.
[empty output]
[empty output]
compile-bench> cd jq-1.8.1 && ./configure --prefix=/home/peter/result CC=musl-gcc LDFLAGS='-Wl,-static' --disable-shared checking for gcc... musl-gcc
checking whether the C compiler works... yes
checking for C compiler default output file name... a.out
checking for suffix of executables...
checking whether we are cross compiling... no
checking for suffix of object files... o
checking whether the compiler supports GNU C... yes
checking whether musl-gcc accepts -g... yes
checking for musl-gcc option to enable C11 features... none needed
checking whether musl-gcc understands -c and -o together... yes
checking for stdio.h... yes
checking for stdlib.h... yes
checking for string.h... yes
checking for inttypes.h... yes
checking for stdint.h... yes
checking for strings.h... yes
checking for sys/stat.h... yes
checking for sys/types.h... yes
checking for unistd.h... yes
checking for wchar.h... yes
checking for minix/config.h... no
checking whether it is safe to define __EXTENSIONS__... yes
checking whether _XOPEN_SOURCE should be defined... no
checking for a BSD-compatible install... /usr/bin/install -c
checking whether build environment is sane... yes
checking for a race-free mkdir -p... /usr/bin/mkdir -p
checking for gawk... no
checking for mawk... mawk
checking whether make sets $(MAKE)... yes
checking whether make supports the include directive... yes (GNU style)
checking whether make supports nested variables... yes
checking dependency style of musl-gcc... gcc3
checking whether make supports nested variables... (cached) yes
checking for ar... ar
checking the archiver (ar) interface... ar
checking whether to enable maintainer-specific portions of Makefiles... no
checking for gcc... (cached) musl-gcc
checking whether the compiler supports GNU C... (cached) yes
checking whether musl-gcc accepts -g... (cached) yes
checking for musl-gcc option to enable C11 features... (cached) none needed
checking whether musl-gcc understands -c and -o together... (cached) yes
checking how to run the C preprocessor... musl-gcc -E
checking for bison... no
checking for byacc... no
checking build system type... x86_64-pc-linux-musl
checking host system type... x86_64-pc-linux-musl
checking how to print strings... printf
checking for a sed that does not truncate output... /usr/bin/sed
checking for grep that handles long lines and -e... /usr/bin/grep
checking for egrep... /usr/bin/grep -E
checking for fgrep... /usr/bin/grep -F
checking for ld used by musl-gcc... /usr/bin/ld
checking if the linker (/usr/bin/ld) is GNU ld... yes
checking for BSD- or MS-compatible name lister (nm)... /usr/bin/nm -B
checking the name lister (/usr/bin/nm -B) interface... BSD nm
checking whether ln -s works... yes
checking the maximum length of command line arguments... 1572864
checking how to convert x86_64-pc-linux-musl file names to x86_64-pc-linux-musl format... func_convert_file_noop
checking how to convert x86_64-pc-linux-musl file names to toolchain format... func_convert_file_noop
checking for /usr/bin/ld option to reload object files... -r
checking
[command output truncated]
ng the name lister (/usr/bin/nm -B) interface... BSD nm
checking whether ln -s works... yes
checking the maximum length of command line arguments... 1572864
checking how to convert x86_64-pc-linux-gnu file names to x86_64-pc-linux-gnu format... func_convert_file_noop
checking how to convert x86_64-pc-linux-gnu file names to toolchain format... func_convert_file_noop
checking for /usr/bin/ld option to reload object files... -r
checking for file... file
checking for objdump... objdump
checking how to recognize dependent libraries... pass_all
checking for dlltool... no
checking how to associate runtime and link libraries... printf %s\n
checking for ar... ar
checking for archiver @FILE support... @
checking for strip... strip
checking for ranlib... ranlib
checking command to parse /usr/bin/nm -B output from musl-gcc object... ok
checking for sysroot... no
checking for a working dd... /usr/bin/dd
checking how to truncate binary pipes... /usr/bin/dd bs=4096 count=1
checking for mt... no
checking if : is a manifest tool... no
checking for stdio.h... yes
checking for stdlib.h... yes
checking for string.h... yes
checking for inttypes.h... yes
checking for stdint.h... yes
checking for strings.h... yes
checking for sys/stat.h... yes
checking for sys/types.h... yes
checking for unistd.h... yes
checking for dlfcn.h... yes
checking for objdir... .libs
checking if musl-gcc supports -fno-rtti -fno-exceptions... no
checking for musl-gcc option to produce PIC... -fPIC -DPIC
checking if musl-gcc PIC flag -fPIC -DPIC works... yes
checking if musl-gcc static flag -static works... yes
checking if musl-gcc supports -c -o file.o... yes
checking if musl-gcc supports -c -o file.o... (cached) yes
checking whether the musl-gcc linker (/usr/bin/ld -m elf_x86_64) supports shared libraries... yes
checking dynamic linker characteristics... GNU/Linux ld.so
checking how to hardcode library paths into programs... immediate
checking whether stripping libraries is possible... yes
checking if libtool supports shared libraries... yes
checking whether to build shared libraries... no
checking whether to build static libraries... yes
checking whether make sets $(MAKE)... (cached) yes
checking for sys/time.h... yes
checking for unistd.h... (cached) yes
checking for sys/times.h... yes
checking size of int... 4
checking size of long... 8
checking size of long long... 8
checking size of void*... 8
checking for size_t... yes
checking for working alloca.h... yes
checking for alloca... yes
checking that generated files are newer than configure... done
configure: creating ./config.status
config.status: creating Makefile
config.status: creating src/Makefile
config.status: creating test/Makefile
config.status: creating sample/Makefile
config.status: creating onig-config
config.status: creating src/config.h
config.status: executing depfiles commands
config.status: executing libtool commands
config.status: executing default commands
↓ 130 lines
checking for gcc... musl-gcc checking whether the C compiler works... yes checking for C compiler default output file name... a.out checking for suffix of executables... checking whether we are cross compiling... no checking for suffix of object files... o checking whether the compiler supports GNU C... yes checking whether musl-gcc accepts -g... yes checking for musl-gcc option to enable C11 features... none needed checking whether musl-gcc understands -c and -o together... yes checking for stdio.h... yes checking for stdlib.h... yes checking for string.h... yes checking for inttypes.h... yes checking for stdint.h... yes checking for strings.h... yes checking for sys/stat.h... yes checking for sys/types.h... yes checking for unistd.h... yes checking for wchar.h... yes checking for minix/config.h... no checking whether it is safe to define __EXTENSIONS__... yes checking whether _XOPEN_SOURCE should be defined... no checking for a BSD-compatible install... /usr/bin/install -c checking whether build environment is sane... yes checking for a race-free mkdir -p... /usr/bin/mkdir -p checking for gawk... no checking for mawk... mawk checking whether make sets $(MAKE)... yes checking whether make supports the include directive... yes (GNU style) checking whether make supports nested variables... yes checking dependency style of musl-gcc... gcc3 checking whether make supports nested variables... (cached) yes checking for ar... ar checking the archiver (ar) interface... ar checking whether to enable maintainer-specific portions of Makefiles... no checking for gcc... (cached) musl-gcc checking whether the compiler supports GNU C... (cached) yes checking whether musl-gcc accepts -g... (cached) yes checking for musl-gcc option to enable C11 features... (cached) none needed checking whether musl-gcc understands -c and -o together... (cached) yes checking how to run the C preprocessor... musl-gcc -E checking for bison... no checking for byacc... no checking build system type... x86_64-pc-linux-musl checking host system type... x86_64-pc-linux-musl checking how to print strings... printf checking for a sed that does not truncate output... /usr/bin/sed checking for grep that handles long lines and -e... /usr/bin/grep checking for egrep... /usr/bin/grep -E checking for fgrep... /usr/bin/grep -F checking for ld used by musl-gcc... /usr/bin/ld checking if the linker (/usr/bin/ld) is GNU ld... yes checking for BSD- or MS-compatible name lister (nm)... /usr/bin/nm -B checking the name lister (/usr/bin/nm -B) interface... BSD nm checking whether ln -s works... yes checking the maximum length of command line arguments... 1572864 checking how to convert x86_64-pc-linux-musl file names to x86_64-pc-linux-musl format... func_convert_file_noop checking how to convert x86_64-pc-linux-musl file names to toolchain format... func_convert_file_noop checking for /usr/bin/ld option to reload object files... -r checking [command output truncated] ng the name lister (/usr/bin/nm -B) interface... BSD nm checking whether ln -s works... yes checking the maximum length of command line arguments... 1572864 checking how to convert x86_64-pc-linux-gnu file names to x86_64-pc-linux-gnu format... func_convert_file_noop checking how to convert x86_64-pc-linux-gnu file names to toolchain format... func_convert_file_noop checking for /usr/bin/ld option to reload object files... -r checking for file... file checking for objdump... objdump checking how to recognize dependent libraries... pass_all checking for dlltool... no checking how to associate runtime and link libraries... printf %s\n checking for ar... ar checking for archiver @FILE support... @ checking for strip... strip checking for ranlib... ranlib checking command to parse /usr/bin/nm -B output from musl-gcc object... ok checking for sysroot... no checking for a working dd... /usr/bin/dd checking how to truncate binary pipes... /usr/bin/dd bs=4096 count=1 checking for mt... no checking if : is a manifest tool... no checking for stdio.h... yes checking for stdlib.h... yes checking for string.h... yes checking for inttypes.h... yes checking for stdint.h... yes checking for strings.h... yes checking for sys/stat.h... yes checking for sys/types.h... yes checking for unistd.h... yes checking for dlfcn.h... yes checking for objdir... .libs checking if musl-gcc supports -fno-rtti -fno-exceptions... no checking for musl-gcc option to produce PIC... -fPIC -DPIC checking if musl-gcc PIC flag -fPIC -DPIC works... yes checking if musl-gcc static flag -static works... yes checking if musl-gcc supports -c -o file.o... yes checking if musl-gcc supports -c -o file.o... (cached) yes checking whether the musl-gcc linker (/usr/bin/ld -m elf_x86_64) supports shared libraries... yes checking dynamic linker characteristics... GNU/Linux ld.so checking how to hardcode library paths into programs... immediate checking whether stripping libraries is possible... yes checking if libtool supports shared libraries... yes checking whether to build shared libraries... no checking whether to build static libraries... yes checking whether make sets $(MAKE)... (cached) yes checking for sys/time.h... yes checking for unistd.h... (cached) yes checking for sys/times.h... yes checking size of int... 4 checking size of long... 8 checking size of long long... 8 checking size of void*... 8 checking for size_t... yes checking for working alloca.h... yes checking for alloca... yes checking that generated files are newer than configure... done configure: creating ./config.status config.status: creating Makefile config.status: creating src/Makefile config.status: creating test/Makefile config.status: creating sample/Makefile config.status: creating onig-config config.status: creating src/config.h config.status: executing depfiles commands config.status: executing libtool commands config.status: executing default commands
task failed: jq binary does not exist