| Cost | $0.775 |
| Total elapsed time | 5m56s |
| LLM inference time | 2m1s |
| Command execution time | 3m55s |
| Commands executed | 34 |
All details >
| Attempt ID | nikawok9pf8m2 | Attempt group | run-17-09-01-01 |
| Revision | fb5c74bd2fee | AWS Instance | m8i.2xlarge |
| Start time | 2025-09-16T23:50:45.114Z | End time | 2025-09-16T23:56:41.523Z |
| Task | jq-static-musl | Environment | ubuntu-22.04-amd64 |
| Model | | OpenRouter slug | qwen/qwen3-max |
| 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.775 | Duration | 5m56s |
| LLM inference time | 2m1s | Command execution time | 3m55s |
| Final context tokens | 32,100 | Total output tokens | 3,067 |
| Output reasoning tokens | 0 | Messages | 71 |
| Assistant messages | 35 | User messages | 1 |
| System messages | 1 | Commands executed | 34 |
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).
compile-bench> sudo apt-get update -y && sudo apt-get install -y musl-tools build-essential
0% [Working]
Get:1 http://security.ubuntu.com/ubuntu jammy-security InRelease [129 kB]
0% [Waiting for headers] [1 InRelease 14.2 kB/129 kB 11%]
Hit:2 http://archive.ubuntu.com/ubuntu jammy InRelease
0% [1 InRelease 14.2 kB/129 kB 11%]
Get:3 http://archive.ubuntu.com/ubuntu jammy-updates InRelease [128 kB]
0% [3 InRelease 5484 B/128 kB 4%] [1 InRelease 25.8 kB/129 kB 20%]
0% [3 InRelease 15.6 kB/128 kB 12%] [1 InRelease 63.4 kB/129 kB 49%]
0% [3 InRelease 50.4 kB/128 kB 39%]
0% [Working]
0% [Waiting for headers]
Get:4 http://archive.ubuntu.com/ubuntu jammy-backports InRelease [127 kB]
0% [4 InRelease 5484 B/127 kB 4%] [Waiting for headers]
Get:5 http://security.ubuntu.com/ubuntu jammy-security/main amd64 Packages [3311 kB]
0% [4 InRelease 62.0 kB/127 kB 49%] [5 Packages 5551 B/3311 kB 0%]
0% [5 Packages 75.1 kB/3311 kB 2%]
0% [5 Packages 134 kB/3311 kB 4%]
Get:6 http://archive.ubuntu.com/ubuntu jammy-updates/main amd64 Packages [3638 kB]
0% [6 Packages 6999 B/3638 kB 0%] [5 Packages 307 kB/3311 kB 9%]
21% [6 Packages 176 kB/3638 kB 5%] [5 Packages 647 kB/3311 kB 20%]
34% [6 Packages 1077 kB/3638 kB 30%]
34% [5 Packages store 0 B] [6 Packages 1105 kB/3638 kB 30%] [Waiting for header
Get:7 http://security.ubuntu.com/ubuntu jammy-security/universe amd64 Packages [1274 kB]
38% [5 Packages store 0 B] [6 Packages 2154 kB/3638 kB 59%] [7 Packages 64.9 kB
44% [5 Packages store 0 B] [6 Packages 2482 kB/3638 kB 68%] [Waiting for header
Get:8 http://security.ubuntu.com/ubuntu jammy-security/multiverse amd64 Packages [80.3 kB]
44% [5 Packages store 0 B] [6 Packages 2482 kB/3638 kB 68%] [8 Packages 28.7 kB
45% [5 Packages store 0 B] [6 Packages 2547 kB/3638 kB 70%] [Waiting for header
Get:9 http://security.ubuntu.com/ubuntu jammy-security/restricted amd64 Packages [5441 kB]
45% [5 Packages store 0 B] [6 Packages 2547 kB/3638 kB 70%] [9 Packages 12.3 kB
56% [5 Packages store 0 B] [9 Packages 2032 kB/5441 kB 37%]
69% [5 Packages store 0 B] [Waiting for headers]
Get:10 http://arc
[command output truncated]
sts... 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
build-essential is already the newest version (12.9ubuntu3).
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% [Working]
Get:2 http://archive.ubuntu.com/ubuntu jammy/universe amd64 musl-dev amd64 1.2.2-4 [605 kB]
39% [2 musl-dev 5509 B/605 kB 1%]
Get:3 http://archive.ubuntu.com/ubuntu jammy/universe amd64 musl-tools amd64 1.2.2-4 [5520 B]
93% [3 musl-tools 2195 B/5520 B 40%]
100% [Working]
Fetched 1018 kB in 1s (1044 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) ...
↓ 43 lines
0% [Working] Get:1 http://security.ubuntu.com/ubuntu jammy-security InRelease [129 kB] 0% [Waiting for headers] [1 InRelease 14.2 kB/129 kB 11%] Hit:2 http://archive.ubuntu.com/ubuntu jammy InRelease 0% [1 InRelease 14.2 kB/129 kB 11%] Get:3 http://archive.ubuntu.com/ubuntu jammy-updates InRelease [128 kB] 0% [3 InRelease 5484 B/128 kB 4%] [1 InRelease 25.8 kB/129 kB 20%] 0% [3 InRelease 15.6 kB/128 kB 12%] [1 InRelease 63.4 kB/129 kB 49%] 0% [3 InRelease 50.4 kB/128 kB 39%] 0% [Working] 0% [Waiting for headers] Get:4 http://archive.ubuntu.com/ubuntu jammy-backports InRelease [127 kB] 0% [4 InRelease 5484 B/127 kB 4%] [Waiting for headers] Get:5 http://security.ubuntu.com/ubuntu jammy-security/main amd64 Packages [3311 kB] 0% [4 InRelease 62.0 kB/127 kB 49%] [5 Packages 5551 B/3311 kB 0%] 0% [5 Packages 75.1 kB/3311 kB 2%] 0% [5 Packages 134 kB/3311 kB 4%] Get:6 http://archive.ubuntu.com/ubuntu jammy-updates/main amd64 Packages [3638 kB] 0% [6 Packages 6999 B/3638 kB 0%] [5 Packages 307 kB/3311 kB 9%] 21% [6 Packages 176 kB/3638 kB 5%] [5 Packages 647 kB/3311 kB 20%] 34% [6 Packages 1077 kB/3638 kB 30%] 34% [5 Packages store 0 B] [6 Packages 1105 kB/3638 kB 30%] [Waiting for header Get:7 http://security.ubuntu.com/ubuntu jammy-security/universe amd64 Packages [1274 kB] 38% [5 Packages store 0 B] [6 Packages 2154 kB/3638 kB 59%] [7 Packages 64.9 kB 44% [5 Packages store 0 B] [6 Packages 2482 kB/3638 kB 68%] [Waiting for header Get:8 http://security.ubuntu.com/ubuntu jammy-security/multiverse amd64 Packages [80.3 kB] 44% [5 Packages store 0 B] [6 Packages 2482 kB/3638 kB 68%] [8 Packages 28.7 kB 45% [5 Packages store 0 B] [6 Packages 2547 kB/3638 kB 70%] [Waiting for header Get:9 http://security.ubuntu.com/ubuntu jammy-security/restricted amd64 Packages [5441 kB] 45% [5 Packages store 0 B] [6 Packages 2547 kB/3638 kB 70%] [9 Packages 12.3 kB 56% [5 Packages store 0 B] [9 Packages 2032 kB/5441 kB 37%] 69% [5 Packages store 0 B] [Waiting for headers] Get:10 http://arc [command output truncated] sts... 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 build-essential is already the newest version (12.9ubuntu3). 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% [Working] Get:2 http://archive.ubuntu.com/ubuntu jammy/universe amd64 musl-dev amd64 1.2.2-4 [605 kB] 39% [2 musl-dev 5509 B/605 kB 1%] Get:3 http://archive.ubuntu.com/ubuntu jammy/universe amd64 musl-tools amd64 1.2.2-4 [5520 B] 93% [3 musl-tools 2195 B/5520 B 40%] 100% [Working] Fetched 1018 kB in 1s (1044 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) ...
[empty output]
compile-bench> cd /home/peter/jq-build && CC=musl-gcc ./configure --prefix=/home/peter/result --enable-all --disable-maintainer-mode 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
compile-bench> cd /home/peter/jq-build && make LDFLAGS="-static" && make install 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-build'
Making all in vendor/oniguruma
make[2]: Entering directory '/home/peter/jq-build/vendor/oniguruma'
Making all in src
make[3]: Entering directory '/home/peter/jq-build/vendor/oniguruma/src'
make all-am
make[4]: Entering directory '/home/peter/jq-build/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]
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-build/vendor/oniguruma'
make[3]: Leaving directory '/home/peter/jq-build/vendor/oniguruma'
make[2]: Leaving directory '/home/peter/jq-build/vendor/oniguruma'
make[2]: Entering directory '/home/peter/jq-build'
mkdir -p src
GEN src/version.h
CC src/main.o
CCLD jq
make[3]: Entering directory '/home/peter/jq-build'
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-build'
make[2]: Leaving directory '/home/peter/jq-build'
make[1]: Leaving directory '/home/peter/jq-build'
↓ 91 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-build'
Making all in vendor/oniguruma
make[2]: Entering directory '/home/peter/jq-build/vendor/oniguruma'
Making all in src
make[3]: Entering directory '/home/peter/jq-build/vendor/oniguruma/src'
make all-am
make[4]: Entering directory '/home/peter/jq-build/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]
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-build/vendor/oniguruma'
make[3]: Leaving directory '/home/peter/jq-build/vendor/oniguruma'
make[2]: Leaving directory '/home/peter/jq-build/vendor/oniguruma'
make[2]: Entering directory '/home/peter/jq-build'
mkdir -p src
GEN src/version.h
CC src/main.o
CCLD jq
make[3]: Entering directory '/home/peter/jq-build'
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-build'
make[2]: Leaving directory '/home/peter/jq-build'
make[1]: Leaving directory '/home/peter/jq-build'
[empty output]
/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
It seems the binary is dynamically linked against musl, not statically linked as required. I need to adjust the build process to enforce static linking. Let me reconfigure and rebuild with explicit static linking flags.
compile-bench> cd /home/peter/jq-build && make clean && ./configure --prefix=/home/peter/result --enable-all --disable-maintainer-mode LDFLAGS="-static" && make && make install Making clean in vendor/oniguruma
make[1]: Entering directory '/home/peter/jq-build/vendor/oniguruma'
Making clean in src
make[2]: Entering directory '/home/peter/jq-build/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-build/vendor/oniguruma/src'
Making clean in test
make[2]: Entering directory '/home/peter/jq-build/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-build/vendor/oniguruma/test'
Making clean in sample
make[2]: Entering directory '/home/peter/jq-build/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-build/vendor/oniguruma/sample'
make[2]: Entering directory '/home/peter/jq-build/vendor/oniguruma'
rm -rf .libs _libs
rm -f *.lo
make[2]: Leaving directory '/home/peter/jq-build/vendor/oniguruma'
make[1]: Leaving directory '/home/peter/jq-build/vendor/oniguruma'
make[1]: Entering directory '/home/peter/jq-build'
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.
[command output truncated]
make[3]: Entering directory '/home/peter/jq-build/vendor/oniguruma'
make[4]: Entering directory '/home/peter/jq-build/vendor/oniguruma'
/usr/bin/mkdir -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-build/vendor/oniguruma'
make[3]: Leaving directory '/home/peter/jq-build/vendor/oniguruma'
make[2]: Leaving directory '/home/peter/jq-build/vendor/oniguruma'
make[2]: Entering directory '/home/peter/jq-build'
make[3]: Entering directory '/home/peter/jq-build'
/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-build'
make[2]: Leaving directory '/home/peter/jq-build'
make[1]: Leaving directory '/home/peter/jq-build'
↓ 102 lines
Making clean in vendor/oniguruma
make[1]: Entering directory '/home/peter/jq-build/vendor/oniguruma'
Making clean in src
make[2]: Entering directory '/home/peter/jq-build/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-build/vendor/oniguruma/src'
Making clean in test
make[2]: Entering directory '/home/peter/jq-build/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-build/vendor/oniguruma/test'
Making clean in sample
make[2]: Entering directory '/home/peter/jq-build/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-build/vendor/oniguruma/sample'
make[2]: Entering directory '/home/peter/jq-build/vendor/oniguruma'
rm -rf .libs _libs
rm -f *.lo
make[2]: Leaving directory '/home/peter/jq-build/vendor/oniguruma'
make[1]: Leaving directory '/home/peter/jq-build/vendor/oniguruma'
make[1]: Entering directory '/home/peter/jq-build'
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.
[command output truncated]
make[3]: Entering directory '/home/peter/jq-build/vendor/oniguruma'
make[4]: Entering directory '/home/peter/jq-build/vendor/oniguruma'
/usr/bin/mkdir -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-build/vendor/oniguruma'
make[3]: Leaving directory '/home/peter/jq-build/vendor/oniguruma'
make[2]: Leaving directory '/home/peter/jq-build/vendor/oniguruma'
make[2]: Entering directory '/home/peter/jq-build'
make[3]: Entering directory '/home/peter/jq-build'
/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-build'
make[2]: Leaving directory '/home/peter/jq-build'
make[1]: Leaving directory '/home/peter/jq-build'
/home/peter/result/bin/jq: ELF 64-bit LSB pie executable, x86-64, version 1 (SYSV), dynamically linked, interpreter /lib64/ld-linux-x86-64.so.2, BuildID[sha1]=5de308ea95d772deeda41969a0f34d6e7ab5d390, for GNU/Linux 3.2.0, with debug_info, not stripped
The binary is still dynamically linked, but now it's using glibc instead of musl. I need to be more explicit about forcing static linking with musl. Let me try again with more specific compiler and linker flags.
compile-bench> cd /home/peter/jq-build && make clean && CC=musl-gcc ./configure --disable-shared --enable-static --prefix=/home/peter/result --enable-all --disable-maintainer-mode && make LDFLAGS="-static -L/usr/lib/x86_64-linux-musl" && make install Making clean in vendor/oniguruma
make[1]: Entering directory '/home/peter/jq-build/vendor/oniguruma'
Making clean in src
make[2]: Entering directory '/home/peter/jq-build/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-build/vendor/oniguruma/src'
Making clean in test
make[2]: Entering directory '/home/peter/jq-build/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-build/vendor/oniguruma/test'
Making clean in sample
make[2]: Entering directory '/home/peter/jq-build/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-build/vendor/oniguruma/sample'
make[2]: Entering directory '/home/peter/jq-build/vendor/oniguruma'
rm -rf .libs _libs
rm -f *.lo
make[2]: Leaving directory '/home/peter/jq-build/vendor/oniguruma'
make[1]: Leaving directory '/home/peter/jq-build/vendor/oniguruma'
make[1]: Entering directory '/home/peter/jq-build'
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.
[command output truncated]
make[3]: Entering directory '/home/peter/jq-build/vendor/oniguruma'
make[4]: Entering directory '/home/peter/jq-build/vendor/oniguruma'
/usr/bin/mkdir -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-build/vendor/oniguruma'
make[3]: Leaving directory '/home/peter/jq-build/vendor/oniguruma'
make[2]: Leaving directory '/home/peter/jq-build/vendor/oniguruma'
make[2]: Entering directory '/home/peter/jq-build'
make[3]: Entering directory '/home/peter/jq-build'
/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-build'
make[2]: Leaving directory '/home/peter/jq-build'
make[1]: Leaving directory '/home/peter/jq-build'
↓ 102 lines
Making clean in vendor/oniguruma
make[1]: Entering directory '/home/peter/jq-build/vendor/oniguruma'
Making clean in src
make[2]: Entering directory '/home/peter/jq-build/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-build/vendor/oniguruma/src'
Making clean in test
make[2]: Entering directory '/home/peter/jq-build/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-build/vendor/oniguruma/test'
Making clean in sample
make[2]: Entering directory '/home/peter/jq-build/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-build/vendor/oniguruma/sample'
make[2]: Entering directory '/home/peter/jq-build/vendor/oniguruma'
rm -rf .libs _libs
rm -f *.lo
make[2]: Leaving directory '/home/peter/jq-build/vendor/oniguruma'
make[1]: Leaving directory '/home/peter/jq-build/vendor/oniguruma'
make[1]: Entering directory '/home/peter/jq-build'
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.
[command output truncated]
make[3]: Entering directory '/home/peter/jq-build/vendor/oniguruma'
make[4]: Entering directory '/home/peter/jq-build/vendor/oniguruma'
/usr/bin/mkdir -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-build/vendor/oniguruma'
make[3]: Leaving directory '/home/peter/jq-build/vendor/oniguruma'
make[2]: Leaving directory '/home/peter/jq-build/vendor/oniguruma'
make[2]: Entering directory '/home/peter/jq-build'
make[3]: Entering directory '/home/peter/jq-build'
/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-build'
make[2]: Leaving directory '/home/peter/jq-build'
make[1]: Leaving directory '/home/peter/jq-build'
/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
The binary is now using musl, but it's still dynamically linked. I need to force completely static linking. Let me try one more approach with more explicit static linking flags.
compile-bench> cd /home/peter/jq-build && make clean && CC='musl-gcc -static' ./configure --disable-shared --enable-static --prefix=/home/peter/result --enable-all --disable-maintainer-mode && make && make install Making clean in vendor/oniguruma
make[1]: Entering directory '/home/peter/jq-build/vendor/oniguruma'
Making clean in src
make[2]: Entering directory '/home/peter/jq-build/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-build/vendor/oniguruma/src'
Making clean in test
make[2]: Entering directory '/home/peter/jq-build/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-build/vendor/oniguruma/test'
Making clean in sample
make[2]: Entering directory '/home/peter/jq-build/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-build/vendor/oniguruma/sample'
make[2]: Entering directory '/home/peter/jq-build/vendor/oniguruma'
rm -rf .libs _libs
rm -f *.lo
make[2]: Leaving directory '/home/peter/jq-build/vendor/oniguruma'
make[1]: Leaving directory '/home/peter/jq-build/vendor/oniguruma'
make[1]: Entering directory '/home/peter/jq-build'
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.
[command output truncated]
make[3]: Entering directory '/home/peter/jq-build/vendor/oniguruma'
make[4]: Entering directory '/home/peter/jq-build/vendor/oniguruma'
/usr/bin/mkdir -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-build/vendor/oniguruma'
make[3]: Leaving directory '/home/peter/jq-build/vendor/oniguruma'
make[2]: Leaving directory '/home/peter/jq-build/vendor/oniguruma'
make[2]: Entering directory '/home/peter/jq-build'
make[3]: Entering directory '/home/peter/jq-build'
/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-build'
make[2]: Leaving directory '/home/peter/jq-build'
make[1]: Leaving directory '/home/peter/jq-build'
↓ 102 lines
Making clean in vendor/oniguruma
make[1]: Entering directory '/home/peter/jq-build/vendor/oniguruma'
Making clean in src
make[2]: Entering directory '/home/peter/jq-build/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-build/vendor/oniguruma/src'
Making clean in test
make[2]: Entering directory '/home/peter/jq-build/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-build/vendor/oniguruma/test'
Making clean in sample
make[2]: Entering directory '/home/peter/jq-build/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-build/vendor/oniguruma/sample'
make[2]: Entering directory '/home/peter/jq-build/vendor/oniguruma'
rm -rf .libs _libs
rm -f *.lo
make[2]: Leaving directory '/home/peter/jq-build/vendor/oniguruma'
make[1]: Leaving directory '/home/peter/jq-build/vendor/oniguruma'
make[1]: Entering directory '/home/peter/jq-build'
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.
[command output truncated]
make[3]: Entering directory '/home/peter/jq-build/vendor/oniguruma'
make[4]: Entering directory '/home/peter/jq-build/vendor/oniguruma'
/usr/bin/mkdir -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-build/vendor/oniguruma'
make[3]: Leaving directory '/home/peter/jq-build/vendor/oniguruma'
make[2]: Leaving directory '/home/peter/jq-build/vendor/oniguruma'
make[2]: Entering directory '/home/peter/jq-build'
make[3]: Entering directory '/home/peter/jq-build'
/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-build'
make[2]: Leaving directory '/home/peter/jq-build'
make[1]: Leaving directory '/home/peter/jq-build'
/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 need to try a different approach. The issue is that the build system is not properly respecting the static linking flags. Let me try setting the CC and LDFLAGS more explicitly and also disable PIE (Position Independent Executable) which might be interfering with static linking.
compile-bench> cd /home/peter/jq-build && make clean && CC='musl-gcc -static' CFLAGS='-fno-pie' LDFLAGS='-static -no-pie' ./configure --disable-shared --enable-static --prefix=/home/peter/result --enable-all --disable-maintainer-mode && make && make install Making clean in vendor/oniguruma
make[1]: Entering directory '/home/peter/jq-build/vendor/oniguruma'
Making clean in src
make[2]: Entering directory '/home/peter/jq-build/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-build/vendor/oniguruma/src'
Making clean in test
make[2]: Entering directory '/home/peter/jq-build/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-build/vendor/oniguruma/test'
Making clean in sample
make[2]: Entering directory '/home/peter/jq-build/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-build/vendor/oniguruma/sample'
make[2]: Entering directory '/home/peter/jq-build/vendor/oniguruma'
rm -rf .libs _libs
rm -f *.lo
make[2]: Leaving directory '/home/peter/jq-build/vendor/oniguruma'
make[1]: Leaving directory '/home/peter/jq-build/vendor/oniguruma'
make[1]: Entering directory '/home/peter/jq-build'
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.
[command output truncated]
make[3]: Entering directory '/home/peter/jq-build/vendor/oniguruma'
make[4]: Entering directory '/home/peter/jq-build/vendor/oniguruma'
/usr/bin/mkdir -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-build/vendor/oniguruma'
make[3]: Leaving directory '/home/peter/jq-build/vendor/oniguruma'
make[2]: Leaving directory '/home/peter/jq-build/vendor/oniguruma'
make[2]: Entering directory '/home/peter/jq-build'
make[3]: Entering directory '/home/peter/jq-build'
/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-build'
make[2]: Leaving directory '/home/peter/jq-build'
make[1]: Leaving directory '/home/peter/jq-build'
↓ 102 lines
Making clean in vendor/oniguruma
make[1]: Entering directory '/home/peter/jq-build/vendor/oniguruma'
Making clean in src
make[2]: Entering directory '/home/peter/jq-build/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-build/vendor/oniguruma/src'
Making clean in test
make[2]: Entering directory '/home/peter/jq-build/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-build/vendor/oniguruma/test'
Making clean in sample
make[2]: Entering directory '/home/peter/jq-build/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-build/vendor/oniguruma/sample'
make[2]: Entering directory '/home/peter/jq-build/vendor/oniguruma'
rm -rf .libs _libs
rm -f *.lo
make[2]: Leaving directory '/home/peter/jq-build/vendor/oniguruma'
make[1]: Leaving directory '/home/peter/jq-build/vendor/oniguruma'
make[1]: Entering directory '/home/peter/jq-build'
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.
[command output truncated]
make[3]: Entering directory '/home/peter/jq-build/vendor/oniguruma'
make[4]: Entering directory '/home/peter/jq-build/vendor/oniguruma'
/usr/bin/mkdir -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-build/vendor/oniguruma'
make[3]: Leaving directory '/home/peter/jq-build/vendor/oniguruma'
make[2]: Leaving directory '/home/peter/jq-build/vendor/oniguruma'
make[2]: Entering directory '/home/peter/jq-build'
make[3]: Entering directory '/home/peter/jq-build'
/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-build'
make[2]: Leaving directory '/home/peter/jq-build'
make[1]: Leaving directory '/home/peter/jq-build'
/home/peter/result/bin/jq: ELF 64-bit LSB executable, x86-64, version 1 (SYSV), dynamically linked, interpreter /lib/ld-musl-x86_64.so.1, with debug_info, not stripped
I see that PIE has been disabled (it now says "executable" instead of "pie executable"), but it's still dynamically linked. Let me try a more forceful approach by directly modifying the Makefile after configuration to ensure static linking.
compile-bench> cd /home/peter/jq-build && make clean && CC=musl-gcc ./configure --disable-shared --enable-static --prefix=/home/peter/result --enable-all --disable-maintainer-mode && sed -i 's/^LDFLAGS =/LDFLAGS = -static -no-pie/' Makefile src/Makefile && make && make install Making clean in vendor/oniguruma
make[1]: Entering directory '/home/peter/jq-build/vendor/oniguruma'
Making clean in src
make[2]: Entering directory '/home/peter/jq-build/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-build/vendor/oniguruma/src'
Making clean in test
make[2]: Entering directory '/home/peter/jq-build/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-build/vendor/oniguruma/test'
Making clean in sample
make[2]: Entering directory '/home/peter/jq-build/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-build/vendor/oniguruma/sample'
make[2]: Entering directory '/home/peter/jq-build/vendor/oniguruma'
rm -rf .libs _libs
rm -f *.lo
make[2]: Leaving directory '/home/peter/jq-build/vendor/oniguruma'
make[1]: Leaving directory '/home/peter/jq-build/vendor/oniguruma'
make[1]: Entering directory '/home/peter/jq-build'
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.
[command output truncated]
ing 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: src/config.h is unchanged
config.status: executing depfiles commands
config.status: executing libtool commands
config.status: executing default commands
sed: can't read src/Makefile: No such file or directory
↓ 118 lines
Making clean in vendor/oniguruma make[1]: Entering directory '/home/peter/jq-build/vendor/oniguruma' Making clean in src make[2]: Entering directory '/home/peter/jq-build/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-build/vendor/oniguruma/src' Making clean in test make[2]: Entering directory '/home/peter/jq-build/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-build/vendor/oniguruma/test' Making clean in sample make[2]: Entering directory '/home/peter/jq-build/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-build/vendor/oniguruma/sample' make[2]: Entering directory '/home/peter/jq-build/vendor/oniguruma' rm -rf .libs _libs rm -f *.lo make[2]: Leaving directory '/home/peter/jq-build/vendor/oniguruma' make[1]: Leaving directory '/home/peter/jq-build/vendor/oniguruma' make[1]: Entering directory '/home/peter/jq-build' 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. [command output truncated] ing 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: src/config.h is unchanged config.status: executing depfiles commands config.status: executing libtool commands config.status: executing default commands sed: can't read src/Makefile: No such file or directory
I see the issue - the Makefiles are generated in subdirectories after running make, not after configure. Let me fix this by running make first, then modifying the Makefiles, then running make again.
compile-bench> cd /home/peter/jq-build && make clean && CC=musl-gcc ./configure --disable-shared --enable-static --prefix=/home/peter/result --enable-all --disable-maintainer-mode && make && sed -i 's/^LDFLAGS =/LDFLAGS = -static -no-pie/' Makefile src/Makefile && make clean && make && make install Making clean in vendor/oniguruma
make[1]: Entering directory '/home/peter/jq-build/vendor/oniguruma'
Making clean in src
make[2]: Entering directory '/home/peter/jq-build/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-build/vendor/oniguruma/src'
Making clean in test
make[2]: Entering directory '/home/peter/jq-build/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-build/vendor/oniguruma/test'
Making clean in sample
make[2]: Entering directory '/home/peter/jq-build/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-build/vendor/oniguruma/sample'
make[2]: Entering directory '/home/peter/jq-build/vendor/oniguruma'
rm -rf .libs _libs
rm -f *.lo
make[2]: Leaving directory '/home/peter/jq-build/vendor/oniguruma'
make[1]: Leaving directory '/home/peter/jq-build/vendor/oniguruma'
make[1]: Entering directory '/home/peter/jq-build'
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.
[command output truncated]
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-build/vendor/oniguruma/src'
make[3]: Leaving directory '/home/peter/jq-build/vendor/oniguruma/src'
Making all in test
make[3]: Entering directory '/home/peter/jq-build/vendor/oniguruma/test'
make[3]: Nothing to be done for 'all'.
make[3]: Leaving directory '/home/peter/jq-build/vendor/oniguruma/test'
Making all in sample
make[3]: Entering directory '/home/peter/jq-build/vendor/oniguruma/sample'
make[3]: Nothing to be done for 'all'.
make[3]: Leaving directory '/home/peter/jq-build/vendor/oniguruma/sample'
make[3]: Entering directory '/home/peter/jq-build/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-build/vendor/oniguruma'
make[2]: Leaving directory '/home/peter/jq-build/vendor/oniguruma'
make[2]: Entering directory '/home/peter/jq-build'
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
GEN jq.1
make[2]: Leaving directory '/home/peter/jq-build'
make[1]: Leaving directory '/home/peter/jq-build'
sed: can't read src/Makefile: No such file or directory
↓ 98 lines
Making clean in vendor/oniguruma make[1]: Entering directory '/home/peter/jq-build/vendor/oniguruma' Making clean in src make[2]: Entering directory '/home/peter/jq-build/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-build/vendor/oniguruma/src' Making clean in test make[2]: Entering directory '/home/peter/jq-build/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-build/vendor/oniguruma/test' Making clean in sample make[2]: Entering directory '/home/peter/jq-build/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-build/vendor/oniguruma/sample' make[2]: Entering directory '/home/peter/jq-build/vendor/oniguruma' rm -rf .libs _libs rm -f *.lo make[2]: Leaving directory '/home/peter/jq-build/vendor/oniguruma' make[1]: Leaving directory '/home/peter/jq-build/vendor/oniguruma' make[1]: Entering directory '/home/peter/jq-build' 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. [command output truncated] 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-build/vendor/oniguruma/src' make[3]: Leaving directory '/home/peter/jq-build/vendor/oniguruma/src' Making all in test make[3]: Entering directory '/home/peter/jq-build/vendor/oniguruma/test' make[3]: Nothing to be done for 'all'. make[3]: Leaving directory '/home/peter/jq-build/vendor/oniguruma/test' Making all in sample make[3]: Entering directory '/home/peter/jq-build/vendor/oniguruma/sample' make[3]: Nothing to be done for 'all'. make[3]: Leaving directory '/home/peter/jq-build/vendor/oniguruma/sample' make[3]: Entering directory '/home/peter/jq-build/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-build/vendor/oniguruma' make[2]: Leaving directory '/home/peter/jq-build/vendor/oniguruma' make[2]: Entering directory '/home/peter/jq-build' 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 GEN jq.1 make[2]: Leaving directory '/home/peter/jq-build' make[1]: Leaving directory '/home/peter/jq-build' sed: can't read src/Makefile: No such file or directory
I see the issue - the src/Makefile doesn't exist until after we run make for the first time. Let me fix this by running make once to generate the Makefiles, then modifying them, then running make clean and make again.
compile-bench> cd /home/peter/jq-build && make clean && CC=musl-gcc ./configure --disable-shared --enable-static --prefix=/home/peter/result --enable-all --disable-maintainer-mode && make && sed -i 's/^LDFLAGS = \(.*\)$/LDFLAGS = -static -no-pie \1/' Makefile src/Makefile && make clean && make && make install Making clean in vendor/oniguruma
make[1]: Entering directory '/home/peter/jq-build/vendor/oniguruma'
Making clean in src
make[2]: Entering directory '/home/peter/jq-build/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-build/vendor/oniguruma/src'
Making clean in test
make[2]: Entering directory '/home/peter/jq-build/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-build/vendor/oniguruma/test'
Making clean in sample
make[2]: Entering directory '/home/peter/jq-build/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-build/vendor/oniguruma/sample'
make[2]: Entering directory '/home/peter/jq-build/vendor/oniguruma'
rm -rf .libs _libs
rm -f *.lo
make[2]: Leaving directory '/home/peter/jq-build/vendor/oniguruma'
make[1]: Leaving directory '/home/peter/jq-build/vendor/oniguruma'
make[1]: Entering directory '/home/peter/jq-build'
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.
[command output truncated]
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-build/vendor/oniguruma/src'
make[3]: Leaving directory '/home/peter/jq-build/vendor/oniguruma/src'
Making all in test
make[3]: Entering directory '/home/peter/jq-build/vendor/oniguruma/test'
make[3]: Nothing to be done for 'all'.
make[3]: Leaving directory '/home/peter/jq-build/vendor/oniguruma/test'
Making all in sample
make[3]: Entering directory '/home/peter/jq-build/vendor/oniguruma/sample'
make[3]: Nothing to be done for 'all'.
make[3]: Leaving directory '/home/peter/jq-build/vendor/oniguruma/sample'
make[3]: Entering directory '/home/peter/jq-build/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-build/vendor/oniguruma'
make[2]: Leaving directory '/home/peter/jq-build/vendor/oniguruma'
make[2]: Entering directory '/home/peter/jq-build'
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
GEN jq.1
make[2]: Leaving directory '/home/peter/jq-build'
make[1]: Leaving directory '/home/peter/jq-build'
sed: can't read src/Makefile: No such file or directory
↓ 98 lines
Making clean in vendor/oniguruma make[1]: Entering directory '/home/peter/jq-build/vendor/oniguruma' Making clean in src make[2]: Entering directory '/home/peter/jq-build/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-build/vendor/oniguruma/src' Making clean in test make[2]: Entering directory '/home/peter/jq-build/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-build/vendor/oniguruma/test' Making clean in sample make[2]: Entering directory '/home/peter/jq-build/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-build/vendor/oniguruma/sample' make[2]: Entering directory '/home/peter/jq-build/vendor/oniguruma' rm -rf .libs _libs rm -f *.lo make[2]: Leaving directory '/home/peter/jq-build/vendor/oniguruma' make[1]: Leaving directory '/home/peter/jq-build/vendor/oniguruma' make[1]: Entering directory '/home/peter/jq-build' 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. [command output truncated] 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-build/vendor/oniguruma/src' make[3]: Leaving directory '/home/peter/jq-build/vendor/oniguruma/src' Making all in test make[3]: Entering directory '/home/peter/jq-build/vendor/oniguruma/test' make[3]: Nothing to be done for 'all'. make[3]: Leaving directory '/home/peter/jq-build/vendor/oniguruma/test' Making all in sample make[3]: Entering directory '/home/peter/jq-build/vendor/oniguruma/sample' make[3]: Nothing to be done for 'all'. make[3]: Leaving directory '/home/peter/jq-build/vendor/oniguruma/sample' make[3]: Entering directory '/home/peter/jq-build/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-build/vendor/oniguruma' make[2]: Leaving directory '/home/peter/jq-build/vendor/oniguruma' make[2]: Entering directory '/home/peter/jq-build' 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 GEN jq.1 make[2]: Leaving directory '/home/peter/jq-build' make[1]: Leaving directory '/home/peter/jq-build' sed: can't read src/Makefile: No such file or directory
I see the issue - the Makefiles are still not being found. Let me check what files are actually generated and adjust my approach accordingly.
compile-bench> cd /home/peter/jq-build && find . -name Makefile ./vendor/oniguruma/sample/Makefile
./vendor/oniguruma/Makefile
./vendor/oniguruma/src/Makefile
./vendor/oniguruma/test/Makefile
./Makefile
↓ 6 lines
./vendor/oniguruma/sample/Makefile ./vendor/oniguruma/Makefile ./vendor/oniguruma/src/Makefile ./vendor/oniguruma/test/Makefile ./Makefile
Now I see the structure. The src directory is not a separate Makefile directory. Let me try a different approach - I'll modify the top-level Makefile and the oniguruma Makefiles to ensure static linking.
compile-bench> cd /home/peter/jq-build && make clean && CC=musl-gcc ./configure --disable-shared --enable-static --prefix=/home/peter/result --enable-all --disable-maintainer-mode && make && sed -i 's/^LDFLAGS = \(.*\)$/LDFLAGS = -static -no-pie \1/' Makefile vendor/oniguruma/Makefile vendor/oniguruma/src/Makefile && make clean && make && make install Making clean in vendor/oniguruma
make[1]: Entering directory '/home/peter/jq-build/vendor/oniguruma'
Making clean in src
make[2]: Entering directory '/home/peter/jq-build/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-build/vendor/oniguruma/src'
Making clean in test
make[2]: Entering directory '/home/peter/jq-build/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-build/vendor/oniguruma/test'
Making clean in sample
make[2]: Entering directory '/home/peter/jq-build/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-build/vendor/oniguruma/sample'
make[2]: Entering directory '/home/peter/jq-build/vendor/oniguruma'
rm -rf .libs _libs
rm -f *.lo
make[2]: Leaving directory '/home/peter/jq-build/vendor/oniguruma'
make[1]: Leaving directory '/home/peter/jq-build/vendor/oniguruma'
make[1]: Entering directory '/home/peter/jq-build'
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.
[command output truncated]
make[3]: Entering directory '/home/peter/jq-build/vendor/oniguruma'
make[4]: Entering directory '/home/peter/jq-build/vendor/oniguruma'
/usr/bin/mkdir -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-build/vendor/oniguruma'
make[3]: Leaving directory '/home/peter/jq-build/vendor/oniguruma'
make[2]: Leaving directory '/home/peter/jq-build/vendor/oniguruma'
make[2]: Entering directory '/home/peter/jq-build'
make[3]: Entering directory '/home/peter/jq-build'
/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-build'
make[2]: Leaving directory '/home/peter/jq-build'
make[1]: Leaving directory '/home/peter/jq-build'
↓ 102 lines
Making clean in vendor/oniguruma
make[1]: Entering directory '/home/peter/jq-build/vendor/oniguruma'
Making clean in src
make[2]: Entering directory '/home/peter/jq-build/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-build/vendor/oniguruma/src'
Making clean in test
make[2]: Entering directory '/home/peter/jq-build/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-build/vendor/oniguruma/test'
Making clean in sample
make[2]: Entering directory '/home/peter/jq-build/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-build/vendor/oniguruma/sample'
make[2]: Entering directory '/home/peter/jq-build/vendor/oniguruma'
rm -rf .libs _libs
rm -f *.lo
make[2]: Leaving directory '/home/peter/jq-build/vendor/oniguruma'
make[1]: Leaving directory '/home/peter/jq-build/vendor/oniguruma'
make[1]: Entering directory '/home/peter/jq-build'
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.
[command output truncated]
make[3]: Entering directory '/home/peter/jq-build/vendor/oniguruma'
make[4]: Entering directory '/home/peter/jq-build/vendor/oniguruma'
/usr/bin/mkdir -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-build/vendor/oniguruma'
make[3]: Leaving directory '/home/peter/jq-build/vendor/oniguruma'
make[2]: Leaving directory '/home/peter/jq-build/vendor/oniguruma'
make[2]: Entering directory '/home/peter/jq-build'
make[3]: Entering directory '/home/peter/jq-build'
/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-build'
make[2]: Leaving directory '/home/peter/jq-build'
make[1]: Leaving directory '/home/peter/jq-build'
/home/peter/result/bin/jq: ELF 64-bit LSB executable, x86-64, version 1 (SYSV), dynamically linked, interpreter /lib/ld-musl-x86_64.so.1, with debug_info, not stripped
I'm still not getting a statically linked binary. Let me try one final approach - I'll directly modify the linking command in the Makefile to force static linking with musl-gcc.
compile-bench> cd /home/peter/jq-build && make clean && CC=musl-gcc ./configure --disable-shared --enable-static --prefix=/home/peter/result --enable-all --disable-maintainer-mode && make && sed -i 's/\(LINK = \)\(.*\)$/\1musl-gcc -static -no-pie /' Makefile && make clean && make && make install Making clean in vendor/oniguruma
make[1]: Entering directory '/home/peter/jq-build/vendor/oniguruma'
Making clean in src
make[2]: Entering directory '/home/peter/jq-build/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-build/vendor/oniguruma/src'
Making clean in test
make[2]: Entering directory '/home/peter/jq-build/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-build/vendor/oniguruma/test'
Making clean in sample
make[2]: Entering directory '/home/peter/jq-build/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-build/vendor/oniguruma/sample'
make[2]: Entering directory '/home/peter/jq-build/vendor/oniguruma'
rm -rf .libs _libs
rm -f *.lo
make[2]: Leaving directory '/home/peter/jq-build/vendor/oniguruma'
make[1]: Leaving directory '/home/peter/jq-build/vendor/oniguruma'
make[1]: Entering directory '/home/peter/jq-build'
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.
[command output truncated]
9_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-build/vendor/oniguruma/src'
make[3]: Leaving directory '/home/peter/jq-build/vendor/oniguruma/src'
Making all in test
make[3]: Entering directory '/home/peter/jq-build/vendor/oniguruma/test'
make[3]: Nothing to be done for 'all'.
make[3]: Leaving directory '/home/peter/jq-build/vendor/oniguruma/test'
Making all in sample
make[3]: Entering directory '/home/peter/jq-build/vendor/oniguruma/sample'
make[3]: Nothing to be done for 'all'.
make[3]: Leaving directory '/home/peter/jq-build/vendor/oniguruma/sample'
make[3]: Entering directory '/home/peter/jq-build/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-build/vendor/oniguruma'
make[2]: Leaving directory '/home/peter/jq-build/vendor/oniguruma'
make[2]: Entering directory '/home/peter/jq-build'
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
GEN jq.1
make[2]: Leaving directory '/home/peter/jq-build'
make[1]: Leaving directory '/home/peter/jq-build'
Makefile:187: *** recipe commences before first target. Stop.
↓ 98 lines
Making clean in vendor/oniguruma make[1]: Entering directory '/home/peter/jq-build/vendor/oniguruma' Making clean in src make[2]: Entering directory '/home/peter/jq-build/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-build/vendor/oniguruma/src' Making clean in test make[2]: Entering directory '/home/peter/jq-build/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-build/vendor/oniguruma/test' Making clean in sample make[2]: Entering directory '/home/peter/jq-build/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-build/vendor/oniguruma/sample' make[2]: Entering directory '/home/peter/jq-build/vendor/oniguruma' rm -rf .libs _libs rm -f *.lo make[2]: Leaving directory '/home/peter/jq-build/vendor/oniguruma' make[1]: Leaving directory '/home/peter/jq-build/vendor/oniguruma' make[1]: Entering directory '/home/peter/jq-build' 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. [command output truncated] 9_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-build/vendor/oniguruma/src' make[3]: Leaving directory '/home/peter/jq-build/vendor/oniguruma/src' Making all in test make[3]: Entering directory '/home/peter/jq-build/vendor/oniguruma/test' make[3]: Nothing to be done for 'all'. make[3]: Leaving directory '/home/peter/jq-build/vendor/oniguruma/test' Making all in sample make[3]: Entering directory '/home/peter/jq-build/vendor/oniguruma/sample' make[3]: Nothing to be done for 'all'. make[3]: Leaving directory '/home/peter/jq-build/vendor/oniguruma/sample' make[3]: Entering directory '/home/peter/jq-build/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-build/vendor/oniguruma' make[2]: Leaving directory '/home/peter/jq-build/vendor/oniguruma' make[2]: Entering directory '/home/peter/jq-build' 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 GEN jq.1 make[2]: Leaving directory '/home/peter/jq-build' make[1]: Leaving directory '/home/peter/jq-build' Makefile:187: *** recipe commences before first target. Stop.
I see the issue - my sed command corrupted the Makefile. Let me try a more careful approach to modify the linking command.
Makefile:187: *** recipe commences before first target. Stop.
I need to be more careful with the sed pattern. Let me examine the Makefile first to understand its structure, then apply a more targeted modification.
Makefile:187: *** recipe commences before first target. Stop.
I see the issue - I'm trying to grep before the Makefile is properly generated. Let me generate the Makefile first, then examine it.
Makefile:187: *** recipe commences before first target. Stop.
I'm still having issues with the Makefile. Let me try a different approach - I'll look for the CCLD line in the build output to understand how the linking is being done, then try to override it with environment variables.
Makefile:187: *** recipe commences before first target. Stop.
I'm still having issues with the Makefile structure. Let me try a completely different approach - I'll use the CFLAGS and LDFLAGS environment variables to force static linking, and also set the LIBS variable to include static libraries explicitly.
Makefile:187: *** recipe commences before first target. Stop.
I'm still having issues with the Makefile. Let me try to reset the build environment completely and start fresh.
compile-bench> rm -rf /home/peter/jq-build && mkdir -p /home/peter/jq-build && tar -xzf /home/peter/jq.tar.gz -C /home/peter/jq-build --strip-components=1 && cd /home/peter/jq-build && CC=musl-gcc ./configure --disable-shared --enable-static --prefix=/home/peter/result --enable-all --disable-maintainer-mode && make LDFLAGS="-static -no-pie" && make install 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]
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-build/vendor/oniguruma'
make[3]: Leaving directory '/home/peter/jq-build/vendor/oniguruma'
make[2]: Leaving directory '/home/peter/jq-build/vendor/oniguruma'
make[2]: Entering directory '/home/peter/jq-build'
mkdir -p src
GEN src/version.h
CC src/main.o
CCLD jq
make[3]: Entering directory '/home/peter/jq-build'
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-build'
make[2]: Leaving directory '/home/peter/jq-build'
make[1]: Leaving directory '/home/peter/jq-build'
↓ 119 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]
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-build/vendor/oniguruma'
make[3]: Leaving directory '/home/peter/jq-build/vendor/oniguruma'
make[2]: Leaving directory '/home/peter/jq-build/vendor/oniguruma'
make[2]: Entering directory '/home/peter/jq-build'
mkdir -p src
GEN src/version.h
CC src/main.o
CCLD jq
make[3]: Entering directory '/home/peter/jq-build'
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-build'
make[2]: Leaving directory '/home/peter/jq-build'
make[1]: Leaving directory '/home/peter/jq-build'
/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've tried multiple approaches but haven't been able to create a statically linked binary. Let me try one final approach - I'll use the musl-gcc wrapper with explicit static flags and also set the --host flag to ensure we're targeting musl properly.
compile-bench> cd /home/peter/jq-build && make clean && ./configure --host=x86_64-linux-musl --disable-shared --enable-static --prefix=/home/peter/result --enable-all --disable-maintainer-mode CC="musl-gcc -static" CFLAGS="-static -fno-pie" LDFLAGS="-static -no-pie" && make && make install Making clean in vendor/oniguruma
make[1]: Entering directory '/home/peter/jq-build/vendor/oniguruma'
Making clean in src
make[2]: Entering directory '/home/peter/jq-build/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-build/vendor/oniguruma/src'
Making clean in test
make[2]: Entering directory '/home/peter/jq-build/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-build/vendor/oniguruma/test'
Making clean in sample
make[2]: Entering directory '/home/peter/jq-build/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-build/vendor/oniguruma/sample'
make[2]: Entering directory '/home/peter/jq-build/vendor/oniguruma'
rm -rf .libs _libs
rm -f *.lo
make[2]: Leaving directory '/home/peter/jq-build/vendor/oniguruma'
make[1]: Leaving directory '/home/peter/jq-build/vendor/oniguruma'
make[1]: Entering directory '/home/peter/jq-build'
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.
[command output truncated]
make[3]: Entering directory '/home/peter/jq-build/vendor/oniguruma'
make[4]: Entering directory '/home/peter/jq-build/vendor/oniguruma'
/usr/bin/mkdir -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-build/vendor/oniguruma'
make[3]: Leaving directory '/home/peter/jq-build/vendor/oniguruma'
make[2]: Leaving directory '/home/peter/jq-build/vendor/oniguruma'
make[2]: Entering directory '/home/peter/jq-build'
make[3]: Entering directory '/home/peter/jq-build'
/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-build'
make[2]: Leaving directory '/home/peter/jq-build'
make[1]: Leaving directory '/home/peter/jq-build'
↓ 102 lines
Making clean in vendor/oniguruma
make[1]: Entering directory '/home/peter/jq-build/vendor/oniguruma'
Making clean in src
make[2]: Entering directory '/home/peter/jq-build/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-build/vendor/oniguruma/src'
Making clean in test
make[2]: Entering directory '/home/peter/jq-build/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-build/vendor/oniguruma/test'
Making clean in sample
make[2]: Entering directory '/home/peter/jq-build/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-build/vendor/oniguruma/sample'
make[2]: Entering directory '/home/peter/jq-build/vendor/oniguruma'
rm -rf .libs _libs
rm -f *.lo
make[2]: Leaving directory '/home/peter/jq-build/vendor/oniguruma'
make[1]: Leaving directory '/home/peter/jq-build/vendor/oniguruma'
make[1]: Entering directory '/home/peter/jq-build'
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.
[command output truncated]
make[3]: Entering directory '/home/peter/jq-build/vendor/oniguruma'
make[4]: Entering directory '/home/peter/jq-build/vendor/oniguruma'
/usr/bin/mkdir -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-build/vendor/oniguruma'
make[3]: Leaving directory '/home/peter/jq-build/vendor/oniguruma'
make[2]: Leaving directory '/home/peter/jq-build/vendor/oniguruma'
make[2]: Entering directory '/home/peter/jq-build'
make[3]: Entering directory '/home/peter/jq-build'
/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-build'
make[2]: Leaving directory '/home/peter/jq-build'
make[1]: Leaving directory '/home/peter/jq-build'
/home/peter/result/bin/jq: ELF 64-bit LSB executable, x86-64, version 1 (SYSV), dynamically linked, interpreter /lib/ld-musl-x86_64.so.1, with debug_info, not stripped
After extensive efforts, I've been unable to create a statically linked binary using the standard build process. This is likely due to the complexity of the build system and dependencies. Let me try one final approach - I'll create a statically linked version by directly using musl-gcc on the final link step after a regular build.
compile-bench> cd /home/peter/jq-build && make clean && CC=musl-gcc ./configure --disable-shared --enable-static --prefix=/home/peter/result --enable-all --disable-maintainer-mode && make && musl-gcc -static -o jq-static src/main.o src/.libs/libjq.a vendor/oniguruma/src/.libs/libonig.a -lm && cp jq-static /home/peter/result/bin/jq && ln -sf /home/peter/result/bin/jq /home/peter/result/jq Making clean in vendor/oniguruma
make[1]: Entering directory '/home/peter/jq-build/vendor/oniguruma'
Making clean in src
make[2]: Entering directory '/home/peter/jq-build/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-build/vendor/oniguruma/src'
Making clean in test
make[2]: Entering directory '/home/peter/jq-build/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-build/vendor/oniguruma/test'
Making clean in sample
make[2]: Entering directory '/home/peter/jq-build/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-build/vendor/oniguruma/sample'
make[2]: Entering directory '/home/peter/jq-build/vendor/oniguruma'
rm -rf .libs _libs
rm -f *.lo
make[2]: Leaving directory '/home/peter/jq-build/vendor/oniguruma'
make[1]: Leaving directory '/home/peter/jq-build/vendor/oniguruma'
make[1]: Entering directory '/home/peter/jq-build'
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.
[command output truncated]
59_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-build/vendor/oniguruma/src'
make[3]: Leaving directory '/home/peter/jq-build/vendor/oniguruma/src'
Making all in test
make[3]: Entering directory '/home/peter/jq-build/vendor/oniguruma/test'
make[3]: Nothing to be done for 'all'.
make[3]: Leaving directory '/home/peter/jq-build/vendor/oniguruma/test'
Making all in sample
make[3]: Entering directory '/home/peter/jq-build/vendor/oniguruma/sample'
make[3]: Nothing to be done for 'all'.
make[3]: Leaving directory '/home/peter/jq-build/vendor/oniguruma/sample'
make[3]: Entering directory '/home/peter/jq-build/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-build/vendor/oniguruma'
make[2]: Leaving directory '/home/peter/jq-build/vendor/oniguruma'
make[2]: Entering directory '/home/peter/jq-build'
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
GEN jq.1
make[2]: Leaving directory '/home/peter/jq-build'
make[1]: Leaving directory '/home/peter/jq-build'
/usr/bin/ld: cannot find src/.libs/libjq.a: No such file or directory
collect2: error: ld returned 1 exit status
↓ 99 lines
Making clean in vendor/oniguruma make[1]: Entering directory '/home/peter/jq-build/vendor/oniguruma' Making clean in src make[2]: Entering directory '/home/peter/jq-build/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-build/vendor/oniguruma/src' Making clean in test make[2]: Entering directory '/home/peter/jq-build/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-build/vendor/oniguruma/test' Making clean in sample make[2]: Entering directory '/home/peter/jq-build/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-build/vendor/oniguruma/sample' make[2]: Entering directory '/home/peter/jq-build/vendor/oniguruma' rm -rf .libs _libs rm -f *.lo make[2]: Leaving directory '/home/peter/jq-build/vendor/oniguruma' make[1]: Leaving directory '/home/peter/jq-build/vendor/oniguruma' make[1]: Entering directory '/home/peter/jq-build' 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. [command output truncated] 59_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-build/vendor/oniguruma/src' make[3]: Leaving directory '/home/peter/jq-build/vendor/oniguruma/src' Making all in test make[3]: Entering directory '/home/peter/jq-build/vendor/oniguruma/test' make[3]: Nothing to be done for 'all'. make[3]: Leaving directory '/home/peter/jq-build/vendor/oniguruma/test' Making all in sample make[3]: Entering directory '/home/peter/jq-build/vendor/oniguruma/sample' make[3]: Nothing to be done for 'all'. make[3]: Leaving directory '/home/peter/jq-build/vendor/oniguruma/sample' make[3]: Entering directory '/home/peter/jq-build/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-build/vendor/oniguruma' make[2]: Leaving directory '/home/peter/jq-build/vendor/oniguruma' make[2]: Entering directory '/home/peter/jq-build' 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 GEN jq.1 make[2]: Leaving directory '/home/peter/jq-build' make[1]: Leaving directory '/home/peter/jq-build' /usr/bin/ld: cannot find src/.libs/libjq.a: No such file or directory collect2: error: ld returned 1 exit status
I see the issue - the static library is not in the location I expected. Let me check where the static libraries are actually located and adjust my command accordingly.
compile-bench> cd /home/peter/jq-build && find . -name "*.a" ./vendor/oniguruma/src/.libs/libonig.a
./.libs/libjq.a
↓ 3 lines
./vendor/oniguruma/src/.libs/libonig.a ./.libs/libjq.a
Now I have the correct paths. Let me try the direct linking approach again with the correct library paths.
[empty output]
/home/peter/result/bin/jq: ELF 64-bit LSB executable, x86-64, version 1 (SYSV), statically linked, with debug_info, not stripped