Mercurial > minori
annotate scripts/win32/deploy_build.sh @ 352:a0e96f50bcce
chore: merge diverging branches
| author | Paper <paper@paper.us.eu.org> |
|---|---|
| date | Sun, 14 Jul 2024 23:24:19 -0400 |
| parents | 1faa72660932 |
| children |
| rev | line source |
|---|---|
| 296 | 1 #!/bin/sh |
| 2 # | |
| 3 # deploys needed libraries for minori on win32 | |
| 4 # | |
| 5 # this also runs windeployqt to deploy qt crap | |
| 6 # as well | |
|
300
8eb0cfe59992
CI/windows: attempt to fix the build
Paper <paper@paper.us.eu.org>
parents:
298
diff
changeset
|
7 # |
|
8eb0cfe59992
CI/windows: attempt to fix the build
Paper <paper@paper.us.eu.org>
parents:
298
diff
changeset
|
8 # note: ldd is NOT a standard ldd; it's mingw-ldd |
|
8eb0cfe59992
CI/windows: attempt to fix the build
Paper <paper@paper.us.eu.org>
parents:
298
diff
changeset
|
9 # from pypi which works much well when cross |
|
8eb0cfe59992
CI/windows: attempt to fix the build
Paper <paper@paper.us.eu.org>
parents:
298
diff
changeset
|
10 # compiling using something like quasi-msys2 |
| 296 | 11 |
|
300
8eb0cfe59992
CI/windows: attempt to fix the build
Paper <paper@paper.us.eu.org>
parents:
298
diff
changeset
|
12 # you can override the paths to these at runtime |
| 296 | 13 DIR="${DIR:-minori}" |
|
300
8eb0cfe59992
CI/windows: attempt to fix the build
Paper <paper@paper.us.eu.org>
parents:
298
diff
changeset
|
14 LDD="${LDD:-mingw-ldd}" |
| 296 | 15 |
| 16 GetNeededLibraries() { | |
| 17 # do not run this on untrusted executables. | |
| 18 # see: ldd(1) | |
| 19 system="$(echo "$MSYSTEM" | tr "[:upper:]" "[:lower:]")" | |
|
343
1faa72660932
*: transfer back to cmake from autotools
Paper <paper@paper.us.eu.org>
parents:
300
diff
changeset
|
20 "$LDD" --output-format ldd-like --dll-lookup-dirs "/$system/bin" "$PWD" -- "$1" | while IFS="" read -r dependency; do |
|
300
8eb0cfe59992
CI/windows: attempt to fix the build
Paper <paper@paper.us.eu.org>
parents:
298
diff
changeset
|
21 # trim whitespace, then get the value; mingw-ldd's "ldd-like" output doesn't use tabs like regular ldd |
|
8eb0cfe59992
CI/windows: attempt to fix the build
Paper <paper@paper.us.eu.org>
parents:
298
diff
changeset
|
22 lib="$(printf -- "%s" "$dependency" | sed -e 's/^[[:space:]]*//' -e 's/[[:space:]]*$//' | cut -d' ' -f3)" |
|
343
1faa72660932
*: transfer back to cmake from autotools
Paper <paper@paper.us.eu.org>
parents:
300
diff
changeset
|
23 if test "x$lib" != "xnot"; then |
|
1faa72660932
*: transfer back to cmake from autotools
Paper <paper@paper.us.eu.org>
parents:
300
diff
changeset
|
24 printf -- "$lib\n" |
|
1faa72660932
*: transfer back to cmake from autotools
Paper <paper@paper.us.eu.org>
parents:
300
diff
changeset
|
25 fi |
| 296 | 26 done |
| 27 } | |
| 28 | |
| 29 | |
|
300
8eb0cfe59992
CI/windows: attempt to fix the build
Paper <paper@paper.us.eu.org>
parents:
298
diff
changeset
|
30 if test -d "$DIR"; then |
| 296 | 31 rm -r "$DIR" |
| 32 fi | |
| 33 | |
| 34 mkdir "$DIR" | |
| 35 | |
|
343
1faa72660932
*: transfer back to cmake from autotools
Paper <paper@paper.us.eu.org>
parents:
300
diff
changeset
|
36 for lib in $(GetNeededLibraries "minori.exe"); do |
|
298
dec4d3c9a909
scripts/win32/deploy_build: be more verbose with libs
Paper <paper@paper.us.eu.org>
parents:
296
diff
changeset
|
37 echo "copying '$lib' to $DIR" |
| 296 | 38 cp "$lib" "$DIR/" |
| 39 done | |
| 40 | |
|
343
1faa72660932
*: transfer back to cmake from autotools
Paper <paper@paper.us.eu.org>
parents:
300
diff
changeset
|
41 cp "minori.exe" "$DIR/" |
| 296 | 42 |
| 43 windeployqt "$DIR/minori.exe" | |
| 44 | |
| 45 zip -r "$DIR.zip" "$DIR" |
