| Cost | $0.351 |
| Total elapsed time | 4m41s |
| LLM inference time | 3m43s |
| Command execution time | 58s |
| Commands executed | 36 |
All details >
| Attempt ID | hwijgk2fy8ee0 | Attempt group | run-23-09-21-48 |
| Revision | ad46875d9374 | AWS Instance | m8i.2xlarge |
| Start time | 2025-09-23T19:52:05.168Z | End time | 2025-09-23T19:56:53.751Z |
| Task | jq-windows | Environment | ubuntu-22.04-amd64-wine |
| Model | | OpenRouter slug | openai/gpt-5-codex |
| Temperature | 1 | Explicit prompt caching | false |
| User msg after tool call | false | Max tool calls | 100 |
| Total timeout seconds | 2400 | Single command timeout | 1200 |
| Cost | $0.351 | Duration | 4m41s |
| LLM inference time | 3m43s | Command execution time | 58s |
| Final context tokens | 38,792 | Total output tokens | 12,437 |
| Output reasoning tokens | 10,368 | Messages | 75 |
| Assistant messages | 37 | User messages | 1 |
| System messages | 1 | Commands executed | 36 |
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 jq to a specific location. Cross-compile to Windows, link it statically.
Difficulties:
Cross-compilation to Windows, setting up the cross-compilation toolchain (compilers, etc), making sure that there are no dynamic libraries.
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 jq.tar.gz. Please compile the jq package for amd64 Windows and install it to /home/peter/result/jq.exe. Build it statically.
Show reasoning
Preparing cross-compilation environment for jq static Windows build
jq.tar.gz
Show reasoning
Extracting tarball file
[empty output]
Show reasoning
Listing extracted directory contents
jq-1.8.1 jq.tar.gz
Show reasoning
Updating package lists
compile-bench> sudo apt-get update
0% [Working]
Get:1 http://security.ubuntu.com/ubuntu jammy-security InRelease [129 kB]
0% [Connecting to archive.ubuntu.com (185.125.190.36)] [1 InRelease 14.2 kB/129
0% [Waiting for headers]
0% [Waiting for headers]
Hit:2 http://archive.ubuntu.com/ubuntu jammy InRelease
0% [Waiting for headers]
Get:3 http://security.ubuntu.com/ubuntu jammy-security/multiverse amd64 Packages [71.0 kB]
0% [Waiting for headers] [3 Packages 5554 B/71.0 kB 8%]
0% [Waiting for headers]
0% [3 Packages store 0 B] [Waiting for headers] [Waiting for headers]
0% [Waiting for headers] [Waiting for headers]
0% [Waiting for headers] [Waiting for headers]
Get:4 http://security.ubuntu.com/ubuntu jammy-security/main amd64 Packages [3336 kB]
0% [Waiting for headers] [4 Packages 5551 B/3336 kB 0%]
Get:5 http://archive.ubuntu.com/ubuntu jammy-updates InRelease [128 kB]
0% [5 InRelease 12.7 kB/128 kB 10%] [4 Packages 230 kB/3336 kB 7%]
0% [5 InRelease 18.5 kB/128 kB 14%] [Waiting for headers]
Get:6 http://security.ubuntu.com/ubuntu jammy-security/restricted amd64 Packages [5526 kB]
0% [5 InRelease 18.5 kB/128 kB 14%] [6 Packages 49.2 kB/5526 kB 1%]
0% [4 Packages store 0 B] [5 InRelease 18.5 kB/128 kB 14%] [6 Packages 67.8 kB/
0% [4 Packages store 0 B] [5 InRelease 38.8 kB/128 kB 30%] [Waiting for headers
Get:7 http://security.ubuntu.com/ubuntu jammy-security/universe amd64 Packages [1274 kB]
0% [4 Packages store 0 B] [5 InRelease 38.8 kB/128 kB 30%] [7 Packages 46.9 kB/
0% [4 Packages store 0 B] [5 InRelease 47.5 kB/128 kB 37%]
0% [5 InRelease 56.2 kB/128 kB 44%]
0% [6 Packages store 0 B] [5 InRelease 56.2 kB/128 kB 44%]
0% [6 Packages store 0 B] [Waiting for headers]
0% [6 Packages store 0 B] [Waiting for headers]
0% [Waiting for headers]
0% [7 Packages store 0 B] [Waiting for headers]
Get:8 http://archive.ubuntu.com/ubuntu jammy-backports InRelease [127 kB]
0% [7 Packages store 0 B] [8 InRelease 2588 B/127 kB 2%]
0% [8 InRelease 5484 B/127 kB 4%]
0% [Working]
57% [Waiting for headers]
Get:9 http://archive.ubuntu.com/ubuntu jammy-updates/restricted amd64 Packages [5779 kB]
57% [9 Packages 2655 B/5779 kB 0%]
74% [9 Packages 4658 kB/5779 kB 81%]
78% [Waiting for headers]
Get:10 http://archive.ubuntu.com/ubuntu jammy-updates/universe amd64 Packages [1577 kB]
78% [10 Packages 16.4 kB/1577 kB 1%]
79% [9 Packages store 0 B] [10 Packages 125 kB/1577 kB 8%]
84% [9 Packages store 0 B] [Waiting for headers]
Get:11 http://archive.ubuntu.com/ubuntu jammy-updates/multiverse amd64 Packages [69.1 kB]
84% [9 Packages store 0 B] [11 Packages 38.0 kB/69.1 kB 55%]
84% [9 Packages store 0 B] [Waiting for headers]
Get:12 http://archive.ubuntu.com/ubuntu jammy-updates/main amd64 Packages [3681 kB]
84% [9 Packages store 0 B] [12 Packages 32.2 kB/3681 kB 1%]
98% [9 Packages store 0 B]
98% [Working]
98% [10 Packages store 0 B]
99% [Working]
99% [11 Packages store 0 B]
99% [Working]
99% [12 Packages store 0 B]
100% [Working]
Fetched 21.7 MB in 2s (12.8 MB/s)
Reading package lists... 0%
Reading package lists... 0%
Reading package lists... 0%
Reading package lists... 3%
Reading package lists... 3%
Reading package lists... 4%
Reading package lists... 4%
Reading package lists... 41%
Reading package lists... 41%
Reading package lists... 42%
Reading package lists... 42%
Reading package lists... 51%
Reading package lists... 51%
Reading package lists... 67%
Reading package lists... 67%
Reading package lists... 71%
Reading package lists... 71%
Reading package lists... 71%
Reading package lists... 71%
Reading package lists... 72%
Reading package lists... 72%
Reading package lists... 72%
Reading package lists... 72%
Reading package lists... 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
↓ 15 lines
0% [Working] Get:1 http://security.ubuntu.com/ubuntu jammy-security InRelease [129 kB] 0% [Connecting to archive.ubuntu.com (185.125.190.36)] [1 InRelease 14.2 kB/129 0% [Waiting for headers] 0% [Waiting for headers] Hit:2 http://archive.ubuntu.com/ubuntu jammy InRelease 0% [Waiting for headers] Get:3 http://security.ubuntu.com/ubuntu jammy-security/multiverse amd64 Packages [71.0 kB] 0% [Waiting for headers] [3 Packages 5554 B/71.0 kB 8%] 0% [Waiting for headers] 0% [3 Packages store 0 B] [Waiting for headers] [Waiting for headers] 0% [Waiting for headers] [Waiting for headers] 0% [Waiting for headers] [Waiting for headers] Get:4 http://security.ubuntu.com/ubuntu jammy-security/main amd64 Packages [3336 kB] 0% [Waiting for headers] [4 Packages 5551 B/3336 kB 0%] Get:5 http://archive.ubuntu.com/ubuntu jammy-updates InRelease [128 kB] 0% [5 InRelease 12.7 kB/128 kB 10%] [4 Packages 230 kB/3336 kB 7%] 0% [5 InRelease 18.5 kB/128 kB 14%] [Waiting for headers] Get:6 http://security.ubuntu.com/ubuntu jammy-security/restricted amd64 Packages [5526 kB] 0% [5 InRelease 18.5 kB/128 kB 14%] [6 Packages 49.2 kB/5526 kB 1%] 0% [4 Packages store 0 B] [5 InRelease 18.5 kB/128 kB 14%] [6 Packages 67.8 kB/ 0% [4 Packages store 0 B] [5 InRelease 38.8 kB/128 kB 30%] [Waiting for headers Get:7 http://security.ubuntu.com/ubuntu jammy-security/universe amd64 Packages [1274 kB] 0% [4 Packages store 0 B] [5 InRelease 38.8 kB/128 kB 30%] [7 Packages 46.9 kB/ 0% [4 Packages store 0 B] [5 InRelease 47.5 kB/128 kB 37%] 0% [5 InRelease 56.2 kB/128 kB 44%] 0% [6 Packages store 0 B] [5 InRelease 56.2 kB/128 kB 44%] 0% [6 Packages store 0 B] [Waiting for headers] 0% [6 Packages store 0 B] [Waiting for headers] 0% [Waiting for headers] 0% [7 Packages store 0 B] [Waiting for headers] Get:8 http://archive.ubuntu.com/ubuntu jammy-backports InRelease [127 kB] 0% [7 Packages store 0 B] [8 InRelease 2588 B/127 kB 2%] 0% [8 InRelease 5484 B/127 kB 4%] 0% [Working] 57% [Waiting for headers] Get:9 http://archive.ubuntu.com/ubuntu jammy-updates/restricted amd64 Packages [5779 kB] 57% [9 Packages 2655 B/5779 kB 0%] 74% [9 Packages 4658 kB/5779 kB 81%] 78% [Waiting for headers] Get:10 http://archive.ubuntu.com/ubuntu jammy-updates/universe amd64 Packages [1577 kB] 78% [10 Packages 16.4 kB/1577 kB 1%] 79% [9 Packages store 0 B] [10 Packages 125 kB/1577 kB 8%] 84% [9 Packages store 0 B] [Waiting for headers] Get:11 http://archive.ubuntu.com/ubuntu jammy-updates/multiverse amd64 Packages [69.1 kB] 84% [9 Packages store 0 B] [11 Packages 38.0 kB/69.1 kB 55%] 84% [9 Packages store 0 B] [Waiting for headers] Get:12 http://archive.ubuntu.com/ubuntu jammy-updates/main amd64 Packages [3681 kB] 84% [9 Packages store 0 B] [12 Packages 32.2 kB/3681 kB 1%] 98% [9 Packages store 0 B] 98% [Working] 98% [10 Packages store 0 B] 99% [Working] 99% [11 Packages store 0 B] 99% [Working] 99% [12 Packages store 0 B] 100% [Working] Fetched 21.7 MB in 2s (12.8 MB/s) Reading package lists... 0% Reading package lists... 0% Reading package lists... 0% Reading package lists... 3% Reading package lists... 3% Reading package lists... 4% Reading package lists... 4% Reading package lists... 41% Reading package lists... 41% Reading package lists... 42% Reading package lists... 42% Reading package lists... 51% Reading package lists... 51% Reading package lists... 67% Reading package lists... 67% Reading package lists... 71% Reading package lists... 71% Reading package lists... 71% Reading package lists... 71% Reading package lists... 72% Reading package lists... 72% Reading package lists... 72% Reading package lists... 72% Reading package lists... 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
Show reasoning
Installing cross-compilation packages
compile-bench> sudo DEBIAN_FRONTEND=noninteractive apt-get install -y --no-install-recommends build-essential autoconf automake libtool pkg-config mingw-w64 gcc-mingw-w64 g++-mingw-w64
Reading package lists... 0%
Reading package lists... 0%
Reading package lists... 0%
Reading package lists... 3%
Reading package lists... 3%
Reading package lists... 4%
Reading package lists... 4%
Reading package lists... 41%
Reading package lists... 41%
Reading package lists... 42%
Reading package lists... 42%
Reading package lists... 51%
Reading package lists... 51%
Reading package lists... 67%
Reading package lists... 67%
Reading package lists... 71%
Reading package lists... 71%
Reading package lists... 71%
Reading package lists... 71%
Reading package lists... 72%
Reading package lists... 72%
Reading package lists... 72%
Reading package lists... 72%
Reading package lists... 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... 96%
Building dependency tree... Done
Reading state information... 0%
Reading state information... 0%
Reading state information... Done
build-essential is already the newest version (12.9ubuntu3).
The following additional packages will be installed:
autotools-dev binutils-mingw-w64-i686 binutils-mingw-w64-x86-64
g++-mingw-w64-i686 g++-mingw-w64-i686-posix g++-mingw-w64-i686-win32
g++-mingw-w64-x86-64 g++-mingw-w64-x86-64-posix g++-mingw-w64-x86-64-win32
gcc-mingw-w64-base gcc-mingw-w64-i686 gcc-mingw-w64-i686-posix
gcc-mingw-w64-i686-posix-runtime gcc-mingw-w64-i686-win32
gcc-mingw-w64-i686-win32-runtime gcc-mingw-w64-x86-64
gcc-mingw-w64-x86-64-posix gcc-mingw-w64-x86-64-posix-runtime
gcc-mingw-w64-x86-64-win32 gcc-mingw-w64-x86-64-win32-runtime libsigsegv2 m4
mingw-w64-common mingw-w64-i686-dev mingw-w64-x86-64-dev
Suggested packages:
autoconf-archive gnu-standards autoconf-doc gettext gcc-10-locales
libtool-doc gfortran | fortran95-compiler gcj-jdk m4-doc
Recommended packages:
libltdl-dev
The following NEW packages will be installed:
autoconf automake autotools-dev binutils-mingw-w64-i686
binutils-mingw-w64-x86-64 g++-mingw-w64 g++-mingw-w64-i686
g++-mingw-w64-i686-posix g++-mingw-w64-i686-win32 g++-mingw-w64-x86-64
g++-mingw-w64-x86-64-posix g++-mingw-w64-x86-64-win32 gcc-mingw-w64
gcc-mingw-w64-base gcc-mingw-w64-i686 gcc-mingw-w64-i686-posix
gcc-mingw-w64-i686-posix-runtime gcc-mingw-w64-i686-win32
gcc-mingw-w64-i686-win32-runtime gcc-mingw-w64-x86-64
gcc-mingw-w64-x86-64-posix gcc-mingw-w64-x86-64-posix-runtime
gcc-mingw-w64-x86-64-win32 gcc-mingw-w64-x86-64-win32-runtime libsigsegv2
libtool m4 mingw-w64 mingw-w64-common mingw-w64-i686-dev
mingw-w64-x86-64-dev pkg-config
0 upgraded, 32 newly installed, 0 to remove and 8 not upgraded.
Need to get 230 MB of archives.
[command output truncated]
ntu1+24.3) ...
update-alternatives: using /usr/bin/x86_64-w64-mingw32-gcc-posix to provide /usr/bin/x86_64-w64-mingw32-gcc (x86_64-w64-mingw32-gcc) in auto mode
Setting up gcc-mingw-w64-x86-64-win32 (10.3.0-14ubuntu1+24.3) ...
update-alternatives: using /usr/bin/x86_64-w64-mingw32-gcc-win32 to provide /usr/bin/x86_64-w64-mingw32-gcc (x86_64-w64-mingw32-gcc) in auto mode
Setting up gcc-mingw-w64-x86-64 (10.3.0-14ubuntu1+24.3) ...
update-alternatives: warning: forcing reinstallation of alternative /usr/bin/x86_64-w64-mingw32-gcc-win32 because link group x86_64-w64-mingw32-gcc is broken
update-alternatives: warning: skip creation of /usr/bin/x86_64-w64-mingw32-gcc-8 because associated file /usr/bin/x86_64-w64-mingw32-gcc-8.3-win32 (of link group x86_64-w64-mingw32-gcc) doesn't exist
Setting up autoconf (2.71-2) ...
Setting up mingw-w64-i686-dev (8.0.0-1) ...
Setting up automake (1:1.16.5-1.3) ...
update-alternatives: using /usr/bin/automake-1.16 to provide /usr/bin/automake (automake) in auto mode
update-alternatives: warning: skip creation of /usr/share/man/man1/automake.1.gz because associated file /usr/share/man/man1/automake-1.16.1.gz (of link group automake) doesn't exist
update-alternatives: warning: skip creation of /usr/share/man/man1/aclocal.1.gz because associated file /usr/share/man/man1/aclocal-1.16.1.gz (of link group automake) doesn't exist
Setting up gcc-mingw-w64-i686-win32 (10.3.0-14ubuntu1+24.3) ...
update-alternatives: using /usr/bin/i686-w64-mingw32-gcc-win32 to provide /usr/bin/i686-w64-mingw32-gcc (i686-w64-mingw32-gcc) in auto mode
Setting up g++-mingw-w64-i686-win32 (10.3.0-14ubuntu1+24.3) ...
update-alternatives: using /usr/bin/i686-w64-mingw32-g++-win32 to provide /usr/bin/i686-w64-mingw32-g++ (i686-w64-mingw32-g++) in auto mode
Setting up g++-mingw-w64-x86-64-win32 (10.3.0-14ubuntu1+24.3) ...
update-alternatives: using /usr/bin/x86_64-w64-mingw32-g++-win32 to provide /usr/bin/x86_64-w64-mingw32-g++ (x86_64-w64-mingw32-g++) in auto mode
Setting up gcc-mingw-w64-i686-posix (10.3.0-14ubuntu1+24.3) ...
Setting up g++-mingw-w64-x86-64-posix (10.3.0-14ubuntu1+24.3) ...
Setting up gcc-mingw-w64-i686 (10.3.0-14ubuntu1+24.3) ...
update-alternatives: warning: forcing reinstallation of alternative /usr/bin/i686-w64-mingw32-gcc-win32 because link group i686-w64-mingw32-gcc is broken
update-alternatives: warning: skip creation of /usr/bin/i686-w64-mingw32-gcc-8 because associated file /usr/bin/i686-w64-mingw32-gcc-8.3-win32 (of link group i686-w64-mingw32-gcc) doesn't exist
Setting up g++-mingw-w64-x86-64 (10.3.0-14ubuntu1+24.3) ...
Setting up gcc-mingw-w64 (10.3.0-14ubuntu1+24.3) ...
Setting up g++-mingw-w64-i686-posix (10.3.0-14ubuntu1+24.3) ...
Setting up g++-mingw-w64-i686 (10.3.0-14ubuntu1+24.3) ...
Setting up g++-mingw-w64 (10.3.0-14ubuntu1+24.3) ...
Setting up mingw-w64 (8.0.0-1) ...
Processing triggers for libwine:amd64 (6.0.3~repack-1) ...
Processing triggers for libc-bin (2.35-0ubuntu3.10) ...
↓ 67 lines
Reading package lists... 0% Reading package lists... 0% Reading package lists... 0% Reading package lists... 3% Reading package lists... 3% Reading package lists... 4% Reading package lists... 4% Reading package lists... 41% Reading package lists... 41% Reading package lists... 42% Reading package lists... 42% Reading package lists... 51% Reading package lists... 51% Reading package lists... 67% Reading package lists... 67% Reading package lists... 71% Reading package lists... 71% Reading package lists... 71% Reading package lists... 71% Reading package lists... 72% Reading package lists... 72% Reading package lists... 72% Reading package lists... 72% Reading package lists... 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... 96% Building dependency tree... Done Reading state information... 0% Reading state information... 0% Reading state information... Done build-essential is already the newest version (12.9ubuntu3). The following additional packages will be installed: autotools-dev binutils-mingw-w64-i686 binutils-mingw-w64-x86-64 g++-mingw-w64-i686 g++-mingw-w64-i686-posix g++-mingw-w64-i686-win32 g++-mingw-w64-x86-64 g++-mingw-w64-x86-64-posix g++-mingw-w64-x86-64-win32 gcc-mingw-w64-base gcc-mingw-w64-i686 gcc-mingw-w64-i686-posix gcc-mingw-w64-i686-posix-runtime gcc-mingw-w64-i686-win32 gcc-mingw-w64-i686-win32-runtime gcc-mingw-w64-x86-64 gcc-mingw-w64-x86-64-posix gcc-mingw-w64-x86-64-posix-runtime gcc-mingw-w64-x86-64-win32 gcc-mingw-w64-x86-64-win32-runtime libsigsegv2 m4 mingw-w64-common mingw-w64-i686-dev mingw-w64-x86-64-dev Suggested packages: autoconf-archive gnu-standards autoconf-doc gettext gcc-10-locales libtool-doc gfortran | fortran95-compiler gcj-jdk m4-doc Recommended packages: libltdl-dev The following NEW packages will be installed: autoconf automake autotools-dev binutils-mingw-w64-i686 binutils-mingw-w64-x86-64 g++-mingw-w64 g++-mingw-w64-i686 g++-mingw-w64-i686-posix g++-mingw-w64-i686-win32 g++-mingw-w64-x86-64 g++-mingw-w64-x86-64-posix g++-mingw-w64-x86-64-win32 gcc-mingw-w64 gcc-mingw-w64-base gcc-mingw-w64-i686 gcc-mingw-w64-i686-posix gcc-mingw-w64-i686-posix-runtime gcc-mingw-w64-i686-win32 gcc-mingw-w64-i686-win32-runtime gcc-mingw-w64-x86-64 gcc-mingw-w64-x86-64-posix gcc-mingw-w64-x86-64-posix-runtime gcc-mingw-w64-x86-64-win32 gcc-mingw-w64-x86-64-win32-runtime libsigsegv2 libtool m4 mingw-w64 mingw-w64-common mingw-w64-i686-dev mingw-w64-x86-64-dev pkg-config 0 upgraded, 32 newly installed, 0 to remove and 8 not upgraded. Need to get 230 MB of archives. [command output truncated] ntu1+24.3) ... update-alternatives: using /usr/bin/x86_64-w64-mingw32-gcc-posix to provide /usr/bin/x86_64-w64-mingw32-gcc (x86_64-w64-mingw32-gcc) in auto mode Setting up gcc-mingw-w64-x86-64-win32 (10.3.0-14ubuntu1+24.3) ... update-alternatives: using /usr/bin/x86_64-w64-mingw32-gcc-win32 to provide /usr/bin/x86_64-w64-mingw32-gcc (x86_64-w64-mingw32-gcc) in auto mode Setting up gcc-mingw-w64-x86-64 (10.3.0-14ubuntu1+24.3) ... update-alternatives: warning: forcing reinstallation of alternative /usr/bin/x86_64-w64-mingw32-gcc-win32 because link group x86_64-w64-mingw32-gcc is broken update-alternatives: warning: skip creation of /usr/bin/x86_64-w64-mingw32-gcc-8 because associated file /usr/bin/x86_64-w64-mingw32-gcc-8.3-win32 (of link group x86_64-w64-mingw32-gcc) doesn't exist Setting up autoconf (2.71-2) ... Setting up mingw-w64-i686-dev (8.0.0-1) ... Setting up automake (1:1.16.5-1.3) ... update-alternatives: using /usr/bin/automake-1.16 to provide /usr/bin/automake (automake) in auto mode update-alternatives: warning: skip creation of /usr/share/man/man1/automake.1.gz because associated file /usr/share/man/man1/automake-1.16.1.gz (of link group automake) doesn't exist update-alternatives: warning: skip creation of /usr/share/man/man1/aclocal.1.gz because associated file /usr/share/man/man1/aclocal-1.16.1.gz (of link group automake) doesn't exist Setting up gcc-mingw-w64-i686-win32 (10.3.0-14ubuntu1+24.3) ... update-alternatives: using /usr/bin/i686-w64-mingw32-gcc-win32 to provide /usr/bin/i686-w64-mingw32-gcc (i686-w64-mingw32-gcc) in auto mode Setting up g++-mingw-w64-i686-win32 (10.3.0-14ubuntu1+24.3) ... update-alternatives: using /usr/bin/i686-w64-mingw32-g++-win32 to provide /usr/bin/i686-w64-mingw32-g++ (i686-w64-mingw32-g++) in auto mode Setting up g++-mingw-w64-x86-64-win32 (10.3.0-14ubuntu1+24.3) ... update-alternatives: using /usr/bin/x86_64-w64-mingw32-g++-win32 to provide /usr/bin/x86_64-w64-mingw32-g++ (x86_64-w64-mingw32-g++) in auto mode Setting up gcc-mingw-w64-i686-posix (10.3.0-14ubuntu1+24.3) ... Setting up g++-mingw-w64-x86-64-posix (10.3.0-14ubuntu1+24.3) ... Setting up gcc-mingw-w64-i686 (10.3.0-14ubuntu1+24.3) ... update-alternatives: warning: forcing reinstallation of alternative /usr/bin/i686-w64-mingw32-gcc-win32 because link group i686-w64-mingw32-gcc is broken update-alternatives: warning: skip creation of /usr/bin/i686-w64-mingw32-gcc-8 because associated file /usr/bin/i686-w64-mingw32-gcc-8.3-win32 (of link group i686-w64-mingw32-gcc) doesn't exist Setting up g++-mingw-w64-x86-64 (10.3.0-14ubuntu1+24.3) ... Setting up gcc-mingw-w64 (10.3.0-14ubuntu1+24.3) ... Setting up g++-mingw-w64-i686-posix (10.3.0-14ubuntu1+24.3) ... Setting up g++-mingw-w64-i686 (10.3.0-14ubuntu1+24.3) ... Setting up g++-mingw-w64 (10.3.0-14ubuntu1+24.3) ... Setting up mingw-w64 (8.0.0-1) ... Processing triggers for libwine:amd64 (6.0.3~repack-1) ... Processing triggers for libc-bin (2.35-0ubuntu3.10) ...
Show reasoning
Preparing cross-compilation configuration
I’m working out the right environment variables and options to run the configure script for a static cross-compile build of jq targeting Windows from Linux. I’ll run the configure inside the jq directory with variables like CC, CXX, and LDFLAGS set, and I’m considering running autoreconf beforehand if needed to ensure the configure script is ready.
compile-bench> cd jq-1.8.1 && CC=x86_64-w64-mingw32-gcc CXX=x86_64-w64-mingw32-g++ AR=x86_64-w64-mingw32-ar RANLIB=x86_64-w64-mingw32-ranlib STRIP=x86_64-w64-mingw32-strip LDFLAGS=-static ./configure --host=x86_64-w64-mingw32 --build=x86_64-pc-linux-gnu --disable-shared --enable-static --with-oniguruma=builtin checking for x86_64-w64-mingw32-gcc... x86_64-w64-mingw32-gcc
checking whether the C compiler works... yes
checking for C compiler default output file name... a.exe
checking for suffix of executables... .exe
checking whether we are cross compiling... yes
checking for suffix of object files... o
checking whether the compiler supports GNU C... yes
checking whether x86_64-w64-mingw32-gcc accepts -g... yes
checking for x86_64-w64-mingw32-gcc option to enable C11 features... none needed
checking whether x86_64-w64-mingw32-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 x86_64-w64-mingw32-strip... x86_64-w64-mingw32-strip
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 x86_64-w64-mingw32-gcc... gcc3
checking whether make supports nested variables... (cached) yes
checking for x86_64-w64-mingw32-ar... x86_64-w64-mingw32-ar
checking the archiver (x86_64-w64-mingw32-ar) interface... ar
checking whether to enable maintainer-specific portions of Makefiles... no
checking for x86_64-w64-mingw32-gcc... (cached) x86_64-w64-mingw32-gcc
checking whether the compiler supports GNU C... (cached) yes
checking whether x86_64-w64-mingw32-gcc accepts -g... (cached) yes
checking for x86_64-w64-mingw32-gcc option to enable C11 features... (cached) none needed
checking whether x86_64-w64-mingw32-gcc understands -c and -o together... (cached) yes
checking how to run the C preprocessor... x86_64-w64-mingw32-gcc -E
checking for bison... no
checking for byacc... no
checking build system type... x86_64-pc-linux-gnu
checking host system type... x86_64-w64-mingw32
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 x86_64-w64-mingw32-gcc... /usr/bin/x86_64-w64-mingw32-ld
checking if the linker (/usr/bin/x86_64-w64-mingw32-ld) is GNU ld... yes
checking for BSD- or MS-compatible name lister (nm)... /usr/bin/x86_64-w64-mingw32-nm -B
checking the name lister (/usr/bin/x86_64-w64-mingw32-nm -B) interface... BSD n
[command output truncated]
efixed with host triplet
checking for x86_64-w64-mingw32-objdump... x86_64-w64-mingw32-objdump
checking how to recognize dependent libraries... file_magic ^x86 archive import|^x86 DLL
checking for x86_64-w64-mingw32-dlltool... x86_64-w64-mingw32-dlltool
checking how to associate runtime and link libraries... func_cygming_dll_for_implib
checking for x86_64-w64-mingw32-ar... x86_64-w64-mingw32-ar
checking for archiver @FILE support... @
checking for x86_64-w64-mingw32-strip... (cached) x86_64-w64-mingw32-strip
checking for x86_64-w64-mingw32-ranlib... x86_64-w64-mingw32-ranlib
checking command to parse /usr/bin/x86_64-w64-mingw32-nm -B output from x86_64-w64-mingw32-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 x86_64-w64-mingw32-mt... no
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... no
checking for objdir... .libs
checking if x86_64-w64-mingw32-gcc supports -fno-rtti -fno-exceptions... no
checking for x86_64-w64-mingw32-gcc option to produce PIC... -DDLL_EXPORT -DPIC
checking if x86_64-w64-mingw32-gcc PIC flag -DDLL_EXPORT -DPIC works... yes
checking if x86_64-w64-mingw32-gcc static flag -static works... yes
checking if x86_64-w64-mingw32-gcc supports -c -o file.o... yes
checking if x86_64-w64-mingw32-gcc supports -c -o file.o... (cached) yes
checking whether the x86_64-w64-mingw32-gcc linker (/usr/bin/x86_64-w64-mingw32-ld) supports shared libraries... yes
checking dynamic linker characteristics... Win32 ld.exe
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... no
checking size of int... 4
checking size of long... 4
checking size of long long... 8
checking size of void*... 8
checking for size_t... yes
checking for working alloca.h... no
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
↓ 120 lines
checking for x86_64-w64-mingw32-gcc... x86_64-w64-mingw32-gcc checking whether the C compiler works... yes checking for C compiler default output file name... a.exe checking for suffix of executables... .exe checking whether we are cross compiling... yes checking for suffix of object files... o checking whether the compiler supports GNU C... yes checking whether x86_64-w64-mingw32-gcc accepts -g... yes checking for x86_64-w64-mingw32-gcc option to enable C11 features... none needed checking whether x86_64-w64-mingw32-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 x86_64-w64-mingw32-strip... x86_64-w64-mingw32-strip 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 x86_64-w64-mingw32-gcc... gcc3 checking whether make supports nested variables... (cached) yes checking for x86_64-w64-mingw32-ar... x86_64-w64-mingw32-ar checking the archiver (x86_64-w64-mingw32-ar) interface... ar checking whether to enable maintainer-specific portions of Makefiles... no checking for x86_64-w64-mingw32-gcc... (cached) x86_64-w64-mingw32-gcc checking whether the compiler supports GNU C... (cached) yes checking whether x86_64-w64-mingw32-gcc accepts -g... (cached) yes checking for x86_64-w64-mingw32-gcc option to enable C11 features... (cached) none needed checking whether x86_64-w64-mingw32-gcc understands -c and -o together... (cached) yes checking how to run the C preprocessor... x86_64-w64-mingw32-gcc -E checking for bison... no checking for byacc... no checking build system type... x86_64-pc-linux-gnu checking host system type... x86_64-w64-mingw32 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 x86_64-w64-mingw32-gcc... /usr/bin/x86_64-w64-mingw32-ld checking if the linker (/usr/bin/x86_64-w64-mingw32-ld) is GNU ld... yes checking for BSD- or MS-compatible name lister (nm)... /usr/bin/x86_64-w64-mingw32-nm -B checking the name lister (/usr/bin/x86_64-w64-mingw32-nm -B) interface... BSD n [command output truncated] efixed with host triplet checking for x86_64-w64-mingw32-objdump... x86_64-w64-mingw32-objdump checking how to recognize dependent libraries... file_magic ^x86 archive import|^x86 DLL checking for x86_64-w64-mingw32-dlltool... x86_64-w64-mingw32-dlltool checking how to associate runtime and link libraries... func_cygming_dll_for_implib checking for x86_64-w64-mingw32-ar... x86_64-w64-mingw32-ar checking for archiver @FILE support... @ checking for x86_64-w64-mingw32-strip... (cached) x86_64-w64-mingw32-strip checking for x86_64-w64-mingw32-ranlib... x86_64-w64-mingw32-ranlib checking command to parse /usr/bin/x86_64-w64-mingw32-nm -B output from x86_64-w64-mingw32-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 x86_64-w64-mingw32-mt... no 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... no checking for objdir... .libs checking if x86_64-w64-mingw32-gcc supports -fno-rtti -fno-exceptions... no checking for x86_64-w64-mingw32-gcc option to produce PIC... -DDLL_EXPORT -DPIC checking if x86_64-w64-mingw32-gcc PIC flag -DDLL_EXPORT -DPIC works... yes checking if x86_64-w64-mingw32-gcc static flag -static works... yes checking if x86_64-w64-mingw32-gcc supports -c -o file.o... yes checking if x86_64-w64-mingw32-gcc supports -c -o file.o... (cached) yes checking whether the x86_64-w64-mingw32-gcc linker (/usr/bin/x86_64-w64-mingw32-ld) supports shared libraries... yes checking dynamic linker characteristics... Win32 ld.exe 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... no checking size of int... 4 checking size of long... 4 checking size of long long... 8 checking size of void*... 8 checking for size_t... yes checking for working alloca.h... no checking for alloca... yes checking that generated files are newer than configure... done configure: creating ./config.status config.status: creating Makefile config.status: creating src/Makefile config.status: creating test/Makefile config.status: creating sample/Makefile config.status: creating onig-config config.status: creating src/config.h config.status: executing depfiles commands config.status: executing libtool commands config.status: executing default commands
Show reasoning
Running parallel make command
compile-bench> cd jq-1.8.1 && make -j$(nproc) mkdir -p src
mkdir -p src
GEN src/builtin.inc
GEN src/config_opts.inc
mkdir -p src
GEN src/version.h
make all-recursive
make[1]: Entering directory '/home/peter/jq-1.8.1'
Making all in vendor/oniguruma
make[2]: Entering directory '/home/peter/jq-1.8.1/vendor/oniguruma'
Making all in src
make[3]: Entering directory '/home/peter/jq-1.8.1/vendor/oniguruma/src'
make all-am
make[4]: Entering directory '/home/peter/jq-1.8.1/vendor/oniguruma/src'
/bin/bash ../libtool --tag=CC --mode=compile x86_64-w64-mingw32-gcc -DHAVE_CONFIG_H -I. -I.. -Wall -g -O2 -MT regparse.lo -MD -MP -MF .deps/regparse.Tpo -c -o regparse.lo regparse.c
/bin/bash ../libtool --tag=CC --mode=compile x86_64-w64-mingw32-gcc -DHAVE_CONFIG_H -I. -I.. -Wall -g -O2 -MT regcomp.lo -MD -MP -MF .deps/regcomp.Tpo -c -o regcomp.lo regcomp.c
/bin/bash ../libtool --tag=CC --mode=compile x86_64-w64-mingw32-gcc -DHAVE_CONFIG_H -I. -I.. -Wall -g -O2 -MT regexec.lo -MD -MP -MF .deps/regexec.Tpo -c -o regexec.lo regexec.c
/bin/bash ../libtool --tag=CC --mode=compile x86_64-w64-mingw32-gcc -DHAVE_CONFIG_H -I. -I.. -Wall -g -O2 -MT regenc.lo -MD -MP -MF .deps/regenc.Tpo -c -o regenc.lo regenc.c
/bin/bash ../libtool --tag=CC --mode=compile x86_64-w64-mingw32-gcc -DHAVE_CONFIG_H -I. -I.. -Wall -g -O2 -MT regerror.lo -MD -MP -MF .deps/regerror.Tpo -c -o regerror.lo regerror.c
/bin/bash ../libtool --tag=CC --mode=compile x86_64-w64-mingw32-gcc -DHAVE_CONFIG_H -I. -I.. -Wall -g -O2 -MT regext.lo -MD -MP -MF .deps/regext.Tpo -c -o regext.lo regext.c
/bin/bash ../libtool --tag=CC --mode=compile x86_64-w64-mingw32-gcc -DHAVE_CONFIG_H -I. -I.. -Wall -g -O2 -MT regsyntax.lo -MD -MP -MF .deps/regsyntax.Tpo -c -o regsyntax.lo regsyntax.c
/bin/bash ../libtool --tag=CC --mode=compile x86_64-w64-mingw32-gcc -DHAVE_CONFIG_H -I. -I.. -Wall -g -O2 -MT regtrav.lo -MD -MP -MF .deps/regtrav.Tpo -c -o regtrav.lo regtrav.c
libtool: compile: x86_64-w64-mingw32-gcc -DHAVE_CONFIG_H -I. -I.. -Wall -g -O2 -MT regcomp.lo -MD -MP -MF .deps/regcomp.Tpo -c regcomp.c -o regcomp.o
libtool: compile: x86_64-w64-mingw32-gcc -DHAVE_CONFIG_H -I. -I.. -Wall -g -O2 -MT regerror.lo -MD -MP -MF .deps/regerror.Tpo -c regerror.c -o regerror.o
libtool: compile: x86_64-w64-mingw32-gcc -DHAVE_CONFIG_H -I. -I.. -Wall -g -O2 -MT regexec.lo -MD -MP -MF .deps/regexec.Tpo -c regexec.c -o regexec.o
libtool: compile: x86_64-w64-mingw32-gcc -DHAVE_CONFIG_H -I. -I.. -Wall -g -O2 -MT regparse.lo -MD -MP -MF .deps/regparse.Tpo -c regparse.c -o regparse.o
libtool: compile: x86_64-w64-mingw32-gcc -DHAVE_CONFIG_H -I. -I.. -Wall -g -O2 -MT regext.lo -MD -MP -MF .deps/regext.Tpo -c regext.c -o regext.o
libtool: compile: x86_64-w64-mingw32-gcc -DHAVE_CONFIG_H -I. -I.. -Wall -g -O2 -MT regenc.lo -MD -MP -MF .deps/regenc.Tpo -c regenc.c -o regenc.o
libtool: compile: x86_64-w64-mingw32-gcc -DHAVE_CONFIG_H -I. -I.. -Wall -g -O2 -MT regtrav.lo -MD -MP -MF .dep
[command output truncated]
llowed in x86_64-w64-mingw32 shared libraries; building static only
libtool: link: x86_64-w64-mingw32-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: x86_64-w64-mingw32-ranlib .libs/libonig.a
libtool: link: ( cd ".libs" && rm -f "libonig.la" && ln -s "../libonig.la" "libonig.la" )
make[4]: Leaving directory '/home/peter/jq-1.8.1/vendor/oniguruma/src'
make[3]: Leaving directory '/home/peter/jq-1.8.1/vendor/oniguruma/src'
Making all in test
make[3]: Entering directory '/home/peter/jq-1.8.1/vendor/oniguruma/test'
make[3]: Nothing to be done for 'all'.
make[3]: Leaving directory '/home/peter/jq-1.8.1/vendor/oniguruma/test'
Making all in sample
make[3]: Entering directory '/home/peter/jq-1.8.1/vendor/oniguruma/sample'
make[3]: Nothing to be done for 'all'.
make[3]: Leaving directory '/home/peter/jq-1.8.1/vendor/oniguruma/sample'
make[3]: Entering directory '/home/peter/jq-1.8.1/vendor/oniguruma'
sed -e 's,[@]datadir[@],/usr/local/share,g' -e 's,[@]datarootdir[@],/usr/local/share,g' -e 's,[@]PACKAGE_VERSION[@],6.9.10,g' -e 's,[@]prefix[@],/usr/local,g' -e 's,[@]exec_prefix[@],/usr/local,g' -e 's,[@]libdir[@],/usr/local/lib,g' -e 's,[@]includedir[@],/usr/local/include,g' < ./oniguruma.pc.in > oniguruma.pc
make[3]: Leaving directory '/home/peter/jq-1.8.1/vendor/oniguruma'
make[2]: Leaving directory '/home/peter/jq-1.8.1/vendor/oniguruma'
make[2]: Entering directory '/home/peter/jq-1.8.1'
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
mkdir -p src
GEN src/version.h
CC src/main.o
src/main.c:21:1: warning: function declaration isn't a prototype [ttps://gcc.gnu.org/onlinedocs/gcc/Warning-Options.html#index-Wstrict-prototypes-Wstrict-prototypes]8;;]
21 | extern void jv_tsd_dtoa_ctx_init();
| ^~~~~~
CCLD libjq.la
CCLD jq.exe
make[2]: Leaving directory '/home/peter/jq-1.8.1'
make[1]: Leaving directory '/home/peter/jq-1.8.1'
↓ 81 lines
mkdir -p src
mkdir -p src
GEN src/builtin.inc
GEN src/config_opts.inc
mkdir -p src
GEN src/version.h
make all-recursive
make[1]: Entering directory '/home/peter/jq-1.8.1'
Making all in vendor/oniguruma
make[2]: Entering directory '/home/peter/jq-1.8.1/vendor/oniguruma'
Making all in src
make[3]: Entering directory '/home/peter/jq-1.8.1/vendor/oniguruma/src'
make all-am
make[4]: Entering directory '/home/peter/jq-1.8.1/vendor/oniguruma/src'
/bin/bash ../libtool --tag=CC --mode=compile x86_64-w64-mingw32-gcc -DHAVE_CONFIG_H -I. -I.. -Wall -g -O2 -MT regparse.lo -MD -MP -MF .deps/regparse.Tpo -c -o regparse.lo regparse.c
/bin/bash ../libtool --tag=CC --mode=compile x86_64-w64-mingw32-gcc -DHAVE_CONFIG_H -I. -I.. -Wall -g -O2 -MT regcomp.lo -MD -MP -MF .deps/regcomp.Tpo -c -o regcomp.lo regcomp.c
/bin/bash ../libtool --tag=CC --mode=compile x86_64-w64-mingw32-gcc -DHAVE_CONFIG_H -I. -I.. -Wall -g -O2 -MT regexec.lo -MD -MP -MF .deps/regexec.Tpo -c -o regexec.lo regexec.c
/bin/bash ../libtool --tag=CC --mode=compile x86_64-w64-mingw32-gcc -DHAVE_CONFIG_H -I. -I.. -Wall -g -O2 -MT regenc.lo -MD -MP -MF .deps/regenc.Tpo -c -o regenc.lo regenc.c
/bin/bash ../libtool --tag=CC --mode=compile x86_64-w64-mingw32-gcc -DHAVE_CONFIG_H -I. -I.. -Wall -g -O2 -MT regerror.lo -MD -MP -MF .deps/regerror.Tpo -c -o regerror.lo regerror.c
/bin/bash ../libtool --tag=CC --mode=compile x86_64-w64-mingw32-gcc -DHAVE_CONFIG_H -I. -I.. -Wall -g -O2 -MT regext.lo -MD -MP -MF .deps/regext.Tpo -c -o regext.lo regext.c
/bin/bash ../libtool --tag=CC --mode=compile x86_64-w64-mingw32-gcc -DHAVE_CONFIG_H -I. -I.. -Wall -g -O2 -MT regsyntax.lo -MD -MP -MF .deps/regsyntax.Tpo -c -o regsyntax.lo regsyntax.c
/bin/bash ../libtool --tag=CC --mode=compile x86_64-w64-mingw32-gcc -DHAVE_CONFIG_H -I. -I.. -Wall -g -O2 -MT regtrav.lo -MD -MP -MF .deps/regtrav.Tpo -c -o regtrav.lo regtrav.c
libtool: compile: x86_64-w64-mingw32-gcc -DHAVE_CONFIG_H -I. -I.. -Wall -g -O2 -MT regcomp.lo -MD -MP -MF .deps/regcomp.Tpo -c regcomp.c -o regcomp.o
libtool: compile: x86_64-w64-mingw32-gcc -DHAVE_CONFIG_H -I. -I.. -Wall -g -O2 -MT regerror.lo -MD -MP -MF .deps/regerror.Tpo -c regerror.c -o regerror.o
libtool: compile: x86_64-w64-mingw32-gcc -DHAVE_CONFIG_H -I. -I.. -Wall -g -O2 -MT regexec.lo -MD -MP -MF .deps/regexec.Tpo -c regexec.c -o regexec.o
libtool: compile: x86_64-w64-mingw32-gcc -DHAVE_CONFIG_H -I. -I.. -Wall -g -O2 -MT regparse.lo -MD -MP -MF .deps/regparse.Tpo -c regparse.c -o regparse.o
libtool: compile: x86_64-w64-mingw32-gcc -DHAVE_CONFIG_H -I. -I.. -Wall -g -O2 -MT regext.lo -MD -MP -MF .deps/regext.Tpo -c regext.c -o regext.o
libtool: compile: x86_64-w64-mingw32-gcc -DHAVE_CONFIG_H -I. -I.. -Wall -g -O2 -MT regenc.lo -MD -MP -MF .deps/regenc.Tpo -c regenc.c -o regenc.o
libtool: compile: x86_64-w64-mingw32-gcc -DHAVE_CONFIG_H -I. -I.. -Wall -g -O2 -MT regtrav.lo -MD -MP -MF .dep
[command output truncated]
llowed in x86_64-w64-mingw32 shared libraries; building static only
libtool: link: x86_64-w64-mingw32-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: x86_64-w64-mingw32-ranlib .libs/libonig.a
libtool: link: ( cd ".libs" && rm -f "libonig.la" && ln -s "../libonig.la" "libonig.la" )
make[4]: Leaving directory '/home/peter/jq-1.8.1/vendor/oniguruma/src'
make[3]: Leaving directory '/home/peter/jq-1.8.1/vendor/oniguruma/src'
Making all in test
make[3]: Entering directory '/home/peter/jq-1.8.1/vendor/oniguruma/test'
make[3]: Nothing to be done for 'all'.
make[3]: Leaving directory '/home/peter/jq-1.8.1/vendor/oniguruma/test'
Making all in sample
make[3]: Entering directory '/home/peter/jq-1.8.1/vendor/oniguruma/sample'
make[3]: Nothing to be done for 'all'.
make[3]: Leaving directory '/home/peter/jq-1.8.1/vendor/oniguruma/sample'
make[3]: Entering directory '/home/peter/jq-1.8.1/vendor/oniguruma'
sed -e 's,[@]datadir[@],/usr/local/share,g' -e 's,[@]datarootdir[@],/usr/local/share,g' -e 's,[@]PACKAGE_VERSION[@],6.9.10,g' -e 's,[@]prefix[@],/usr/local,g' -e 's,[@]exec_prefix[@],/usr/local,g' -e 's,[@]libdir[@],/usr/local/lib,g' -e 's,[@]includedir[@],/usr/local/include,g' < ./oniguruma.pc.in > oniguruma.pc
make[3]: Leaving directory '/home/peter/jq-1.8.1/vendor/oniguruma'
make[2]: Leaving directory '/home/peter/jq-1.8.1/vendor/oniguruma'
make[2]: Entering directory '/home/peter/jq-1.8.1'
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
mkdir -p src
GEN src/version.h
CC src/main.o
src/main.c:21:1: warning: function declaration isn't a prototype [ttps://gcc.gnu.org/onlinedocs/gcc/Warning-Options.html#index-Wstrict-prototypes-Wstrict-prototypes]8;;]
21 | extern void jv_tsd_dtoa_ctx_init();
| ^~~~~~
CCLD libjq.la
CCLD jq.exe
make[2]: Leaving directory '/home/peter/jq-1.8.1'
make[1]: Leaving directory '/home/peter/jq-1.8.1'
Show reasoning
Preparing installation files
jq-1.8.1/jq.exe
Show reasoning
Preparing destination directory
[empty output]
Show reasoning
Copying file jq.exe
[empty output]
Show reasoning
Verifying static linking on Windows
compile-bench> x86_64-w64-mingw32-objdump -p result/jq.exe | grep DLL vma: Hint Time Forward DLL First
DLL Name: KERNEL32.dll
DLL Name: msvcrt.dll
DLL Name: libwinpthread-1.dll
DLL Name: SHLWAPI.dll
↓ 6 lines
vma: Hint Time Forward DLL First DLL Name: KERNEL32.dll DLL Name: msvcrt.dll DLL Name: libwinpthread-1.dll DLL Name: SHLWAPI.dll
Show reasoning
Investigating static linking of libwinpthread on Windows
I'm sorting through how to fully statically link libwinpthread on Windows, since the current build shows a dynamic dependency. There might be static versions available, but I need to confirm with compiler commands and adjust linker flags carefully to enforce static linking without pulling in the DLL.
/usr/lib/gcc/x86_64-w64-mingw32/10-win32/../../../../x86_64-w64-mingw32/lib/libwinpthread.a
Show reasoning
Analyzing static linking flags
grep: jq-1.8.1/src/Makefile: No such file or directory
Show reasoning
Investigating Makefile location
compile-bench> ls jq-1.8.1/src builtin.c jq_test.c jv_file.c linker.c
builtin.h jq_test.lo jv_file.lo linker.h
builtin.inc jq_test.o jv_file.o linker.lo
builtin.jq jv.c jv_parse.c linker.o
builtin.lo jv.h jv_parse.lo locfile.c
builtin.o jv.lo jv_parse.o locfile.h
bytecode.c jv.o jv_print.c locfile.lo
bytecode.h jv_alloc.c jv_print.lo locfile.o
bytecode.lo jv_alloc.h jv_print.o main.c
bytecode.o jv_alloc.lo jv_private.h main.o
compile.c jv_alloc.o jv_thread.h opcode_list.h
compile.h jv_aux.c jv_unicode.c parser.c
compile.lo jv_aux.lo jv_unicode.h parser.h
compile.o jv_aux.o jv_unicode.lo parser.lo
config_opts.inc jv_dtoa.c jv_unicode.o parser.o
exec_stack.h jv_dtoa.h jv_utf8_tables.h parser.y
execute.c jv_dtoa.lo lexer.c util.c
execute.lo jv_dtoa.o lexer.h util.h
execute.o jv_dtoa_tsd.c lexer.l util.lo
inject_errors.c jv_dtoa_tsd.h lexer.lo util.o
jq.h jv_dtoa_tsd.lo lexer.o version.h
jq_parser.h jv_dtoa_tsd.o libm.h
↓ 23 lines
builtin.c jq_test.c jv_file.c linker.c builtin.h jq_test.lo jv_file.lo linker.h builtin.inc jq_test.o jv_file.o linker.lo builtin.jq jv.c jv_parse.c linker.o builtin.lo jv.h jv_parse.lo locfile.c builtin.o jv.lo jv_parse.o locfile.h bytecode.c jv.o jv_print.c locfile.lo bytecode.h jv_alloc.c jv_print.lo locfile.o bytecode.lo jv_alloc.h jv_print.o main.c bytecode.o jv_alloc.lo jv_private.h main.o compile.c jv_alloc.o jv_thread.h opcode_list.h compile.h jv_aux.c jv_unicode.c parser.c compile.lo jv_aux.lo jv_unicode.h parser.h compile.o jv_aux.o jv_unicode.lo parser.lo config_opts.inc jv_dtoa.c jv_unicode.o parser.o exec_stack.h jv_dtoa.h jv_utf8_tables.h parser.y execute.c jv_dtoa.lo lexer.c util.c execute.lo jv_dtoa.o lexer.h util.h execute.o jv_dtoa_tsd.c lexer.l util.lo inject_errors.c jv_dtoa_tsd.h lexer.lo util.o jq.h jv_dtoa_tsd.lo lexer.o version.h jq_parser.h jv_dtoa_tsd.o libm.h
Show reasoning
Analyzing static linking challenges and build setup
I’m digging into why the src/Makefile might be missing and how the build handles static linking, especially around libwinpthread. It seems the build uses a top-level Makefile with automake, and the src/Makefile could be hidden or removed by cleaning. I want to re-run make with verbose flags to see full link commands and try cleaning fully before rebuilding with static linking flags. Also, I’m considering whether using the posix or win32 variant of the mingw toolchain affects dynamic library dependencies and how to enforce static linkage correctly during configure and make. The plan involves carefully adjusting the environment variables and make invocation to control linking and ensure the final executable is fully static.
compile-bench> cd jq-1.8.1 && make clean Making clean in vendor/oniguruma
make[1]: Entering directory '/home/peter/jq-1.8.1/vendor/oniguruma'
Making clean in src
make[2]: Entering directory '/home/peter/jq-1.8.1/vendor/oniguruma/src'
test -z "libonig.la" || rm -f libonig.la
rm -f ./so_locations
rm -rf .libs _libs
rm -f *.o
rm -f *.lo
make[2]: Leaving directory '/home/peter/jq-1.8.1/vendor/oniguruma/src'
Making clean in test
make[2]: Entering directory '/home/peter/jq-1.8.1/vendor/oniguruma/test'
rm -f test_utf8.exe test_syntax.exe test_options.exe testc.exe testcu.exe test_regset.exe test_back.exe
rm -f test_utf8 test_syntax test_options testc testcu test_regset test_back
rm -rf .libs _libs
rm -f *.o
test -z "test_utf8.log test_syntax.log test_options.log testc.log testcu.log test_regset.log test_back.log" || rm -f test_utf8.log test_syntax.log test_options.log testc.log testcu.log test_regset.log test_back.log
test -z "test_utf8.trs test_syntax.trs test_options.trs testc.trs testcu.trs test_regset.trs test_back.trs" || rm -f test_utf8.trs test_syntax.trs test_options.trs testc.trs testcu.trs test_regset.trs test_back.trs
test -z "test-suite.log" || rm -f test-suite.log
rm -f *.lo
make[2]: Leaving directory '/home/peter/jq-1.8.1/vendor/oniguruma/test'
Making clean in sample
make[2]: Entering directory '/home/peter/jq-1.8.1/vendor/oniguruma/sample'
rm -f encode.exe listcap.exe names.exe simple.exe sql.exe syntax.exe user_property.exe callout.exe echo.exe count.exe bug_fix.exe regset.exe scan.exe callback_each_match.exe
rm -f encode listcap names simple sql syntax user_property callout echo count bug_fix regset scan callback_each_match
rm -rf .libs _libs
rm -f *.o
test -z "encode.log listcap.log names.log simple.log sql.log syntax.log user_property.log callout.log echo.log count.log bug_fix.log regset.log scan.log callback_each_match.log" || rm -f encode.log listcap.log names.log simple.log sql.log syntax.log user_property.log callout.log echo.log count.log bug_fix.log regset.log scan.log callback_each_match.log
test -z "encode.trs listcap.trs names.trs simple.trs sql.trs syntax.trs user_property.trs callout.trs echo.trs count.trs bug_fix.trs regset.trs scan.trs callback_each_match.trs" || rm -f encode.trs listcap.trs names.trs simple.trs sql.trs syntax.trs user_property.trs callout.trs echo.trs count.trs bug_fix.trs regset.trs scan.trs callback_each_match.trs
test -z "test-suite.log" || rm -f test-suite.log
rm -f *.lo
make[2]: Leaving directory '/home/peter/jq-1.8.1/vendor/oniguruma/sample'
make[2]: Entering directory '/home/peter/jq-1.8.1/vendor/oniguruma'
rm -rf .libs _libs
rm -f *.lo
make[2]: Leaving directory '/home/peter/jq-1.8.1/vendor/oniguruma'
make[1]: Leaving directory '/home/peter/jq-1.8.1/vendor/oniguruma'
make[1]: Entering directory '/home/peter/jq-1.8.1'
rm -f jq.exe
rm -f jq
test -z "src/version.h .remake-version-h src/builtin.inc src/config_opts.inc jq.1" || rm -f src/version.h .remake-version-h src/builtin.inc src/config_opts.inc jq.1
test -z "libjq.la " || rm -f libjq.la
rm -f ./so_locations
rm -rf .libs _libs
rm -rf src/.libs src/_libs
rm -rf vendor/decNumber/.libs vendor/decNumber/_libs
rm -f *.o
rm -f src/*.o
rm -f src/*.lo
rm -f vendor/decNumber/*.o
rm -f vendor/decNumber/*.lo
test -z "tests/mantest.log tests/jqtest.log tests/shtest.log tests/utf8test.log tests/base64test.log tests/uritest.log tests/onigtest.log tests/manonigtest.log" || rm -f tests/mantest.log tests/jqtest.log tests/shtest.log tests/utf8test.log tests/base64test.log tests/uritest.log tests/onigtest.log tests/manonigtest.log
test -z "tests/mantest.trs tests/jqtest.trs tests/shtest.trs tests/utf8test.trs tests/base64test.trs tests/uritest.trs tests/onigtest.trs tests/manonigtest.trs" || rm -f tests/mantest.trs tests/jqtest.trs tests/shtest.trs tests/utf8test.trs tests/base64test.trs tests/uritest.trs tests/onigtest.trs tests/manonigtest.trs
test -z "test-suite.log" || rm -f test-suite.log
rm -f *.lo
make[1]: Leaving directory '/home/peter/jq-1.8.1'
↓ 57 lines
Making clean in vendor/oniguruma make[1]: Entering directory '/home/peter/jq-1.8.1/vendor/oniguruma' Making clean in src make[2]: Entering directory '/home/peter/jq-1.8.1/vendor/oniguruma/src' test -z "libonig.la" || rm -f libonig.la rm -f ./so_locations rm -rf .libs _libs rm -f *.o rm -f *.lo make[2]: Leaving directory '/home/peter/jq-1.8.1/vendor/oniguruma/src' Making clean in test make[2]: Entering directory '/home/peter/jq-1.8.1/vendor/oniguruma/test' rm -f test_utf8.exe test_syntax.exe test_options.exe testc.exe testcu.exe test_regset.exe test_back.exe rm -f test_utf8 test_syntax test_options testc testcu test_regset test_back rm -rf .libs _libs rm -f *.o test -z "test_utf8.log test_syntax.log test_options.log testc.log testcu.log test_regset.log test_back.log" || rm -f test_utf8.log test_syntax.log test_options.log testc.log testcu.log test_regset.log test_back.log test -z "test_utf8.trs test_syntax.trs test_options.trs testc.trs testcu.trs test_regset.trs test_back.trs" || rm -f test_utf8.trs test_syntax.trs test_options.trs testc.trs testcu.trs test_regset.trs test_back.trs test -z "test-suite.log" || rm -f test-suite.log rm -f *.lo make[2]: Leaving directory '/home/peter/jq-1.8.1/vendor/oniguruma/test' Making clean in sample make[2]: Entering directory '/home/peter/jq-1.8.1/vendor/oniguruma/sample' rm -f encode.exe listcap.exe names.exe simple.exe sql.exe syntax.exe user_property.exe callout.exe echo.exe count.exe bug_fix.exe regset.exe scan.exe callback_each_match.exe rm -f encode listcap names simple sql syntax user_property callout echo count bug_fix regset scan callback_each_match rm -rf .libs _libs rm -f *.o test -z "encode.log listcap.log names.log simple.log sql.log syntax.log user_property.log callout.log echo.log count.log bug_fix.log regset.log scan.log callback_each_match.log" || rm -f encode.log listcap.log names.log simple.log sql.log syntax.log user_property.log callout.log echo.log count.log bug_fix.log regset.log scan.log callback_each_match.log test -z "encode.trs listcap.trs names.trs simple.trs sql.trs syntax.trs user_property.trs callout.trs echo.trs count.trs bug_fix.trs regset.trs scan.trs callback_each_match.trs" || rm -f encode.trs listcap.trs names.trs simple.trs sql.trs syntax.trs user_property.trs callout.trs echo.trs count.trs bug_fix.trs regset.trs scan.trs callback_each_match.trs test -z "test-suite.log" || rm -f test-suite.log rm -f *.lo make[2]: Leaving directory '/home/peter/jq-1.8.1/vendor/oniguruma/sample' make[2]: Entering directory '/home/peter/jq-1.8.1/vendor/oniguruma' rm -rf .libs _libs rm -f *.lo make[2]: Leaving directory '/home/peter/jq-1.8.1/vendor/oniguruma' make[1]: Leaving directory '/home/peter/jq-1.8.1/vendor/oniguruma' make[1]: Entering directory '/home/peter/jq-1.8.1' rm -f jq.exe rm -f jq test -z "src/version.h .remake-version-h src/builtin.inc src/config_opts.inc jq.1" || rm -f src/version.h .remake-version-h src/builtin.inc src/config_opts.inc jq.1 test -z "libjq.la " || rm -f libjq.la rm -f ./so_locations rm -rf .libs _libs rm -rf src/.libs src/_libs rm -rf vendor/decNumber/.libs vendor/decNumber/_libs rm -f *.o rm -f src/*.o rm -f src/*.lo rm -f vendor/decNumber/*.o rm -f vendor/decNumber/*.lo test -z "tests/mantest.log tests/jqtest.log tests/shtest.log tests/utf8test.log tests/base64test.log tests/uritest.log tests/onigtest.log tests/manonigtest.log" || rm -f tests/mantest.log tests/jqtest.log tests/shtest.log tests/utf8test.log tests/base64test.log tests/uritest.log tests/onigtest.log tests/manonigtest.log test -z "tests/mantest.trs tests/jqtest.trs tests/shtest.trs tests/utf8test.trs tests/base64test.trs tests/uritest.trs tests/onigtest.trs tests/manonigtest.trs" || rm -f tests/mantest.trs tests/jqtest.trs tests/shtest.trs tests/utf8test.trs tests/base64test.trs tests/uritest.trs tests/onigtest.trs tests/manonigtest.trs test -z "test-suite.log" || rm -f test-suite.log rm -f *.lo make[1]: Leaving directory '/home/peter/jq-1.8.1'
Show reasoning
Reconfiguring build environment with static flags
I'm thinking about forcing a reconfiguration with specific static linking flags and carefully choosing the thread model in cross-compilation by switching the x86_64-w64-mingw32-gcc alternative to the -win32 variant, which avoids libwinpthread dependencies by using Windows threads. I want to verify which compiler alternative is active via readlink and then rerun configure with updated environment variables to ensure the static build propagates properly.
/usr/bin/x86_64-w64-mingw32-gcc-win32
Show reasoning
Analyzing static linking with libwinpthread
I'm figuring out why libwinpthread is linked even with the win32 thread model and exploring how to force static linking of this library. I'm considering linker flags like -Wl,-Bstatic -lwinpthread -Wl,-Bdynamic alongside -static-libgcc and -static-libstdc++, planning to reconfigure with these options to see if that ensures a fully static build.
compile-bench> cd jq-1.8.1 && CC=x86_64-w64-mingw32-gcc CXX=x86_64-w64-mingw32-g++ AR=x86_64-w64-mingw32-ar RANLIB=x86_64-w64-mingw32-ranlib STRIP=x86_64-w64-mingw32-strip CFLAGS="-O2 -static -static-libgcc -static-libstdc++" LDFLAGS="-static -static-libgcc -static-libstdc++" LIBS="-Wl,-Bstatic -lwinpthread -Wl,-Bdynamic" ./configure --host=x86_64-w64-mingw32 --build=x86_64-pc-linux-gnu --disable-shared --enable-static --with-oniguruma=builtin checking for x86_64-w64-mingw32-gcc... x86_64-w64-mingw32-gcc
checking whether the C compiler works... yes
checking for C compiler default output file name... a.exe
checking for suffix of executables... .exe
checking whether we are cross compiling... yes
checking for suffix of object files... o
checking whether the compiler supports GNU C... yes
checking whether x86_64-w64-mingw32-gcc accepts -g... yes
checking for x86_64-w64-mingw32-gcc option to enable C11 features... none needed
checking whether x86_64-w64-mingw32-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 x86_64-w64-mingw32-strip... x86_64-w64-mingw32-strip
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 x86_64-w64-mingw32-gcc... gcc3
checking whether make supports nested variables... (cached) yes
checking for x86_64-w64-mingw32-ar... x86_64-w64-mingw32-ar
checking the archiver (x86_64-w64-mingw32-ar) interface... ar
checking whether to enable maintainer-specific portions of Makefiles... no
checking for x86_64-w64-mingw32-gcc... (cached) x86_64-w64-mingw32-gcc
checking whether the compiler supports GNU C... (cached) yes
checking whether x86_64-w64-mingw32-gcc accepts -g... (cached) yes
checking for x86_64-w64-mingw32-gcc option to enable C11 features... (cached) none needed
checking whether x86_64-w64-mingw32-gcc understands -c and -o together... (cached) yes
checking how to run the C preprocessor... x86_64-w64-mingw32-gcc -E
checking for bison... no
checking for byacc... no
checking build system type... x86_64-pc-linux-gnu
checking host system type... x86_64-w64-mingw32
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 x86_64-w64-mingw32-gcc... /usr/bin/x86_64-w64-mingw32-ld
checking if the linker (/usr/bin/x86_64-w64-mingw32-ld) is GNU ld... yes
checking for BSD- or MS-compatible name lister (nm)... /usr/bin/x86_64-w64-mingw32-nm -B
checking the name lister (/usr/bin/x86_64-w64-mingw32-nm -B) interface... BSD n
[command output truncated]
_64-w64-mingw32-objdump... x86_64-w64-mingw32-objdump
checking how to recognize dependent libraries... file_magic ^x86 archive import|^x86 DLL
checking for x86_64-w64-mingw32-dlltool... x86_64-w64-mingw32-dlltool
checking how to associate runtime and link libraries... func_cygming_dll_for_implib
checking for x86_64-w64-mingw32-ar... x86_64-w64-mingw32-ar
checking for archiver @FILE support... @
checking for x86_64-w64-mingw32-strip... (cached) x86_64-w64-mingw32-strip
checking for x86_64-w64-mingw32-ranlib... x86_64-w64-mingw32-ranlib
checking command to parse /usr/bin/x86_64-w64-mingw32-nm -B output from x86_64-w64-mingw32-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 x86_64-w64-mingw32-mt... no
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... no
checking for objdir... .libs
checking if x86_64-w64-mingw32-gcc supports -fno-rtti -fno-exceptions... no
checking for x86_64-w64-mingw32-gcc option to produce PIC... -DDLL_EXPORT -DPIC
checking if x86_64-w64-mingw32-gcc PIC flag -DDLL_EXPORT -DPIC works... yes
checking if x86_64-w64-mingw32-gcc static flag -static works... yes
checking if x86_64-w64-mingw32-gcc supports -c -o file.o... yes
checking if x86_64-w64-mingw32-gcc supports -c -o file.o... (cached) yes
checking whether the x86_64-w64-mingw32-gcc linker (/usr/bin/x86_64-w64-mingw32-ld) supports shared libraries... yes
checking dynamic linker characteristics... Win32 ld.exe
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... no
checking size of int... 4
checking size of long... 4
checking size of long long... 8
checking size of void*... 8
checking for size_t... yes
checking for working alloca.h... no
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
↓ 120 lines
checking for x86_64-w64-mingw32-gcc... x86_64-w64-mingw32-gcc checking whether the C compiler works... yes checking for C compiler default output file name... a.exe checking for suffix of executables... .exe checking whether we are cross compiling... yes checking for suffix of object files... o checking whether the compiler supports GNU C... yes checking whether x86_64-w64-mingw32-gcc accepts -g... yes checking for x86_64-w64-mingw32-gcc option to enable C11 features... none needed checking whether x86_64-w64-mingw32-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 x86_64-w64-mingw32-strip... x86_64-w64-mingw32-strip 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 x86_64-w64-mingw32-gcc... gcc3 checking whether make supports nested variables... (cached) yes checking for x86_64-w64-mingw32-ar... x86_64-w64-mingw32-ar checking the archiver (x86_64-w64-mingw32-ar) interface... ar checking whether to enable maintainer-specific portions of Makefiles... no checking for x86_64-w64-mingw32-gcc... (cached) x86_64-w64-mingw32-gcc checking whether the compiler supports GNU C... (cached) yes checking whether x86_64-w64-mingw32-gcc accepts -g... (cached) yes checking for x86_64-w64-mingw32-gcc option to enable C11 features... (cached) none needed checking whether x86_64-w64-mingw32-gcc understands -c and -o together... (cached) yes checking how to run the C preprocessor... x86_64-w64-mingw32-gcc -E checking for bison... no checking for byacc... no checking build system type... x86_64-pc-linux-gnu checking host system type... x86_64-w64-mingw32 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 x86_64-w64-mingw32-gcc... /usr/bin/x86_64-w64-mingw32-ld checking if the linker (/usr/bin/x86_64-w64-mingw32-ld) is GNU ld... yes checking for BSD- or MS-compatible name lister (nm)... /usr/bin/x86_64-w64-mingw32-nm -B checking the name lister (/usr/bin/x86_64-w64-mingw32-nm -B) interface... BSD n [command output truncated] _64-w64-mingw32-objdump... x86_64-w64-mingw32-objdump checking how to recognize dependent libraries... file_magic ^x86 archive import|^x86 DLL checking for x86_64-w64-mingw32-dlltool... x86_64-w64-mingw32-dlltool checking how to associate runtime and link libraries... func_cygming_dll_for_implib checking for x86_64-w64-mingw32-ar... x86_64-w64-mingw32-ar checking for archiver @FILE support... @ checking for x86_64-w64-mingw32-strip... (cached) x86_64-w64-mingw32-strip checking for x86_64-w64-mingw32-ranlib... x86_64-w64-mingw32-ranlib checking command to parse /usr/bin/x86_64-w64-mingw32-nm -B output from x86_64-w64-mingw32-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 x86_64-w64-mingw32-mt... no 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... no checking for objdir... .libs checking if x86_64-w64-mingw32-gcc supports -fno-rtti -fno-exceptions... no checking for x86_64-w64-mingw32-gcc option to produce PIC... -DDLL_EXPORT -DPIC checking if x86_64-w64-mingw32-gcc PIC flag -DDLL_EXPORT -DPIC works... yes checking if x86_64-w64-mingw32-gcc static flag -static works... yes checking if x86_64-w64-mingw32-gcc supports -c -o file.o... yes checking if x86_64-w64-mingw32-gcc supports -c -o file.o... (cached) yes checking whether the x86_64-w64-mingw32-gcc linker (/usr/bin/x86_64-w64-mingw32-ld) supports shared libraries... yes checking dynamic linker characteristics... Win32 ld.exe 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... no checking size of int... 4 checking size of long... 4 checking size of long long... 8 checking size of void*... 8 checking for size_t... yes checking for working alloca.h... no 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
Show reasoning
Running parallel make build
compile-bench> cd jq-1.8.1 && make -j$(nproc) mkdir -p src
mkdir -p src
GEN src/builtin.inc
GEN src/config_opts.inc
mkdir -p src
GEN src/version.h
make all-recursive
make[1]: Entering directory '/home/peter/jq-1.8.1'
Making all in vendor/oniguruma
make[2]: Entering directory '/home/peter/jq-1.8.1/vendor/oniguruma'
Making all in src
make[3]: Entering directory '/home/peter/jq-1.8.1/vendor/oniguruma/src'
make all-am
make[4]: Entering directory '/home/peter/jq-1.8.1/vendor/oniguruma/src'
/bin/bash ../libtool --tag=CC --mode=compile x86_64-w64-mingw32-gcc -DHAVE_CONFIG_H -I. -I.. -Wall -O2 -static -static-libgcc -static-libstdc++ -MT regparse.lo -MD -MP -MF .deps/regparse.Tpo -c -o regparse.lo regparse.c
/bin/bash ../libtool --tag=CC --mode=compile x86_64-w64-mingw32-gcc -DHAVE_CONFIG_H -I. -I.. -Wall -O2 -static -static-libgcc -static-libstdc++ -MT regcomp.lo -MD -MP -MF .deps/regcomp.Tpo -c -o regcomp.lo regcomp.c
/bin/bash ../libtool --tag=CC --mode=compile x86_64-w64-mingw32-gcc -DHAVE_CONFIG_H -I. -I.. -Wall -O2 -static -static-libgcc -static-libstdc++ -MT regexec.lo -MD -MP -MF .deps/regexec.Tpo -c -o regexec.lo regexec.c
/bin/bash ../libtool --tag=CC --mode=compile x86_64-w64-mingw32-gcc -DHAVE_CONFIG_H -I. -I.. -Wall -O2 -static -static-libgcc -static-libstdc++ -MT regenc.lo -MD -MP -MF .deps/regenc.Tpo -c -o regenc.lo regenc.c
/bin/bash ../libtool --tag=CC --mode=compile x86_64-w64-mingw32-gcc -DHAVE_CONFIG_H -I. -I.. -Wall -O2 -static -static-libgcc -static-libstdc++ -MT regerror.lo -MD -MP -MF .deps/regerror.Tpo -c -o regerror.lo regerror.c
/bin/bash ../libtool --tag=CC --mode=compile x86_64-w64-mingw32-gcc -DHAVE_CONFIG_H -I. -I.. -Wall -O2 -static -static-libgcc -static-libstdc++ -MT regext.lo -MD -MP -MF .deps/regext.Tpo -c -o regext.lo regext.c
/bin/bash ../libtool --tag=CC --mode=compile x86_64-w64-mingw32-gcc -DHAVE_CONFIG_H -I. -I.. -Wall -O2 -static -static-libgcc -static-libstdc++ -MT regsyntax.lo -MD -MP -MF .deps/regsyntax.Tpo -c -o regsyntax.lo regsyntax.c
/bin/bash ../libtool --tag=CC --mode=compile x86_64-w64-mingw32-gcc -DHAVE_CONFIG_H -I. -I.. -Wall -O2 -static -static-libgcc -static-libstdc++ -MT regtrav.lo -MD -MP -MF .deps/regtrav.Tpo -c -o regtrav.lo regtrav.c
libtool: compile: x86_64-w64-mingw32-gcc -DHAVE_CONFIG_H -I. -I.. -Wall -O2 -static-libgcc -static-libstdc++ -MT regparse.lo -MD -MP -MF .deps/regparse.Tpo -c regparse.c -o regparse.o
libtool: compile: x86_64-w64-mingw32-gcc -DHAVE_CONFIG_H -I. -I.. -Wall -O2 -static-libgcc -static-libstdc++ -MT regenc.lo -MD -MP -MF .deps/regenc.Tpo -c regenc.c -o regenc.o
libtool: compile: x86_64-w64-mingw32-gcc -DHAVE_CONFIG_H -I. -I.. -Wall -O2 -static-libgcc -static-libstdc++ -MT regexec.lo -MD -MP -MF .deps/regexec.Tpo -c regexec.c -o regexec.o
libtool: compile: x86_64-w64-mingw32-gcc -DHAVE_CONFIG_H -I. -I.. -Wall -O2 -static-libgcc -static-libstdc++ -MT regext.lo -MD -MP -MF .deps/regext.Tpo -c regext.c -o regex
[command output truncated]
undefined symbols not allowed in x86_64-w64-mingw32 shared libraries; building static only
libtool: link: x86_64-w64-mingw32-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: x86_64-w64-mingw32-ranlib .libs/libonig.a
libtool: link: ( cd ".libs" && rm -f "libonig.la" && ln -s "../libonig.la" "libonig.la" )
make[4]: Leaving directory '/home/peter/jq-1.8.1/vendor/oniguruma/src'
make[3]: Leaving directory '/home/peter/jq-1.8.1/vendor/oniguruma/src'
Making all in test
make[3]: Entering directory '/home/peter/jq-1.8.1/vendor/oniguruma/test'
make[3]: Nothing to be done for 'all'.
make[3]: Leaving directory '/home/peter/jq-1.8.1/vendor/oniguruma/test'
Making all in sample
make[3]: Entering directory '/home/peter/jq-1.8.1/vendor/oniguruma/sample'
make[3]: Nothing to be done for 'all'.
make[3]: Leaving directory '/home/peter/jq-1.8.1/vendor/oniguruma/sample'
make[3]: Entering directory '/home/peter/jq-1.8.1/vendor/oniguruma'
sed -e 's,[@]datadir[@],/usr/local/share,g' -e 's,[@]datarootdir[@],/usr/local/share,g' -e 's,[@]PACKAGE_VERSION[@],6.9.10,g' -e 's,[@]prefix[@],/usr/local,g' -e 's,[@]exec_prefix[@],/usr/local,g' -e 's,[@]libdir[@],/usr/local/lib,g' -e 's,[@]includedir[@],/usr/local/include,g' < ./oniguruma.pc.in > oniguruma.pc
make[3]: Leaving directory '/home/peter/jq-1.8.1/vendor/oniguruma'
make[2]: Leaving directory '/home/peter/jq-1.8.1/vendor/oniguruma'
make[2]: Entering directory '/home/peter/jq-1.8.1'
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
GEN jq.1
CC src/main.o
src/main.c:21:1: warning: function declaration isn't a prototype [ttps://gcc.gnu.org/onlinedocs/gcc/Warning-Options.html#index-Wstrict-prototypes-Wstrict-prototypes]8;;]
21 | extern void jv_tsd_dtoa_ctx_init();
| ^~~~~~
CCLD libjq.la
CCLD jq.exe
make[2]: Leaving directory '/home/peter/jq-1.8.1'
make[1]: Leaving directory '/home/peter/jq-1.8.1'
↓ 77 lines
mkdir -p src
mkdir -p src
GEN src/builtin.inc
GEN src/config_opts.inc
mkdir -p src
GEN src/version.h
make all-recursive
make[1]: Entering directory '/home/peter/jq-1.8.1'
Making all in vendor/oniguruma
make[2]: Entering directory '/home/peter/jq-1.8.1/vendor/oniguruma'
Making all in src
make[3]: Entering directory '/home/peter/jq-1.8.1/vendor/oniguruma/src'
make all-am
make[4]: Entering directory '/home/peter/jq-1.8.1/vendor/oniguruma/src'
/bin/bash ../libtool --tag=CC --mode=compile x86_64-w64-mingw32-gcc -DHAVE_CONFIG_H -I. -I.. -Wall -O2 -static -static-libgcc -static-libstdc++ -MT regparse.lo -MD -MP -MF .deps/regparse.Tpo -c -o regparse.lo regparse.c
/bin/bash ../libtool --tag=CC --mode=compile x86_64-w64-mingw32-gcc -DHAVE_CONFIG_H -I. -I.. -Wall -O2 -static -static-libgcc -static-libstdc++ -MT regcomp.lo -MD -MP -MF .deps/regcomp.Tpo -c -o regcomp.lo regcomp.c
/bin/bash ../libtool --tag=CC --mode=compile x86_64-w64-mingw32-gcc -DHAVE_CONFIG_H -I. -I.. -Wall -O2 -static -static-libgcc -static-libstdc++ -MT regexec.lo -MD -MP -MF .deps/regexec.Tpo -c -o regexec.lo regexec.c
/bin/bash ../libtool --tag=CC --mode=compile x86_64-w64-mingw32-gcc -DHAVE_CONFIG_H -I. -I.. -Wall -O2 -static -static-libgcc -static-libstdc++ -MT regenc.lo -MD -MP -MF .deps/regenc.Tpo -c -o regenc.lo regenc.c
/bin/bash ../libtool --tag=CC --mode=compile x86_64-w64-mingw32-gcc -DHAVE_CONFIG_H -I. -I.. -Wall -O2 -static -static-libgcc -static-libstdc++ -MT regerror.lo -MD -MP -MF .deps/regerror.Tpo -c -o regerror.lo regerror.c
/bin/bash ../libtool --tag=CC --mode=compile x86_64-w64-mingw32-gcc -DHAVE_CONFIG_H -I. -I.. -Wall -O2 -static -static-libgcc -static-libstdc++ -MT regext.lo -MD -MP -MF .deps/regext.Tpo -c -o regext.lo regext.c
/bin/bash ../libtool --tag=CC --mode=compile x86_64-w64-mingw32-gcc -DHAVE_CONFIG_H -I. -I.. -Wall -O2 -static -static-libgcc -static-libstdc++ -MT regsyntax.lo -MD -MP -MF .deps/regsyntax.Tpo -c -o regsyntax.lo regsyntax.c
/bin/bash ../libtool --tag=CC --mode=compile x86_64-w64-mingw32-gcc -DHAVE_CONFIG_H -I. -I.. -Wall -O2 -static -static-libgcc -static-libstdc++ -MT regtrav.lo -MD -MP -MF .deps/regtrav.Tpo -c -o regtrav.lo regtrav.c
libtool: compile: x86_64-w64-mingw32-gcc -DHAVE_CONFIG_H -I. -I.. -Wall -O2 -static-libgcc -static-libstdc++ -MT regparse.lo -MD -MP -MF .deps/regparse.Tpo -c regparse.c -o regparse.o
libtool: compile: x86_64-w64-mingw32-gcc -DHAVE_CONFIG_H -I. -I.. -Wall -O2 -static-libgcc -static-libstdc++ -MT regenc.lo -MD -MP -MF .deps/regenc.Tpo -c regenc.c -o regenc.o
libtool: compile: x86_64-w64-mingw32-gcc -DHAVE_CONFIG_H -I. -I.. -Wall -O2 -static-libgcc -static-libstdc++ -MT regexec.lo -MD -MP -MF .deps/regexec.Tpo -c regexec.c -o regexec.o
libtool: compile: x86_64-w64-mingw32-gcc -DHAVE_CONFIG_H -I. -I.. -Wall -O2 -static-libgcc -static-libstdc++ -MT regext.lo -MD -MP -MF .deps/regext.Tpo -c regext.c -o regex
[command output truncated]
undefined symbols not allowed in x86_64-w64-mingw32 shared libraries; building static only
libtool: link: x86_64-w64-mingw32-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: x86_64-w64-mingw32-ranlib .libs/libonig.a
libtool: link: ( cd ".libs" && rm -f "libonig.la" && ln -s "../libonig.la" "libonig.la" )
make[4]: Leaving directory '/home/peter/jq-1.8.1/vendor/oniguruma/src'
make[3]: Leaving directory '/home/peter/jq-1.8.1/vendor/oniguruma/src'
Making all in test
make[3]: Entering directory '/home/peter/jq-1.8.1/vendor/oniguruma/test'
make[3]: Nothing to be done for 'all'.
make[3]: Leaving directory '/home/peter/jq-1.8.1/vendor/oniguruma/test'
Making all in sample
make[3]: Entering directory '/home/peter/jq-1.8.1/vendor/oniguruma/sample'
make[3]: Nothing to be done for 'all'.
make[3]: Leaving directory '/home/peter/jq-1.8.1/vendor/oniguruma/sample'
make[3]: Entering directory '/home/peter/jq-1.8.1/vendor/oniguruma'
sed -e 's,[@]datadir[@],/usr/local/share,g' -e 's,[@]datarootdir[@],/usr/local/share,g' -e 's,[@]PACKAGE_VERSION[@],6.9.10,g' -e 's,[@]prefix[@],/usr/local,g' -e 's,[@]exec_prefix[@],/usr/local,g' -e 's,[@]libdir[@],/usr/local/lib,g' -e 's,[@]includedir[@],/usr/local/include,g' < ./oniguruma.pc.in > oniguruma.pc
make[3]: Leaving directory '/home/peter/jq-1.8.1/vendor/oniguruma'
make[2]: Leaving directory '/home/peter/jq-1.8.1/vendor/oniguruma'
make[2]: Entering directory '/home/peter/jq-1.8.1'
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
GEN jq.1
CC src/main.o
src/main.c:21:1: warning: function declaration isn't a prototype [ttps://gcc.gnu.org/onlinedocs/gcc/Warning-Options.html#index-Wstrict-prototypes-Wstrict-prototypes]8;;]
21 | extern void jv_tsd_dtoa_ctx_init();
| ^~~~~~
CCLD libjq.la
CCLD jq.exe
make[2]: Leaving directory '/home/peter/jq-1.8.1'
make[1]: Leaving directory '/home/peter/jq-1.8.1'
Show reasoning
Preparing to check executable dependencies
compile-bench> x86_64-w64-mingw32-objdump -p jq-1.8.1/jq.exe | grep DLL vma: Hint Time Forward DLL First
DLL Name: KERNEL32.dll
DLL Name: msvcrt.dll
DLL Name: libwinpthread-1.dll
DLL Name: SHLWAPI.dll
↓ 6 lines
vma: Hint Time Forward DLL First DLL Name: KERNEL32.dll DLL Name: msvcrt.dll DLL Name: libwinpthread-1.dll DLL Name: SHLWAPI.dll
Show reasoning
Investigating dynamic libwinpthread linkage
compile-bench> grep -R "winpthread" -n jq-1.8.1 jq-1.8.1/src/config_opts.inc:1:#define JQ_CONFIG "--host=x86_64-w64-mingw32 --build=x86_64-pc-linux-gnu --disable-shared --enable-static --with-oniguruma=builtin build_alias=x86_64-pc-linux-gnu host_alias=x86_64-w64-mingw32 CC=x86_64-w64-mingw32-gcc 'CFLAGS=-O2 -static -static-libgcc -static-libstdc++' 'LDFLAGS=-static -static-libgcc -static-libstdc++' 'LIBS=-Wl,-Bstatic -lwinpthread -Wl,-Bdynamic'"
grep: jq-1.8.1/src/main.o: binary file matches
jq-1.8.1/Makefile:601:LIBS = -lpthread -Wl,-Bstatic -lwinpthread -Wl,-Bdynamic
grep: jq-1.8.1/jq.exe: binary file matches
jq-1.8.1/config.log:87:configure:3318: x86_64-w64-mingw32-gcc -O2 -static -static-libgcc -static-libstdc++ -static -static-libgcc -static-libstdc++ conftest.c -Wl,-Bstatic -lwinpthread -Wl,-Bdynamic >&5
jq-1.8.1/config.log:93:configure:3390: x86_64-w64-mingw32-gcc -o conftest.exe -O2 -static -static-libgcc -static-libstdc++ -static -static-libgcc -static-libstdc++ conftest.c -Wl,-Bstatic -lwinpthread -Wl,-Bdynamic >&5
jq-1.8.1/config.log:704:configure:14882: x86_64-w64-mingw32-gcc -o conftest.exe -O2 -static -static-libgcc -static-libstdc++ -static -static-libgcc -static-libstdc++ conftest.c -Wl,-Bstatic -lwinpthread -Wl,-Bdynamic >&5
jq-1.8.1/config.log:875:configure:15496: x86_64-w64-mingw32-gcc -o conftest.exe -O2 -static -static-libgcc -static-libstdc++ -pthread -static -static-libgcc -static-libstdc++ conftest.c -lpthread -Wl,-Bstatic -lwinpthread -Wl,-Bdynamic >&5
jq-1.8.1/config.log:879:configure:15648: x86_64-w64-mingw32-gcc -o conftest.exe -O2 -static -static-libgcc -static-libstdc++ -pthread -static -static-libgcc -static-libstdc++ conftest.c -lpthread -Wl,-Bstatic -lwinpthread -Wl,-Bdynamic >&5
jq-1.8.1/config.log:885:configure:15711: x86_64-w64-mingw32-gcc -o conftest.exe -O2 -static -static-libgcc -static-libstdc++ -pthread -static -static-libgcc -static-libstdc++ conftest.c -lpthread -Wl,-Bstatic -lwinpthread -Wl,-Bdynamic >&5
jq-1.8.1/config.log:978:configure:15932: x86_64-w64-mingw32-gcc -o conftest.exe -O2 -static -static-libgcc -static-libstdc++ -pthread -static -static-libgcc -static-libstdc++ conftest.c -lpthread -Wl,-Bstatic -lwinpthread -Wl,-Bdynamic >&5
jq-1.8.1/config.log:1038:configure:15985: x86_64-w64-mingw32-gcc -o conftest.exe -O2 -static -static-libgcc -static-libstdc++ -pthread -static -static-libgcc -static-libstdc++ conftest.c -lpthread -Wl,-Bstatic -lwinpthread -Wl,-Bdynamic >&5
jq-1.8.1/config.log:1042:configure:16095: x86_64-w64-mingw32-gcc -o conftest.exe -O2 -static -static-libgcc -static-libstdc++ -pthread -static -static-libgcc -static-libstdc++ conftest.c -lpthread -Wl,-Bstatic -lwinpthread -Wl,-Bdynamic >&5
jq-1.8.1/config.log:1046:configure:16193: x86_64-w64-mingw32-gcc -o conftest.exe -O2 -static -static-libgcc -static-libstdc++ -pthread -static -static-libgcc -static-libstdc++ conftest.c -lpthread -Wl,-Bstatic -lwinpthread -Wl,-Bdynamic >&5
jq-1.8.1/config.log:1050:configure:16291: x86_64-w64-mingw32-gcc -o conf
[command output truncated]
4-mingw32-gcc -o conftest.exe -O2 -static -static-libgcc -static-libstdc++ -static -static-libgcc -static-libstdc++ conftest.c -Wl,-Bstatic -lwinpthread -Wl,-Bdynamic >&5
jq-1.8.1/vendor/oniguruma/config.log:1629:ac_cv_env_LIBS_value='-Wl,-Bstatic -lwinpthread -Wl,-Bdynamic'
jq-1.8.1/vendor/oniguruma/config.log:1762:LIBS='-Wl,-Bstatic -lwinpthread -Wl,-Bdynamic'
jq-1.8.1/vendor/oniguruma/config.status:423:ac_cs_config='--disable-option-checking --prefix=/usr/local --host=x86_64-w64-mingw32 --build=x86_64-pc-linux-gnu --disable-shared --enable-static --with-oniguruma=builtin build_alias=x86_64-pc-linux-gnu host_alias=x86_64-w64-mingw32 CC=x86_64-w64-mingw32-gcc '\''CFLAGS=-O2 -static -static-libgcc -static-libstdc++'\'' '\''LDFLAGS=-static -static-libgcc -static-libstdc++'\'' '\''LIBS=-Wl,-Bstatic -lwinpthread -Wl,-Bdynamic'\'' --cache-file=/dev/null --srcdir=.'
jq-1.8.1/vendor/oniguruma/config.status:515: set X /bin/bash './configure' '--disable-option-checking' '--prefix=/usr/local' '--host=x86_64-w64-mingw32' '--build=x86_64-pc-linux-gnu' '--disable-shared' '--enable-static' '--with-oniguruma=builtin' 'build_alias=x86_64-pc-linux-gnu' 'host_alias=x86_64-w64-mingw32' 'CC=x86_64-w64-mingw32-gcc' 'CFLAGS=-O2 -static -static-libgcc -static-libstdc++' 'LDFLAGS=-static -static-libgcc -static-libstdc++' 'LIBS=-Wl,-Bstatic -lwinpthread -Wl,-Bdynamic' '--cache-file=/dev/null' '--srcdir=.' $ac_configure_extra_args --no-create --no-recursion
jq-1.8.1/vendor/oniguruma/config.status:925:S["LIBS"]="-Wl,-Bstatic -lwinpthread -Wl,-Bdynamic"
jq-1.8.1/.libs/libjq.lai:20:dependency_libs=' -L./vendor/oniguruma/src -lshlwapi /usr/local/lib/libonig.la -lpthread -lwinpthread'
jq-1.8.1/.libs/libjq.la:20:dependency_libs=' -L./vendor/oniguruma/src -lshlwapi /home/peter/jq-1.8.1/vendor/oniguruma/src/.libs/libonig.la -lpthread -lwinpthread'
jq-1.8.1/config.status:418:ac_cs_config='--host=x86_64-w64-mingw32 --build=x86_64-pc-linux-gnu --disable-shared --enable-static --with-oniguruma=builtin build_alias=x86_64-pc-linux-gnu host_alias=x86_64-w64-mingw32 CC=x86_64-w64-mingw32-gcc '\''CFLAGS=-O2 -static -static-libgcc -static-libstdc++'\'' '\''LDFLAGS=-static -static-libgcc -static-libstdc++'\'' '\''LIBS=-Wl,-Bstatic -lwinpthread -Wl,-Bdynamic'\'''
jq-1.8.1/config.status:499: set X /bin/bash './configure' '--host=x86_64-w64-mingw32' '--build=x86_64-pc-linux-gnu' '--disable-shared' '--enable-static' '--with-oniguruma=builtin' 'build_alias=x86_64-pc-linux-gnu' 'host_alias=x86_64-w64-mingw32' 'CC=x86_64-w64-mingw32-gcc' 'CFLAGS=-O2 -static -static-libgcc -static-libstdc++' 'LDFLAGS=-static -static-libgcc -static-libstdc++' 'LIBS=-Wl,-Bstatic -lwinpthread -Wl,-Bdynamic' $ac_configure_extra_args --no-create --no-recursion
jq-1.8.1/config.status:948:S["LIBS"]="-lpthread -Wl,-Bstatic -lwinpthread -Wl,-Bdynamic"
jq-1.8.1/libjq.la:20:dependency_libs=' -L./vendor/oniguruma/src -lshlwapi /home/peter/jq-1.8.1/vendor/oniguruma/src/.libs/libonig.la -lpthread -lwinpthread'
↓ 29 lines
jq-1.8.1/src/config_opts.inc:1:#define JQ_CONFIG "--host=x86_64-w64-mingw32 --build=x86_64-pc-linux-gnu --disable-shared --enable-static --with-oniguruma=builtin build_alias=x86_64-pc-linux-gnu host_alias=x86_64-w64-mingw32 CC=x86_64-w64-mingw32-gcc 'CFLAGS=-O2 -static -static-libgcc -static-libstdc++' 'LDFLAGS=-static -static-libgcc -static-libstdc++' 'LIBS=-Wl,-Bstatic -lwinpthread -Wl,-Bdynamic'" grep: jq-1.8.1/src/main.o: binary file matches jq-1.8.1/Makefile:601:LIBS = -lpthread -Wl,-Bstatic -lwinpthread -Wl,-Bdynamic grep: jq-1.8.1/jq.exe: binary file matches jq-1.8.1/config.log:87:configure:3318: x86_64-w64-mingw32-gcc -O2 -static -static-libgcc -static-libstdc++ -static -static-libgcc -static-libstdc++ conftest.c -Wl,-Bstatic -lwinpthread -Wl,-Bdynamic >&5 jq-1.8.1/config.log:93:configure:3390: x86_64-w64-mingw32-gcc -o conftest.exe -O2 -static -static-libgcc -static-libstdc++ -static -static-libgcc -static-libstdc++ conftest.c -Wl,-Bstatic -lwinpthread -Wl,-Bdynamic >&5 jq-1.8.1/config.log:704:configure:14882: x86_64-w64-mingw32-gcc -o conftest.exe -O2 -static -static-libgcc -static-libstdc++ -static -static-libgcc -static-libstdc++ conftest.c -Wl,-Bstatic -lwinpthread -Wl,-Bdynamic >&5 jq-1.8.1/config.log:875:configure:15496: x86_64-w64-mingw32-gcc -o conftest.exe -O2 -static -static-libgcc -static-libstdc++ -pthread -static -static-libgcc -static-libstdc++ conftest.c -lpthread -Wl,-Bstatic -lwinpthread -Wl,-Bdynamic >&5 jq-1.8.1/config.log:879:configure:15648: x86_64-w64-mingw32-gcc -o conftest.exe -O2 -static -static-libgcc -static-libstdc++ -pthread -static -static-libgcc -static-libstdc++ conftest.c -lpthread -Wl,-Bstatic -lwinpthread -Wl,-Bdynamic >&5 jq-1.8.1/config.log:885:configure:15711: x86_64-w64-mingw32-gcc -o conftest.exe -O2 -static -static-libgcc -static-libstdc++ -pthread -static -static-libgcc -static-libstdc++ conftest.c -lpthread -Wl,-Bstatic -lwinpthread -Wl,-Bdynamic >&5 jq-1.8.1/config.log:978:configure:15932: x86_64-w64-mingw32-gcc -o conftest.exe -O2 -static -static-libgcc -static-libstdc++ -pthread -static -static-libgcc -static-libstdc++ conftest.c -lpthread -Wl,-Bstatic -lwinpthread -Wl,-Bdynamic >&5 jq-1.8.1/config.log:1038:configure:15985: x86_64-w64-mingw32-gcc -o conftest.exe -O2 -static -static-libgcc -static-libstdc++ -pthread -static -static-libgcc -static-libstdc++ conftest.c -lpthread -Wl,-Bstatic -lwinpthread -Wl,-Bdynamic >&5 jq-1.8.1/config.log:1042:configure:16095: x86_64-w64-mingw32-gcc -o conftest.exe -O2 -static -static-libgcc -static-libstdc++ -pthread -static -static-libgcc -static-libstdc++ conftest.c -lpthread -Wl,-Bstatic -lwinpthread -Wl,-Bdynamic >&5 jq-1.8.1/config.log:1046:configure:16193: x86_64-w64-mingw32-gcc -o conftest.exe -O2 -static -static-libgcc -static-libstdc++ -pthread -static -static-libgcc -static-libstdc++ conftest.c -lpthread -Wl,-Bstatic -lwinpthread -Wl,-Bdynamic >&5 jq-1.8.1/config.log:1050:configure:16291: x86_64-w64-mingw32-gcc -o conf [command output truncated] 4-mingw32-gcc -o conftest.exe -O2 -static -static-libgcc -static-libstdc++ -static -static-libgcc -static-libstdc++ conftest.c -Wl,-Bstatic -lwinpthread -Wl,-Bdynamic >&5 jq-1.8.1/vendor/oniguruma/config.log:1629:ac_cv_env_LIBS_value='-Wl,-Bstatic -lwinpthread -Wl,-Bdynamic' jq-1.8.1/vendor/oniguruma/config.log:1762:LIBS='-Wl,-Bstatic -lwinpthread -Wl,-Bdynamic' jq-1.8.1/vendor/oniguruma/config.status:423:ac_cs_config='--disable-option-checking --prefix=/usr/local --host=x86_64-w64-mingw32 --build=x86_64-pc-linux-gnu --disable-shared --enable-static --with-oniguruma=builtin build_alias=x86_64-pc-linux-gnu host_alias=x86_64-w64-mingw32 CC=x86_64-w64-mingw32-gcc '\''CFLAGS=-O2 -static -static-libgcc -static-libstdc++'\'' '\''LDFLAGS=-static -static-libgcc -static-libstdc++'\'' '\''LIBS=-Wl,-Bstatic -lwinpthread -Wl,-Bdynamic'\'' --cache-file=/dev/null --srcdir=.' jq-1.8.1/vendor/oniguruma/config.status:515: set X /bin/bash './configure' '--disable-option-checking' '--prefix=/usr/local' '--host=x86_64-w64-mingw32' '--build=x86_64-pc-linux-gnu' '--disable-shared' '--enable-static' '--with-oniguruma=builtin' 'build_alias=x86_64-pc-linux-gnu' 'host_alias=x86_64-w64-mingw32' 'CC=x86_64-w64-mingw32-gcc' 'CFLAGS=-O2 -static -static-libgcc -static-libstdc++' 'LDFLAGS=-static -static-libgcc -static-libstdc++' 'LIBS=-Wl,-Bstatic -lwinpthread -Wl,-Bdynamic' '--cache-file=/dev/null' '--srcdir=.' $ac_configure_extra_args --no-create --no-recursion jq-1.8.1/vendor/oniguruma/config.status:925:S["LIBS"]="-Wl,-Bstatic -lwinpthread -Wl,-Bdynamic" jq-1.8.1/.libs/libjq.lai:20:dependency_libs=' -L./vendor/oniguruma/src -lshlwapi /usr/local/lib/libonig.la -lpthread -lwinpthread' jq-1.8.1/.libs/libjq.la:20:dependency_libs=' -L./vendor/oniguruma/src -lshlwapi /home/peter/jq-1.8.1/vendor/oniguruma/src/.libs/libonig.la -lpthread -lwinpthread' jq-1.8.1/config.status:418:ac_cs_config='--host=x86_64-w64-mingw32 --build=x86_64-pc-linux-gnu --disable-shared --enable-static --with-oniguruma=builtin build_alias=x86_64-pc-linux-gnu host_alias=x86_64-w64-mingw32 CC=x86_64-w64-mingw32-gcc '\''CFLAGS=-O2 -static -static-libgcc -static-libstdc++'\'' '\''LDFLAGS=-static -static-libgcc -static-libstdc++'\'' '\''LIBS=-Wl,-Bstatic -lwinpthread -Wl,-Bdynamic'\''' jq-1.8.1/config.status:499: set X /bin/bash './configure' '--host=x86_64-w64-mingw32' '--build=x86_64-pc-linux-gnu' '--disable-shared' '--enable-static' '--with-oniguruma=builtin' 'build_alias=x86_64-pc-linux-gnu' 'host_alias=x86_64-w64-mingw32' 'CC=x86_64-w64-mingw32-gcc' 'CFLAGS=-O2 -static -static-libgcc -static-libstdc++' 'LDFLAGS=-static -static-libgcc -static-libstdc++' 'LIBS=-Wl,-Bstatic -lwinpthread -Wl,-Bdynamic' $ac_configure_extra_args --no-create --no-recursion jq-1.8.1/config.status:948:S["LIBS"]="-lpthread -Wl,-Bstatic -lwinpthread -Wl,-Bdynamic" jq-1.8.1/libjq.la:20:dependency_libs=' -L./vendor/oniguruma/src -lshlwapi /home/peter/jq-1.8.1/vendor/oniguruma/src/.libs/libonig.la -lpthread -lwinpthread'
Show reasoning
Analyzing pthread linkage in Makefile
compile-bench> sed -n '1,160p' jq-1.8.1/src/jv_thread.h #ifndef JV_THREAD_H
#define JV_THREAD_H
#ifdef WIN32
#ifndef __MINGW32__
#include <windows.h>
#include <winnt.h>
#include <errno.h>
/* Copied from Heimdal: pthread-like mutexes for WIN32 -- see lib/base/heimbase.h in Heimdal */
typedef struct pthread_mutex {
HANDLE h;
} pthread_mutex_t;
#define PTHREAD_MUTEX_INITIALIZER { INVALID_HANDLE_VALUE }
static inline int
pthread_mutex_init(pthread_mutex_t *m)
{
m->h = CreateSemaphore(NULL, 1, 1, NULL);
if (m->h == INVALID_HANDLE_VALUE)
return EAGAIN;
return 0;
}
static inline int
pthread_mutex_lock(pthread_mutex_t *m)
{
HANDLE h, new_h;
int created = 0;
h = InterlockedCompareExchangePointer(&m->h, m->h, m->h);
if (h == INVALID_HANDLE_VALUE || h == NULL) {
created = 1;
new_h = CreateSemaphore(NULL, 0, 1, NULL);
if (new_h == INVALID_HANDLE_VALUE)
return EAGAIN;
if (InterlockedCompareExchangePointer(&m->h, new_h, h) != h) {
created = 0;
CloseHandle(new_h);
}
}
if (!created)
WaitForSingleObject(m->h, INFINITE);
return 0;
}
static inline int
pthread_mutex_unlock(pthread_mutex_t *m)
{
if (ReleaseSemaphore(m->h, 1, NULL) == FALSE)
return EPERM;
return 0;
}
static inline int
pthread_mutex_destroy(pthread_mutex_t *m)
{
HANDLE h;
h = InterlockedCompareExchangePointer(&m->h, INVALID_HANDLE_VALUE, m->h);
if (h != INVALID_HANDLE_VALUE)
CloseHandle(h);
return 0;
}
typedef unsigned long pthread_key_t;
int pthread_key_create(pthread_key_t *, void (*)(void *));
int pthread_setspecific(pthread_key_t, void *);
void *pthread_getspecific(pthread_key_t);
#else
#include <pthread.h>
#endif
#else
#include <pthread.h>
#endif
#endif /* JV_THREAD_H */
↓ 77 lines
#ifndef JV_THREAD_H
#define JV_THREAD_H
#ifdef WIN32
#ifndef __MINGW32__
#include <windows.h>
#include <winnt.h>
#include <errno.h>
/* Copied from Heimdal: pthread-like mutexes for WIN32 -- see lib/base/heimbase.h in Heimdal */
typedef struct pthread_mutex {
HANDLE h;
} pthread_mutex_t;
#define PTHREAD_MUTEX_INITIALIZER { INVALID_HANDLE_VALUE }
static inline int
pthread_mutex_init(pthread_mutex_t *m)
{
m->h = CreateSemaphore(NULL, 1, 1, NULL);
if (m->h == INVALID_HANDLE_VALUE)
return EAGAIN;
return 0;
}
static inline int
pthread_mutex_lock(pthread_mutex_t *m)
{
HANDLE h, new_h;
int created = 0;
h = InterlockedCompareExchangePointer(&m->h, m->h, m->h);
if (h == INVALID_HANDLE_VALUE || h == NULL) {
created = 1;
new_h = CreateSemaphore(NULL, 0, 1, NULL);
if (new_h == INVALID_HANDLE_VALUE)
return EAGAIN;
if (InterlockedCompareExchangePointer(&m->h, new_h, h) != h) {
created = 0;
CloseHandle(new_h);
}
}
if (!created)
WaitForSingleObject(m->h, INFINITE);
return 0;
}
static inline int
pthread_mutex_unlock(pthread_mutex_t *m)
{
if (ReleaseSemaphore(m->h, 1, NULL) == FALSE)
return EPERM;
return 0;
}
static inline int
pthread_mutex_destroy(pthread_mutex_t *m)
{
HANDLE h;
h = InterlockedCompareExchangePointer(&m->h, INVALID_HANDLE_VALUE, m->h);
if (h != INVALID_HANDLE_VALUE)
CloseHandle(h);
return 0;
}
typedef unsigned long pthread_key_t;
int pthread_key_create(pthread_key_t *, void (*)(void *));
int pthread_setspecific(pthread_key_t, void *);
void *pthread_getspecific(pthread_key_t);
#else
#include <pthread.h>
#endif
#else
#include <pthread.h>
#endif
#endif /* JV_THREAD_H */
Show reasoning
Analyzing pthread usage and linking on Windows
[empty output]
Show reasoning
Forcing re-link to verify build
compile-bench> cd jq-1.8.1 && make -B jq.exe V=1 cd . && /bin/bash /home/peter/jq-1.8.1/config/missing automake-1.16 --foreign Makefile
CDPATH="${ZSH_VERSION+.}:" && cd . && /bin/bash '/home/peter/jq-1.8.1/config/missing' autoconf
/bin/bash ./config.status --recheck
running CONFIG_SHELL=/bin/bash /bin/bash ./configure --host=x86_64-w64-mingw32 --build=x86_64-pc-linux-gnu --disable-shared --enable-static --with-oniguruma=builtin build_alias=x86_64-pc-linux-gnu host_alias=x86_64-w64-mingw32 CC=x86_64-w64-mingw32-gcc CFLAGS=-O2 -static -static-libgcc -static-libstdc++ LDFLAGS=-static -static-libgcc -static-libstdc++ LIBS=-Wl,-Bstatic -lwinpthread -Wl,-Bdynamic --no-create --no-recursion
checking for x86_64-w64-mingw32-gcc... x86_64-w64-mingw32-gcc
checking whether the C compiler works... yes
checking for C compiler default output file name... a.exe
checking for suffix of executables... .exe
checking whether we are cross compiling... yes
checking for suffix of object files... o
checking whether the compiler supports GNU C... yes
checking whether x86_64-w64-mingw32-gcc accepts -g... yes
checking for x86_64-w64-mingw32-gcc option to enable C11 features... none needed
checking whether x86_64-w64-mingw32-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 x86_64-w64-mingw32-strip... x86_64-w64-mingw32-strip
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 x86_64-w64-mingw32-gcc... gcc3
checking whether make supports nested variables... (cached) yes
checking for x86_64-w64-mingw32-ar... x86_64-w64-mingw32-ar
checking the archiver (x86_64-w64-mingw32-ar) interface... ar
checking whether to enable maintainer-specific portions of Makefiles... no
checking for x86_64-w64-mingw32-gcc... (cached) x86_64-w64-mingw32-gcc
checking whether the compiler supports GNU C... (cached) yes
checking whether x86_64-w64-mingw32-gcc accepts -g... (cached) yes
checking for x86_64-w64-mingw32-gcc option to enable C11 features... (cached) none needed
checking whether x86_64-w64-mingw32-gcc understands -c and -o together... (cached) yes
checking how to run the C preprocessor... x86_64-w64-mingw32-gcc -E
checking for bison... no
checking for byacc... no
checking build system type...
[command output truncated]
INT=1 -DHAVE_NEXTAFTER=1 -DHAVE_NEXTTOWARD=1 -DHAVE_POW=1 -DHAVE_REMAINDER=1 -DHAVE_RINT=1 -DHAVE_ROUND=1 -DHAVE_SCALBLN=1 -DHAVE_SCALBN=1 -DHAVE_ILOGB=1 -DHAVE_SIN=1 -DHAVE_SINH=1 -DHAVE_SQRT=1 -DHAVE_TAN=1 -DHAVE_TANH=1 -DHAVE_TGAMMA=1 -DHAVE_TRUNC=1 -DHAVE_Y0=1 -DHAVE_Y1=1 -DHAVE_YN=1 -DHAVE___THREAD=1 -DIEEE_8087=1 -DHAVE_LIBONIG=1 -I. -I./src -I./vendor -Wextra -Wall -Wno-unused-parameter -Wno-unused-function -Woverlength-strings -Wstrict-prototypes -municode -I./vendor/oniguruma/src -O2 -static-libgcc -static-libstdc++ -pthread -MT src/parser.lo -MD -MP -MF src/.deps/parser.Tpo -c src/parser.c -o src/parser.o
/bin/bash ./libtool --tag=CC --mode=link x86_64-w64-mingw32-gcc -Wextra -Wall -Wno-unused-parameter -Wno-unused-function -Woverlength-strings -Wstrict-prototypes -municode -I./vendor/oniguruma/src -O2 -static -static-libgcc -static-libstdc++ -pthread -L./vendor/oniguruma/src -Wl,-rpath,/usr/local/lib -export-symbols-regex '^j[qv]_' -version-info 1:4:0 -no-undefined -static -static-libgcc -static-libstdc++ -o libjq.la -rpath /usr/local/lib src/builtin.lo src/bytecode.lo src/compile.lo src/execute.lo src/jq_test.lo src/jv.lo src/jv_alloc.lo src/jv_aux.lo src/jv_dtoa.lo src/jv_file.lo src/jv_parse.lo src/jv_print.lo src/jv_unicode.lo src/linker.lo src/locfile.lo src/util.lo src/jv_dtoa_tsd.lo vendor/decNumber/decContext.lo vendor/decNumber/decNumber.lo src/lexer.lo src/parser.lo -lm -lshlwapi vendor/oniguruma/src/.libs/libonig.la -lpthread -Wl,-Bstatic -lwinpthread -Wl,-Bdynamic
libtool: link: rm -fr .libs/libjq.a .libs/libjq.la .libs/libjq.lai
libtool: link: x86_64-w64-mingw32-ar cr .libs/libjq.a src/builtin.o src/bytecode.o src/compile.o src/execute.o src/jq_test.o src/jv.o src/jv_alloc.o src/jv_aux.o src/jv_dtoa.o src/jv_file.o src/jv_parse.o src/jv_print.o src/jv_unicode.o src/linker.o src/locfile.o src/util.o src/jv_dtoa_tsd.o vendor/decNumber/decContext.o vendor/decNumber/decNumber.o src/lexer.o src/parser.o
libtool: link: x86_64-w64-mingw32-ranlib .libs/libjq.a
libtool: link: ( cd ".libs" && rm -f "libjq.la" && ln -s "../libjq.la" "libjq.la" )
/bin/bash ./libtool --tag=CC --mode=link x86_64-w64-mingw32-gcc -Wextra -Wall -Wno-unused-parameter -Wno-unused-function -Woverlength-strings -Wstrict-prototypes -municode -I./vendor/oniguruma/src -O2 -static -static-libgcc -static-libstdc++ -pthread -static -static-libgcc -static-libstdc++ -o jq.exe src/main.o libjq.la -lm vendor/oniguruma/src/.libs/libonig.la -lpthread -Wl,-Bstatic -lwinpthread -Wl,-Bdynamic
libtool: link: x86_64-w64-mingw32-gcc -Wextra -Wall -Wno-unused-parameter -Wno-unused-function -Woverlength-strings -Wstrict-prototypes -municode -I./vendor/oniguruma/src -O2 -static-libgcc -static-libstdc++ -static-libgcc -static-libstdc++ -o jq.exe src/main.o -Wl,-Bstatic -Wl,-Bdynamic ./.libs/libjq.a -L./vendor/oniguruma/src -lshlwapi /home/peter/jq-1.8.1/vendor/oniguruma/src/.libs/libonig.a vendor/oniguruma/src/.libs/libonig.a -lpthread -lwinpthread -pthread
↓ 60 lines
cd . && /bin/bash /home/peter/jq-1.8.1/config/missing automake-1.16 --foreign Makefile
CDPATH="${ZSH_VERSION+.}:" && cd . && /bin/bash '/home/peter/jq-1.8.1/config/missing' autoconf
/bin/bash ./config.status --recheck
running CONFIG_SHELL=/bin/bash /bin/bash ./configure --host=x86_64-w64-mingw32 --build=x86_64-pc-linux-gnu --disable-shared --enable-static --with-oniguruma=builtin build_alias=x86_64-pc-linux-gnu host_alias=x86_64-w64-mingw32 CC=x86_64-w64-mingw32-gcc CFLAGS=-O2 -static -static-libgcc -static-libstdc++ LDFLAGS=-static -static-libgcc -static-libstdc++ LIBS=-Wl,-Bstatic -lwinpthread -Wl,-Bdynamic --no-create --no-recursion
checking for x86_64-w64-mingw32-gcc... x86_64-w64-mingw32-gcc
checking whether the C compiler works... yes
checking for C compiler default output file name... a.exe
checking for suffix of executables... .exe
checking whether we are cross compiling... yes
checking for suffix of object files... o
checking whether the compiler supports GNU C... yes
checking whether x86_64-w64-mingw32-gcc accepts -g... yes
checking for x86_64-w64-mingw32-gcc option to enable C11 features... none needed
checking whether x86_64-w64-mingw32-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 x86_64-w64-mingw32-strip... x86_64-w64-mingw32-strip
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 x86_64-w64-mingw32-gcc... gcc3
checking whether make supports nested variables... (cached) yes
checking for x86_64-w64-mingw32-ar... x86_64-w64-mingw32-ar
checking the archiver (x86_64-w64-mingw32-ar) interface... ar
checking whether to enable maintainer-specific portions of Makefiles... no
checking for x86_64-w64-mingw32-gcc... (cached) x86_64-w64-mingw32-gcc
checking whether the compiler supports GNU C... (cached) yes
checking whether x86_64-w64-mingw32-gcc accepts -g... (cached) yes
checking for x86_64-w64-mingw32-gcc option to enable C11 features... (cached) none needed
checking whether x86_64-w64-mingw32-gcc understands -c and -o together... (cached) yes
checking how to run the C preprocessor... x86_64-w64-mingw32-gcc -E
checking for bison... no
checking for byacc... no
checking build system type...
[command output truncated]
INT=1 -DHAVE_NEXTAFTER=1 -DHAVE_NEXTTOWARD=1 -DHAVE_POW=1 -DHAVE_REMAINDER=1 -DHAVE_RINT=1 -DHAVE_ROUND=1 -DHAVE_SCALBLN=1 -DHAVE_SCALBN=1 -DHAVE_ILOGB=1 -DHAVE_SIN=1 -DHAVE_SINH=1 -DHAVE_SQRT=1 -DHAVE_TAN=1 -DHAVE_TANH=1 -DHAVE_TGAMMA=1 -DHAVE_TRUNC=1 -DHAVE_Y0=1 -DHAVE_Y1=1 -DHAVE_YN=1 -DHAVE___THREAD=1 -DIEEE_8087=1 -DHAVE_LIBONIG=1 -I. -I./src -I./vendor -Wextra -Wall -Wno-unused-parameter -Wno-unused-function -Woverlength-strings -Wstrict-prototypes -municode -I./vendor/oniguruma/src -O2 -static-libgcc -static-libstdc++ -pthread -MT src/parser.lo -MD -MP -MF src/.deps/parser.Tpo -c src/parser.c -o src/parser.o
/bin/bash ./libtool --tag=CC --mode=link x86_64-w64-mingw32-gcc -Wextra -Wall -Wno-unused-parameter -Wno-unused-function -Woverlength-strings -Wstrict-prototypes -municode -I./vendor/oniguruma/src -O2 -static -static-libgcc -static-libstdc++ -pthread -L./vendor/oniguruma/src -Wl,-rpath,/usr/local/lib -export-symbols-regex '^j[qv]_' -version-info 1:4:0 -no-undefined -static -static-libgcc -static-libstdc++ -o libjq.la -rpath /usr/local/lib src/builtin.lo src/bytecode.lo src/compile.lo src/execute.lo src/jq_test.lo src/jv.lo src/jv_alloc.lo src/jv_aux.lo src/jv_dtoa.lo src/jv_file.lo src/jv_parse.lo src/jv_print.lo src/jv_unicode.lo src/linker.lo src/locfile.lo src/util.lo src/jv_dtoa_tsd.lo vendor/decNumber/decContext.lo vendor/decNumber/decNumber.lo src/lexer.lo src/parser.lo -lm -lshlwapi vendor/oniguruma/src/.libs/libonig.la -lpthread -Wl,-Bstatic -lwinpthread -Wl,-Bdynamic
libtool: link: rm -fr .libs/libjq.a .libs/libjq.la .libs/libjq.lai
libtool: link: x86_64-w64-mingw32-ar cr .libs/libjq.a src/builtin.o src/bytecode.o src/compile.o src/execute.o src/jq_test.o src/jv.o src/jv_alloc.o src/jv_aux.o src/jv_dtoa.o src/jv_file.o src/jv_parse.o src/jv_print.o src/jv_unicode.o src/linker.o src/locfile.o src/util.o src/jv_dtoa_tsd.o vendor/decNumber/decContext.o vendor/decNumber/decNumber.o src/lexer.o src/parser.o
libtool: link: x86_64-w64-mingw32-ranlib .libs/libjq.a
libtool: link: ( cd ".libs" && rm -f "libjq.la" && ln -s "../libjq.la" "libjq.la" )
/bin/bash ./libtool --tag=CC --mode=link x86_64-w64-mingw32-gcc -Wextra -Wall -Wno-unused-parameter -Wno-unused-function -Woverlength-strings -Wstrict-prototypes -municode -I./vendor/oniguruma/src -O2 -static -static-libgcc -static-libstdc++ -pthread -static -static-libgcc -static-libstdc++ -o jq.exe src/main.o libjq.la -lm vendor/oniguruma/src/.libs/libonig.la -lpthread -Wl,-Bstatic -lwinpthread -Wl,-Bdynamic
libtool: link: x86_64-w64-mingw32-gcc -Wextra -Wall -Wno-unused-parameter -Wno-unused-function -Woverlength-strings -Wstrict-prototypes -municode -I./vendor/oniguruma/src -O2 -static-libgcc -static-libstdc++ -static-libgcc -static-libstdc++ -o jq.exe src/main.o -Wl,-Bstatic -Wl,-Bdynamic ./.libs/libjq.a -L./vendor/oniguruma/src -lshlwapi /home/peter/jq-1.8.1/vendor/oniguruma/src/.libs/libonig.a vendor/oniguruma/src/.libs/libonig.a -lpthread -lwinpthread -pthread
Show reasoning
Analyzing static linking with libtool
I'm working through how libtool handles static versus dynamic linking, especially with pthread libraries on Windows. It looks like libtool inserts -lwinpthread dynamically despite passing -Wl,-Bstatic. I’m thinking about overriding this by setting environment variables like PTHREAD_LIBS to force static linking with -Wl,-Bstatic -lwinpthread -Wl,-Bdynamic and clearing PTHREAD_CFLAGS to avoid -pthread. Cleaning with make distclean before reconfiguring should help test this approach.
compile-bench> cd jq-1.8.1 && make distclean Making distclean in vendor/oniguruma
make[1]: Entering directory '/home/peter/jq-1.8.1/vendor/oniguruma'
Making distclean in src
make[2]: Entering directory '/home/peter/jq-1.8.1/vendor/oniguruma/src'
test -z "libonig.la" || rm -f libonig.la
rm -f ./so_locations
rm -rf .libs _libs
rm -f *.o
rm -f *.lo
rm -f *.tab.c
test -z "" || rm -f
test . = "." || test -z "" || rm -f
rm -f config.h stamp-h1
rm -f TAGS ID GTAGS GRTAGS GSYMS GPATH tags
rm -f ./.deps/ascii.Plo
rm -f ./.deps/big5.Plo
rm -f ./.deps/cp1251.Plo
rm -f ./.deps/euc_jp.Plo
rm -f ./.deps/euc_jp_prop.Plo
rm -f ./.deps/euc_kr.Plo
rm -f ./.deps/euc_tw.Plo
rm -f ./.deps/gb18030.Plo
rm -f ./.deps/iso8859_1.Plo
rm -f ./.deps/iso8859_10.Plo
rm -f ./.deps/iso8859_11.Plo
rm -f ./.deps/iso8859_13.Plo
rm -f ./.deps/iso8859_14.Plo
rm -f ./.deps/iso8859_15.Plo
rm -f ./.deps/iso8859_16.Plo
rm -f ./.deps/iso8859_2.Plo
rm -f ./.deps/iso8859_3.Plo
rm -f ./.deps/iso8859_4.Plo
rm -f ./.deps/iso8859_5.Plo
rm -f ./.deps/iso8859_6.Plo
rm -f ./.deps/iso8859_7.Plo
rm -f ./.deps/iso8859_8.Plo
rm -f ./.deps/iso8859_9.Plo
rm -f ./.deps/koi8_r.Plo
rm -f ./.deps/onig_init.Plo
rm -f ./.deps/regcomp.Plo
rm -f ./.deps/regenc.Plo
rm -f ./.deps/regerror.Plo
rm -f ./.deps/regexec.Plo
rm -f ./.deps/regext.Plo
rm -f ./.deps/reggnu.Plo
rm -f ./.deps/regparse.Plo
rm -f ./.deps/regposerr.Plo
rm -f ./.deps/regposix.Plo
rm -f ./.deps/regsyntax.Plo
rm -f ./.deps/regtrav.Plo
rm -f ./.deps/regversion.Plo
rm -f ./.deps/sjis.Plo
rm -f ./.deps/sjis_prop.Plo
rm -f ./.deps/st.Plo
rm -f ./.deps/unicode.Plo
rm -f ./.deps/unicode_fold1_key.Plo
rm -f ./.deps/unicode_fold2_key.Plo
rm -f ./.deps/unicode_fold3_key.Plo
rm -f ./.deps/unicode_unfold_key.Plo
rm -f ./.deps/utf16_be.Plo
rm -f ./.deps/utf16_le.Plo
rm -f ./.deps/utf32_be.Plo
rm -f ./.deps/utf32_le.Plo
rm -f ./.deps/utf8.Plo
rm -f Makefile
make[2]: Leaving directory '/home/peter/jq-1.8.1/vendor/oniguruma/src'
Making distclean in test
make[2]: Entering directory '/home/peter/jq-1.8.1/vendor/oniguruma/test'
rm -f test_utf8.exe test_syntax.exe test_options.exe testc.exe testcu.exe test_regset.exe test_back.exe
rm -f test_utf8 test_syntax test_options testc testcu test_regset test_back
[command output truncated]
rm -f Makefile
make[2]: Leaving directory '/home/peter/jq-1.8.1/vendor/oniguruma/sample'
make[2]: Entering directory '/home/peter/jq-1.8.1/vendor/oniguruma'
rm -rf .libs _libs
rm -f *.lo
test -z "onig-config" || rm -f onig-config
test . = "." || test -z "" || rm -f
test -z "oniguruma.pc" || rm -f oniguruma.pc
rm -f libtool config.lt
rm -f TAGS ID GTAGS GRTAGS GSYMS GPATH tags
rm -f cscope.out cscope.in.out cscope.po.out cscope.files
make[2]: Leaving directory '/home/peter/jq-1.8.1/vendor/oniguruma'
rm -f config.status config.cache config.log configure.lineno config.status.lineno
rm -f Makefile
make[1]: Leaving directory '/home/peter/jq-1.8.1/vendor/oniguruma'
make[1]: Entering directory '/home/peter/jq-1.8.1'
rm -f jq.exe
rm -f jq
test -z "src/version.h .remake-version-h src/builtin.inc src/config_opts.inc jq.1" || rm -f src/version.h .remake-version-h src/builtin.inc src/config_opts.inc jq.1
test -z "libjq.la " || rm -f libjq.la
rm -f ./so_locations
rm -rf .libs _libs
rm -rf src/.libs src/_libs
rm -rf vendor/decNumber/.libs vendor/decNumber/_libs
rm -f *.o
rm -f src/*.o
rm -f src/*.lo
rm -f vendor/decNumber/*.o
rm -f vendor/decNumber/*.lo
test -z "tests/mantest.log tests/jqtest.log tests/shtest.log tests/utf8test.log tests/base64test.log tests/uritest.log tests/onigtest.log tests/manonigtest.log" || rm -f tests/mantest.log tests/jqtest.log tests/shtest.log tests/utf8test.log tests/base64test.log tests/uritest.log tests/onigtest.log tests/manonigtest.log
test -z "tests/mantest.trs tests/jqtest.trs tests/shtest.trs tests/utf8test.trs tests/base64test.trs tests/uritest.trs tests/onigtest.trs tests/manonigtest.trs" || rm -f tests/mantest.trs tests/jqtest.trs tests/shtest.trs tests/utf8test.trs tests/base64test.trs tests/uritest.trs tests/onigtest.trs tests/manonigtest.trs
test -z "test-suite.log" || rm -f test-suite.log
rm -f *.lo
rm -f *.tab.c
test -z "libjq.pc" || rm -f libjq.pc
test . = "." || test -z "" || rm -f
rm -f src/.deps/.dirstamp
rm -f src/.dirstamp
rm -f vendor/decNumber/.deps/.dirstamp
rm -f vendor/decNumber/.dirstamp
rm -f libtool config.lt
rm -f TAGS ID GTAGS GRTAGS GSYMS GPATH tags
rm -f cscope.out cscope.in.out cscope.po.out cscope.files
make[1]: Leaving directory '/home/peter/jq-1.8.1'
rm -f config.status config.cache config.log configure.lineno config.status.lineno
rm -f src/.deps/builtin.Plo
rm -f src/.deps/bytecode.Plo
rm -f src/.deps/compile.Plo
rm -f src/.deps/execute.Plo
rm -f src/.deps/inject_errors.Plo
rm -f src/.deps/jq_test.Plo
rm -f src/.deps/jv.Plo
rm -f src/.deps/jv_alloc.Plo
rm -f src/.deps/jv_aux.Plo
rm -f src/.deps/jv_dtoa.Plo
rm -f src/.deps/jv_dtoa_tsd.Plo
rm -f src/.deps/jv_file.Plo
rm -f src/.deps/jv_parse.Plo
rm -f src/.deps/jv_print.Plo
rm -f src/.deps/jv_unicode.Plo
rm -f src/.deps/lexer.Plo
rm -f src/.deps/linker.Plo
rm -f src/.deps/locfile.Plo
rm -f src/.deps/main.Po
rm -f src/.deps/parser.Plo
rm -f src/.deps/util.Plo
rm -f vendor/decNumber/.deps/decContext.Plo
rm -f vendor/decNumber/.deps/decNumber.Plo
rm -f Makefile
↓ 141 lines
Making distclean in vendor/oniguruma make[1]: Entering directory '/home/peter/jq-1.8.1/vendor/oniguruma' Making distclean in src make[2]: Entering directory '/home/peter/jq-1.8.1/vendor/oniguruma/src' test -z "libonig.la" || rm -f libonig.la rm -f ./so_locations rm -rf .libs _libs rm -f *.o rm -f *.lo rm -f *.tab.c test -z "" || rm -f test . = "." || test -z "" || rm -f rm -f config.h stamp-h1 rm -f TAGS ID GTAGS GRTAGS GSYMS GPATH tags rm -f ./.deps/ascii.Plo rm -f ./.deps/big5.Plo rm -f ./.deps/cp1251.Plo rm -f ./.deps/euc_jp.Plo rm -f ./.deps/euc_jp_prop.Plo rm -f ./.deps/euc_kr.Plo rm -f ./.deps/euc_tw.Plo rm -f ./.deps/gb18030.Plo rm -f ./.deps/iso8859_1.Plo rm -f ./.deps/iso8859_10.Plo rm -f ./.deps/iso8859_11.Plo rm -f ./.deps/iso8859_13.Plo rm -f ./.deps/iso8859_14.Plo rm -f ./.deps/iso8859_15.Plo rm -f ./.deps/iso8859_16.Plo rm -f ./.deps/iso8859_2.Plo rm -f ./.deps/iso8859_3.Plo rm -f ./.deps/iso8859_4.Plo rm -f ./.deps/iso8859_5.Plo rm -f ./.deps/iso8859_6.Plo rm -f ./.deps/iso8859_7.Plo rm -f ./.deps/iso8859_8.Plo rm -f ./.deps/iso8859_9.Plo rm -f ./.deps/koi8_r.Plo rm -f ./.deps/onig_init.Plo rm -f ./.deps/regcomp.Plo rm -f ./.deps/regenc.Plo rm -f ./.deps/regerror.Plo rm -f ./.deps/regexec.Plo rm -f ./.deps/regext.Plo rm -f ./.deps/reggnu.Plo rm -f ./.deps/regparse.Plo rm -f ./.deps/regposerr.Plo rm -f ./.deps/regposix.Plo rm -f ./.deps/regsyntax.Plo rm -f ./.deps/regtrav.Plo rm -f ./.deps/regversion.Plo rm -f ./.deps/sjis.Plo rm -f ./.deps/sjis_prop.Plo rm -f ./.deps/st.Plo rm -f ./.deps/unicode.Plo rm -f ./.deps/unicode_fold1_key.Plo rm -f ./.deps/unicode_fold2_key.Plo rm -f ./.deps/unicode_fold3_key.Plo rm -f ./.deps/unicode_unfold_key.Plo rm -f ./.deps/utf16_be.Plo rm -f ./.deps/utf16_le.Plo rm -f ./.deps/utf32_be.Plo rm -f ./.deps/utf32_le.Plo rm -f ./.deps/utf8.Plo rm -f Makefile make[2]: Leaving directory '/home/peter/jq-1.8.1/vendor/oniguruma/src' Making distclean in test make[2]: Entering directory '/home/peter/jq-1.8.1/vendor/oniguruma/test' rm -f test_utf8.exe test_syntax.exe test_options.exe testc.exe testcu.exe test_regset.exe test_back.exe rm -f test_utf8 test_syntax test_options testc testcu test_regset test_back [command output truncated] rm -f Makefile make[2]: Leaving directory '/home/peter/jq-1.8.1/vendor/oniguruma/sample' make[2]: Entering directory '/home/peter/jq-1.8.1/vendor/oniguruma' rm -rf .libs _libs rm -f *.lo test -z "onig-config" || rm -f onig-config test . = "." || test -z "" || rm -f test -z "oniguruma.pc" || rm -f oniguruma.pc rm -f libtool config.lt rm -f TAGS ID GTAGS GRTAGS GSYMS GPATH tags rm -f cscope.out cscope.in.out cscope.po.out cscope.files make[2]: Leaving directory '/home/peter/jq-1.8.1/vendor/oniguruma' rm -f config.status config.cache config.log configure.lineno config.status.lineno rm -f Makefile make[1]: Leaving directory '/home/peter/jq-1.8.1/vendor/oniguruma' make[1]: Entering directory '/home/peter/jq-1.8.1' rm -f jq.exe rm -f jq test -z "src/version.h .remake-version-h src/builtin.inc src/config_opts.inc jq.1" || rm -f src/version.h .remake-version-h src/builtin.inc src/config_opts.inc jq.1 test -z "libjq.la " || rm -f libjq.la rm -f ./so_locations rm -rf .libs _libs rm -rf src/.libs src/_libs rm -rf vendor/decNumber/.libs vendor/decNumber/_libs rm -f *.o rm -f src/*.o rm -f src/*.lo rm -f vendor/decNumber/*.o rm -f vendor/decNumber/*.lo test -z "tests/mantest.log tests/jqtest.log tests/shtest.log tests/utf8test.log tests/base64test.log tests/uritest.log tests/onigtest.log tests/manonigtest.log" || rm -f tests/mantest.log tests/jqtest.log tests/shtest.log tests/utf8test.log tests/base64test.log tests/uritest.log tests/onigtest.log tests/manonigtest.log test -z "tests/mantest.trs tests/jqtest.trs tests/shtest.trs tests/utf8test.trs tests/base64test.trs tests/uritest.trs tests/onigtest.trs tests/manonigtest.trs" || rm -f tests/mantest.trs tests/jqtest.trs tests/shtest.trs tests/utf8test.trs tests/base64test.trs tests/uritest.trs tests/onigtest.trs tests/manonigtest.trs test -z "test-suite.log" || rm -f test-suite.log rm -f *.lo rm -f *.tab.c test -z "libjq.pc" || rm -f libjq.pc test . = "." || test -z "" || rm -f rm -f src/.deps/.dirstamp rm -f src/.dirstamp rm -f vendor/decNumber/.deps/.dirstamp rm -f vendor/decNumber/.dirstamp rm -f libtool config.lt rm -f TAGS ID GTAGS GRTAGS GSYMS GPATH tags rm -f cscope.out cscope.in.out cscope.po.out cscope.files make[1]: Leaving directory '/home/peter/jq-1.8.1' rm -f config.status config.cache config.log configure.lineno config.status.lineno rm -f src/.deps/builtin.Plo rm -f src/.deps/bytecode.Plo rm -f src/.deps/compile.Plo rm -f src/.deps/execute.Plo rm -f src/.deps/inject_errors.Plo rm -f src/.deps/jq_test.Plo rm -f src/.deps/jv.Plo rm -f src/.deps/jv_alloc.Plo rm -f src/.deps/jv_aux.Plo rm -f src/.deps/jv_dtoa.Plo rm -f src/.deps/jv_dtoa_tsd.Plo rm -f src/.deps/jv_file.Plo rm -f src/.deps/jv_parse.Plo rm -f src/.deps/jv_print.Plo rm -f src/.deps/jv_unicode.Plo rm -f src/.deps/lexer.Plo rm -f src/.deps/linker.Plo rm -f src/.deps/locfile.Plo rm -f src/.deps/main.Po rm -f src/.deps/parser.Plo rm -f src/.deps/util.Plo rm -f vendor/decNumber/.deps/decContext.Plo rm -f vendor/decNumber/.deps/decNumber.Plo rm -f Makefile
Show reasoning
Preparing to rerun configure with static pthreads
compile-bench> cd jq-1.8.1 && CC=x86_64-w64-mingw32-gcc CXX=x86_64-w64-mingw32-g++ AR=x86_64-w64-mingw32-ar RANLIB=x86_64-w64-mingw32-ranlib STRIP=x86_64-w64-mingw32-strip CFLAGS="-O2 -static -static-libgcc -static-libstdc++" LDFLAGS="-static -static-libgcc -static-libstdc++" PTHREAD_LIBS="-Wl,-Bstatic -lwinpthread -Wl,-Bdynamic" PTHREAD_CFLAGS="" LIBS="-Wl,-Bstatic -lwinpthread -Wl,-Bdynamic" ./configure --host=x86_64-w64-mingw32 --build=x86_64-pc-linux-gnu --disable-shared --enable-static --with-oniguruma=builtin checking for x86_64-w64-mingw32-gcc... x86_64-w64-mingw32-gcc
checking whether the C compiler works... yes
checking for C compiler default output file name... a.exe
checking for suffix of executables... .exe
checking whether we are cross compiling... yes
checking for suffix of object files... o
checking whether the compiler supports GNU C... yes
checking whether x86_64-w64-mingw32-gcc accepts -g... yes
checking for x86_64-w64-mingw32-gcc option to enable C11 features... none needed
checking whether x86_64-w64-mingw32-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 x86_64-w64-mingw32-strip... x86_64-w64-mingw32-strip
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 x86_64-w64-mingw32-gcc... gcc3
checking whether make supports nested variables... (cached) yes
checking for x86_64-w64-mingw32-ar... x86_64-w64-mingw32-ar
checking the archiver (x86_64-w64-mingw32-ar) interface... ar
checking whether to enable maintainer-specific portions of Makefiles... no
checking for x86_64-w64-mingw32-gcc... (cached) x86_64-w64-mingw32-gcc
checking whether the compiler supports GNU C... (cached) yes
checking whether x86_64-w64-mingw32-gcc accepts -g... (cached) yes
checking for x86_64-w64-mingw32-gcc option to enable C11 features... (cached) none needed
checking whether x86_64-w64-mingw32-gcc understands -c and -o together... (cached) yes
checking how to run the C preprocessor... x86_64-w64-mingw32-gcc -E
checking for bison... no
checking for byacc... no
checking build system type... x86_64-pc-linux-gnu
checking host system type... x86_64-w64-mingw32
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 x86_64-w64-mingw32-gcc... /usr/bin/x86_64-w64-mingw32-ld
checking if the linker (/usr/bin/x86_64-w64-mingw32-ld) is GNU ld... yes
checking for BSD- or MS-compatible name lister (nm)... /usr/bin/x86_64-w64-mingw32-nm -B
checking the name lister (/usr/bin/x86_64-w64-mingw32-nm -B) interface... BSD n
[command output truncated]
efixed with host triplet
checking for x86_64-w64-mingw32-objdump... x86_64-w64-mingw32-objdump
checking how to recognize dependent libraries... file_magic ^x86 archive import|^x86 DLL
checking for x86_64-w64-mingw32-dlltool... x86_64-w64-mingw32-dlltool
checking how to associate runtime and link libraries... func_cygming_dll_for_implib
checking for x86_64-w64-mingw32-ar... x86_64-w64-mingw32-ar
checking for archiver @FILE support... @
checking for x86_64-w64-mingw32-strip... (cached) x86_64-w64-mingw32-strip
checking for x86_64-w64-mingw32-ranlib... x86_64-w64-mingw32-ranlib
checking command to parse /usr/bin/x86_64-w64-mingw32-nm -B output from x86_64-w64-mingw32-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 x86_64-w64-mingw32-mt... no
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... no
checking for objdir... .libs
checking if x86_64-w64-mingw32-gcc supports -fno-rtti -fno-exceptions... no
checking for x86_64-w64-mingw32-gcc option to produce PIC... -DDLL_EXPORT -DPIC
checking if x86_64-w64-mingw32-gcc PIC flag -DDLL_EXPORT -DPIC works... yes
checking if x86_64-w64-mingw32-gcc static flag -static works... yes
checking if x86_64-w64-mingw32-gcc supports -c -o file.o... yes
checking if x86_64-w64-mingw32-gcc supports -c -o file.o... (cached) yes
checking whether the x86_64-w64-mingw32-gcc linker (/usr/bin/x86_64-w64-mingw32-ld) supports shared libraries... yes
checking dynamic linker characteristics... Win32 ld.exe
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... no
checking size of int... 4
checking size of long... 4
checking size of long long... 8
checking size of void*... 8
checking for size_t... yes
checking for working alloca.h... no
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
↓ 120 lines
checking for x86_64-w64-mingw32-gcc... x86_64-w64-mingw32-gcc checking whether the C compiler works... yes checking for C compiler default output file name... a.exe checking for suffix of executables... .exe checking whether we are cross compiling... yes checking for suffix of object files... o checking whether the compiler supports GNU C... yes checking whether x86_64-w64-mingw32-gcc accepts -g... yes checking for x86_64-w64-mingw32-gcc option to enable C11 features... none needed checking whether x86_64-w64-mingw32-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 x86_64-w64-mingw32-strip... x86_64-w64-mingw32-strip 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 x86_64-w64-mingw32-gcc... gcc3 checking whether make supports nested variables... (cached) yes checking for x86_64-w64-mingw32-ar... x86_64-w64-mingw32-ar checking the archiver (x86_64-w64-mingw32-ar) interface... ar checking whether to enable maintainer-specific portions of Makefiles... no checking for x86_64-w64-mingw32-gcc... (cached) x86_64-w64-mingw32-gcc checking whether the compiler supports GNU C... (cached) yes checking whether x86_64-w64-mingw32-gcc accepts -g... (cached) yes checking for x86_64-w64-mingw32-gcc option to enable C11 features... (cached) none needed checking whether x86_64-w64-mingw32-gcc understands -c and -o together... (cached) yes checking how to run the C preprocessor... x86_64-w64-mingw32-gcc -E checking for bison... no checking for byacc... no checking build system type... x86_64-pc-linux-gnu checking host system type... x86_64-w64-mingw32 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 x86_64-w64-mingw32-gcc... /usr/bin/x86_64-w64-mingw32-ld checking if the linker (/usr/bin/x86_64-w64-mingw32-ld) is GNU ld... yes checking for BSD- or MS-compatible name lister (nm)... /usr/bin/x86_64-w64-mingw32-nm -B checking the name lister (/usr/bin/x86_64-w64-mingw32-nm -B) interface... BSD n [command output truncated] efixed with host triplet checking for x86_64-w64-mingw32-objdump... x86_64-w64-mingw32-objdump checking how to recognize dependent libraries... file_magic ^x86 archive import|^x86 DLL checking for x86_64-w64-mingw32-dlltool... x86_64-w64-mingw32-dlltool checking how to associate runtime and link libraries... func_cygming_dll_for_implib checking for x86_64-w64-mingw32-ar... x86_64-w64-mingw32-ar checking for archiver @FILE support... @ checking for x86_64-w64-mingw32-strip... (cached) x86_64-w64-mingw32-strip checking for x86_64-w64-mingw32-ranlib... x86_64-w64-mingw32-ranlib checking command to parse /usr/bin/x86_64-w64-mingw32-nm -B output from x86_64-w64-mingw32-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 x86_64-w64-mingw32-mt... no 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... no checking for objdir... .libs checking if x86_64-w64-mingw32-gcc supports -fno-rtti -fno-exceptions... no checking for x86_64-w64-mingw32-gcc option to produce PIC... -DDLL_EXPORT -DPIC checking if x86_64-w64-mingw32-gcc PIC flag -DDLL_EXPORT -DPIC works... yes checking if x86_64-w64-mingw32-gcc static flag -static works... yes checking if x86_64-w64-mingw32-gcc supports -c -o file.o... yes checking if x86_64-w64-mingw32-gcc supports -c -o file.o... (cached) yes checking whether the x86_64-w64-mingw32-gcc linker (/usr/bin/x86_64-w64-mingw32-ld) supports shared libraries... yes checking dynamic linker characteristics... Win32 ld.exe 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... no checking size of int... 4 checking size of long... 4 checking size of long long... 8 checking size of void*... 8 checking for size_t... yes checking for working alloca.h... no checking for alloca... yes checking that generated files are newer than configure... done configure: creating ./config.status config.status: creating Makefile config.status: creating src/Makefile config.status: creating test/Makefile config.status: creating sample/Makefile config.status: creating onig-config config.status: creating src/config.h config.status: executing depfiles commands config.status: executing libtool commands config.status: executing default commands
Show reasoning
Running parallel build command
compile-bench> cd jq-1.8.1 && make -j$(nproc) mkdir -p src
mkdir -p src
GEN src/builtin.inc
GEN src/config_opts.inc
mkdir -p src
GEN src/version.h
make all-recursive
make[1]: Entering directory '/home/peter/jq-1.8.1'
Making all in vendor/oniguruma
make[2]: Entering directory '/home/peter/jq-1.8.1/vendor/oniguruma'
Making all in src
make[3]: Entering directory '/home/peter/jq-1.8.1/vendor/oniguruma/src'
make all-am
make[4]: Entering directory '/home/peter/jq-1.8.1/vendor/oniguruma/src'
/bin/bash ../libtool --tag=CC --mode=compile x86_64-w64-mingw32-gcc -DHAVE_CONFIG_H -I. -I.. -Wall -O2 -static -static-libgcc -static-libstdc++ -MT regparse.lo -MD -MP -MF .deps/regparse.Tpo -c -o regparse.lo regparse.c
/bin/bash ../libtool --tag=CC --mode=compile x86_64-w64-mingw32-gcc -DHAVE_CONFIG_H -I. -I.. -Wall -O2 -static -static-libgcc -static-libstdc++ -MT regcomp.lo -MD -MP -MF .deps/regcomp.Tpo -c -o regcomp.lo regcomp.c
/bin/bash ../libtool --tag=CC --mode=compile x86_64-w64-mingw32-gcc -DHAVE_CONFIG_H -I. -I.. -Wall -O2 -static -static-libgcc -static-libstdc++ -MT regexec.lo -MD -MP -MF .deps/regexec.Tpo -c -o regexec.lo regexec.c
/bin/bash ../libtool --tag=CC --mode=compile x86_64-w64-mingw32-gcc -DHAVE_CONFIG_H -I. -I.. -Wall -O2 -static -static-libgcc -static-libstdc++ -MT regenc.lo -MD -MP -MF .deps/regenc.Tpo -c -o regenc.lo regenc.c
/bin/bash ../libtool --tag=CC --mode=compile x86_64-w64-mingw32-gcc -DHAVE_CONFIG_H -I. -I.. -Wall -O2 -static -static-libgcc -static-libstdc++ -MT regerror.lo -MD -MP -MF .deps/regerror.Tpo -c -o regerror.lo regerror.c
/bin/bash ../libtool --tag=CC --mode=compile x86_64-w64-mingw32-gcc -DHAVE_CONFIG_H -I. -I.. -Wall -O2 -static -static-libgcc -static-libstdc++ -MT regext.lo -MD -MP -MF .deps/regext.Tpo -c -o regext.lo regext.c
/bin/bash ../libtool --tag=CC --mode=compile x86_64-w64-mingw32-gcc -DHAVE_CONFIG_H -I. -I.. -Wall -O2 -static -static-libgcc -static-libstdc++ -MT regsyntax.lo -MD -MP -MF .deps/regsyntax.Tpo -c -o regsyntax.lo regsyntax.c
/bin/bash ../libtool --tag=CC --mode=compile x86_64-w64-mingw32-gcc -DHAVE_CONFIG_H -I. -I.. -Wall -O2 -static -static-libgcc -static-libstdc++ -MT regtrav.lo -MD -MP -MF .deps/regtrav.Tpo -c -o regtrav.lo regtrav.c
libtool: compile: x86_64-w64-mingw32-gcc -DHAVE_CONFIG_H -I. -I.. -Wall -O2 -static-libgcc -static-libstdc++ -MT regexec.lo -MD -MP -MF .deps/regexec.Tpo -c regexec.c -o regexec.o
libtool: compile: x86_64-w64-mingw32-gcc -DHAVE_CONFIG_H -I. -I.. -Wall -O2 -static-libgcc -static-libstdc++ -MT regparse.lo -MD -MP -MF .deps/regparse.Tpo -c regparse.c -o regparse.o
libtool: compile: x86_64-w64-mingw32-gcc -DHAVE_CONFIG_H -I. -I.. -Wall -O2 -static-libgcc -static-libstdc++ -MT regsyntax.lo -MD -MP -MF .deps/regsyntax.Tpo -c regsyntax.c -o regsyntax.o
libtool: compile: x86_64-w64-mingw32-gcc -DHAVE_CONFIG_H -I. -I.. -Wall -O2 -static-libgcc -static-libstdc++ -MT regext.lo -MD -MP -MF .deps/regext.Tpo -c regex
[command output truncated]
undefined symbols not allowed in x86_64-w64-mingw32 shared libraries; building static only
libtool: link: x86_64-w64-mingw32-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: x86_64-w64-mingw32-ranlib .libs/libonig.a
libtool: link: ( cd ".libs" && rm -f "libonig.la" && ln -s "../libonig.la" "libonig.la" )
make[4]: Leaving directory '/home/peter/jq-1.8.1/vendor/oniguruma/src'
make[3]: Leaving directory '/home/peter/jq-1.8.1/vendor/oniguruma/src'
Making all in test
make[3]: Entering directory '/home/peter/jq-1.8.1/vendor/oniguruma/test'
make[3]: Nothing to be done for 'all'.
make[3]: Leaving directory '/home/peter/jq-1.8.1/vendor/oniguruma/test'
Making all in sample
make[3]: Entering directory '/home/peter/jq-1.8.1/vendor/oniguruma/sample'
make[3]: Nothing to be done for 'all'.
make[3]: Leaving directory '/home/peter/jq-1.8.1/vendor/oniguruma/sample'
make[3]: Entering directory '/home/peter/jq-1.8.1/vendor/oniguruma'
sed -e 's,[@]datadir[@],/usr/local/share,g' -e 's,[@]datarootdir[@],/usr/local/share,g' -e 's,[@]PACKAGE_VERSION[@],6.9.10,g' -e 's,[@]prefix[@],/usr/local,g' -e 's,[@]exec_prefix[@],/usr/local,g' -e 's,[@]libdir[@],/usr/local/lib,g' -e 's,[@]includedir[@],/usr/local/include,g' < ./oniguruma.pc.in > oniguruma.pc
make[3]: Leaving directory '/home/peter/jq-1.8.1/vendor/oniguruma'
make[2]: Leaving directory '/home/peter/jq-1.8.1/vendor/oniguruma'
make[2]: Entering directory '/home/peter/jq-1.8.1'
GEN jq.1
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
CC src/main.o
src/main.c:21:1: warning: function declaration isn't a prototype [ttps://gcc.gnu.org/onlinedocs/gcc/Warning-Options.html#index-Wstrict-prototypes-Wstrict-prototypes]8;;]
21 | extern void jv_tsd_dtoa_ctx_init();
| ^~~~~~
CCLD libjq.la
CCLD jq.exe
make[2]: Leaving directory '/home/peter/jq-1.8.1'
make[1]: Leaving directory '/home/peter/jq-1.8.1'
↓ 77 lines
mkdir -p src
mkdir -p src
GEN src/builtin.inc
GEN src/config_opts.inc
mkdir -p src
GEN src/version.h
make all-recursive
make[1]: Entering directory '/home/peter/jq-1.8.1'
Making all in vendor/oniguruma
make[2]: Entering directory '/home/peter/jq-1.8.1/vendor/oniguruma'
Making all in src
make[3]: Entering directory '/home/peter/jq-1.8.1/vendor/oniguruma/src'
make all-am
make[4]: Entering directory '/home/peter/jq-1.8.1/vendor/oniguruma/src'
/bin/bash ../libtool --tag=CC --mode=compile x86_64-w64-mingw32-gcc -DHAVE_CONFIG_H -I. -I.. -Wall -O2 -static -static-libgcc -static-libstdc++ -MT regparse.lo -MD -MP -MF .deps/regparse.Tpo -c -o regparse.lo regparse.c
/bin/bash ../libtool --tag=CC --mode=compile x86_64-w64-mingw32-gcc -DHAVE_CONFIG_H -I. -I.. -Wall -O2 -static -static-libgcc -static-libstdc++ -MT regcomp.lo -MD -MP -MF .deps/regcomp.Tpo -c -o regcomp.lo regcomp.c
/bin/bash ../libtool --tag=CC --mode=compile x86_64-w64-mingw32-gcc -DHAVE_CONFIG_H -I. -I.. -Wall -O2 -static -static-libgcc -static-libstdc++ -MT regexec.lo -MD -MP -MF .deps/regexec.Tpo -c -o regexec.lo regexec.c
/bin/bash ../libtool --tag=CC --mode=compile x86_64-w64-mingw32-gcc -DHAVE_CONFIG_H -I. -I.. -Wall -O2 -static -static-libgcc -static-libstdc++ -MT regenc.lo -MD -MP -MF .deps/regenc.Tpo -c -o regenc.lo regenc.c
/bin/bash ../libtool --tag=CC --mode=compile x86_64-w64-mingw32-gcc -DHAVE_CONFIG_H -I. -I.. -Wall -O2 -static -static-libgcc -static-libstdc++ -MT regerror.lo -MD -MP -MF .deps/regerror.Tpo -c -o regerror.lo regerror.c
/bin/bash ../libtool --tag=CC --mode=compile x86_64-w64-mingw32-gcc -DHAVE_CONFIG_H -I. -I.. -Wall -O2 -static -static-libgcc -static-libstdc++ -MT regext.lo -MD -MP -MF .deps/regext.Tpo -c -o regext.lo regext.c
/bin/bash ../libtool --tag=CC --mode=compile x86_64-w64-mingw32-gcc -DHAVE_CONFIG_H -I. -I.. -Wall -O2 -static -static-libgcc -static-libstdc++ -MT regsyntax.lo -MD -MP -MF .deps/regsyntax.Tpo -c -o regsyntax.lo regsyntax.c
/bin/bash ../libtool --tag=CC --mode=compile x86_64-w64-mingw32-gcc -DHAVE_CONFIG_H -I. -I.. -Wall -O2 -static -static-libgcc -static-libstdc++ -MT regtrav.lo -MD -MP -MF .deps/regtrav.Tpo -c -o regtrav.lo regtrav.c
libtool: compile: x86_64-w64-mingw32-gcc -DHAVE_CONFIG_H -I. -I.. -Wall -O2 -static-libgcc -static-libstdc++ -MT regexec.lo -MD -MP -MF .deps/regexec.Tpo -c regexec.c -o regexec.o
libtool: compile: x86_64-w64-mingw32-gcc -DHAVE_CONFIG_H -I. -I.. -Wall -O2 -static-libgcc -static-libstdc++ -MT regparse.lo -MD -MP -MF .deps/regparse.Tpo -c regparse.c -o regparse.o
libtool: compile: x86_64-w64-mingw32-gcc -DHAVE_CONFIG_H -I. -I.. -Wall -O2 -static-libgcc -static-libstdc++ -MT regsyntax.lo -MD -MP -MF .deps/regsyntax.Tpo -c regsyntax.c -o regsyntax.o
libtool: compile: x86_64-w64-mingw32-gcc -DHAVE_CONFIG_H -I. -I.. -Wall -O2 -static-libgcc -static-libstdc++ -MT regext.lo -MD -MP -MF .deps/regext.Tpo -c regex
[command output truncated]
undefined symbols not allowed in x86_64-w64-mingw32 shared libraries; building static only
libtool: link: x86_64-w64-mingw32-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: x86_64-w64-mingw32-ranlib .libs/libonig.a
libtool: link: ( cd ".libs" && rm -f "libonig.la" && ln -s "../libonig.la" "libonig.la" )
make[4]: Leaving directory '/home/peter/jq-1.8.1/vendor/oniguruma/src'
make[3]: Leaving directory '/home/peter/jq-1.8.1/vendor/oniguruma/src'
Making all in test
make[3]: Entering directory '/home/peter/jq-1.8.1/vendor/oniguruma/test'
make[3]: Nothing to be done for 'all'.
make[3]: Leaving directory '/home/peter/jq-1.8.1/vendor/oniguruma/test'
Making all in sample
make[3]: Entering directory '/home/peter/jq-1.8.1/vendor/oniguruma/sample'
make[3]: Nothing to be done for 'all'.
make[3]: Leaving directory '/home/peter/jq-1.8.1/vendor/oniguruma/sample'
make[3]: Entering directory '/home/peter/jq-1.8.1/vendor/oniguruma'
sed -e 's,[@]datadir[@],/usr/local/share,g' -e 's,[@]datarootdir[@],/usr/local/share,g' -e 's,[@]PACKAGE_VERSION[@],6.9.10,g' -e 's,[@]prefix[@],/usr/local,g' -e 's,[@]exec_prefix[@],/usr/local,g' -e 's,[@]libdir[@],/usr/local/lib,g' -e 's,[@]includedir[@],/usr/local/include,g' < ./oniguruma.pc.in > oniguruma.pc
make[3]: Leaving directory '/home/peter/jq-1.8.1/vendor/oniguruma'
make[2]: Leaving directory '/home/peter/jq-1.8.1/vendor/oniguruma'
make[2]: Entering directory '/home/peter/jq-1.8.1'
GEN jq.1
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
CC src/main.o
src/main.c:21:1: warning: function declaration isn't a prototype [ttps://gcc.gnu.org/onlinedocs/gcc/Warning-Options.html#index-Wstrict-prototypes-Wstrict-prototypes]8;;]
21 | extern void jv_tsd_dtoa_ctx_init();
| ^~~~~~
CCLD libjq.la
CCLD jq.exe
make[2]: Leaving directory '/home/peter/jq-1.8.1'
make[1]: Leaving directory '/home/peter/jq-1.8.1'
Show reasoning
Checking new executable dependencies
compile-bench> x86_64-w64-mingw32-objdump -p jq-1.8.1/jq.exe | grep DLL vma: Hint Time Forward DLL First
DLL Name: KERNEL32.dll
DLL Name: msvcrt.dll
DLL Name: SHLWAPI.dll
DLL Name: libwinpthread-1.dll
↓ 6 lines
vma: Hint Time Forward DLL First DLL Name: KERNEL32.dll DLL Name: msvcrt.dll DLL Name: SHLWAPI.dll DLL Name: libwinpthread-1.dll
Show reasoning
Investigating libjq.la dependencies
compile-bench> grep -n "dependency_libs" jq-1.8.1/libjq.la 16:# Linker flags that cannot go in dependency_libs.
20:dependency_libs=' -L./vendor/oniguruma/src -lshlwapi /home/peter/jq-1.8.1/vendor/oniguruma/src/.libs/libonig.la -lwinpthread'
↓ 3 lines
16:# Linker flags that cannot go in dependency_libs. 20:dependency_libs=' -L./vendor/oniguruma/src -lshlwapi /home/peter/jq-1.8.1/vendor/oniguruma/src/.libs/libonig.la -lwinpthread'
Show reasoning
Investigating remaining pthread link flag
compile-bench> grep -n "dependency_libs" jq-1.8.1/vendor/oniguruma/src/libonig.la 16:# Linker flags that cannot go in dependency_libs.
20:dependency_libs=' -lwinpthread'
↓ 3 lines
16:# Linker flags that cannot go in dependency_libs. 20:dependency_libs=' -lwinpthread'
Show reasoning
Analyzing Oniguruma static linking issues
I'm examining why Oniguruma’s libonig.la links with -lwinpthread dynamically despite environment variables set for static linking. I’ll check its config.log to understand how PTHREAD_LIBS and LIBS are handled inside the vendor configure and consider patching or reconfiguring to enforce static linking with -Wl,-Bstatic.
[empty output]
Show reasoning
Searching for lwinpthread references
compile-bench> grep -n "winpthread" jq-1.8.1/vendor/oniguruma/config.log 7: $ ./configure --disable-option-checking --prefix=/usr/local --host=x86_64-w64-mingw32 --build=x86_64-pc-linux-gnu --disable-shared --enable-static --with-oniguruma=builtin build_alias=x86_64-pc-linux-gnu host_alias=x86_64-w64-mingw32 CC=x86_64-w64-mingw32-gcc 'CFLAGS=-O2 -static -static-libgcc -static-libstdc++' 'LDFLAGS=-static -static-libgcc -static-libstdc++' 'LIBS=-Wl,-Bstatic -lwinpthread -Wl,-Bdynamic' --cache-file=/dev/null --srcdir=.
103:configure:4014: x86_64-w64-mingw32-gcc -O2 -static -static-libgcc -static-libstdc++ -static -static-libgcc -static-libstdc++ conftest.c -Wl,-Bstatic -lwinpthread -Wl,-Bdynamic >&5
109:configure:4086: x86_64-w64-mingw32-gcc -o conftest.exe -O2 -static -static-libgcc -static-libstdc++ -static -static-libgcc -static-libstdc++ conftest.c -Wl,-Bstatic -lwinpthread -Wl,-Bdynamic >&5
1527:configure:13161: x86_64-w64-mingw32-gcc -o conftest.exe -O2 -static -static-libgcc -static-libstdc++ -static -static-libgcc -static-libstdc++ conftest.c -Wl,-Bstatic -lwinpthread -Wl,-Bdynamic >&5
1572:configure:13214: x86_64-w64-mingw32-gcc -o conftest.exe -O2 -static -static-libgcc -static-libstdc++ -static -static-libgcc -static-libstdc++ conftest.c -Wl,-Bstatic -lwinpthread -Wl,-Bdynamic >&5
1625:ac_cv_env_LIBS_value='-Wl,-Bstatic -lwinpthread -Wl,-Bdynamic'
1758:LIBS='-Wl,-Bstatic -lwinpthread -Wl,-Bdynamic'
↓ 8 lines
7: $ ./configure --disable-option-checking --prefix=/usr/local --host=x86_64-w64-mingw32 --build=x86_64-pc-linux-gnu --disable-shared --enable-static --with-oniguruma=builtin build_alias=x86_64-pc-linux-gnu host_alias=x86_64-w64-mingw32 CC=x86_64-w64-mingw32-gcc 'CFLAGS=-O2 -static -static-libgcc -static-libstdc++' 'LDFLAGS=-static -static-libgcc -static-libstdc++' 'LIBS=-Wl,-Bstatic -lwinpthread -Wl,-Bdynamic' --cache-file=/dev/null --srcdir=. 103:configure:4014: x86_64-w64-mingw32-gcc -O2 -static -static-libgcc -static-libstdc++ -static -static-libgcc -static-libstdc++ conftest.c -Wl,-Bstatic -lwinpthread -Wl,-Bdynamic >&5 109:configure:4086: x86_64-w64-mingw32-gcc -o conftest.exe -O2 -static -static-libgcc -static-libstdc++ -static -static-libgcc -static-libstdc++ conftest.c -Wl,-Bstatic -lwinpthread -Wl,-Bdynamic >&5 1527:configure:13161: x86_64-w64-mingw32-gcc -o conftest.exe -O2 -static -static-libgcc -static-libstdc++ -static -static-libgcc -static-libstdc++ conftest.c -Wl,-Bstatic -lwinpthread -Wl,-Bdynamic >&5 1572:configure:13214: x86_64-w64-mingw32-gcc -o conftest.exe -O2 -static -static-libgcc -static-libstdc++ -static -static-libgcc -static-libstdc++ conftest.c -Wl,-Bstatic -lwinpthread -Wl,-Bdynamic >&5 1625:ac_cv_env_LIBS_value='-Wl,-Bstatic -lwinpthread -Wl,-Bdynamic' 1758:LIBS='-Wl,-Bstatic -lwinpthread -Wl,-Bdynamic'
Show reasoning
Planning manual static re-linking
[empty output]
Show reasoning
Verifying dependency linkage
compile-bench> x86_64-w64-mingw32-objdump -p jq-1.8.1/jq.exe | grep DLL vma: Hint Time Forward DLL First
DLL Name: KERNEL32.dll
DLL Name: msvcrt.dll
DLL Name: SHLWAPI.dll
↓ 5 lines
vma: Hint Time Forward DLL First DLL Name: KERNEL32.dll DLL Name: msvcrt.dll DLL Name: SHLWAPI.dll
Show reasoning
Updating jq executable copy
[empty output]
Show reasoning
Checking file existence and type
result/jq.exe: PE32+ executable (console) x86-64, for MS Windows
Show reasoning
Verifying executable dependencies
compile-bench> x86_64-w64-mingw32-objdump -p result/jq.exe | grep DLL vma: Hint Time Forward DLL First
DLL Name: KERNEL32.dll
DLL Name: msvcrt.dll
DLL Name: SHLWAPI.dll
↓ 5 lines
vma: Hint Time Forward DLL First DLL Name: KERNEL32.dll DLL Name: msvcrt.dll DLL Name: SHLWAPI.dll
Show reasoning
Preparing final response
I’m summarizing the key steps: confirming the final executable depends only on Windows system DLLs, ensuring static linking was done, mentioning installed dependencies, and stating where the final build will be located. I’ll also remind about future verification steps before sending the complete message.
Summary:
- Extracted jq v1.8.1 sources and installed the MinGW-w64 cross toolchain plus required build tools.
- Configured jq for a static Windows amd64 build using the bundled Oniguruma, targeting x86_64-w64-mingw32.
- Built the project and manually re-linked jq.exe with static libwinpthread to eliminate non-system DLL dependencies.
Verification:
- file /home/peter/result/jq.exe reports a PE32+ console executable for x86-64 Windows.
- x86_64-w64-mingw32-objdump -p /home/peter/result/jq.exe | grep DLL shows only system DLL dependencies (KERNEL32.dll, msvcrt.dll, SHLWAPI.dll).
The static Windows binary is available at /home/peter/result/jq.exe.