forked from mirrors/principia
It's UCRT64 time
This commit is contained in:
parent
ffa8ce97d1
commit
4c5eae3aa6
7 changed files with 83 additions and 180 deletions
21
packaging/bundledlls
Normal file
21
packaging/bundledlls
Normal file
|
|
@ -0,0 +1,21 @@
|
|||
#!/bin/bash
|
||||
# msys2-bundledlls - Copy DLLs linked against a Windows executable for bundling with a distribution
|
||||
|
||||
if [ "$#" -ne 2 ];
|
||||
then
|
||||
echo "Usage: ./bundledlls <executable> <directory>"
|
||||
exit
|
||||
fi
|
||||
|
||||
mkdir -p $2
|
||||
|
||||
# Get list of dynamic libraries, filter by ones that are found in the current MSYS2 prefix
|
||||
# and strip off everything but the full path. E.g.:
|
||||
# `lua51.dll => /ucrt64/bin/lua51.dll (0xdeadbeef)` => `/ucrt64/bin/lua51.dll`
|
||||
list=$(ldd $1 | grep $MINGW_PREFIX | sed 's/.* => //' | sed 's/ \(.*\)//')
|
||||
|
||||
for dll in $list;
|
||||
do
|
||||
echo $dll
|
||||
cp $dll $2/
|
||||
done
|
||||
|
|
@ -1,151 +0,0 @@
|
|||
#!/usr/bin/env python3
|
||||
|
||||
# The MIT License (MIT)
|
||||
#
|
||||
# Copyright (c) 2015 Martin Preisler
|
||||
#
|
||||
# Permission is hereby granted, free of charge, to any person obtaining a copy
|
||||
# of this software and associated documentation files (the "Software"), to deal
|
||||
# in the Software without restriction, including without limitation the rights
|
||||
# to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
|
||||
# copies of the Software, and to permit persons to whom the Software is
|
||||
# furnished to do so, subject to the following conditions:
|
||||
#
|
||||
# The above copyright notice and this permission notice shall be included in all
|
||||
# copies or substantial portions of the Software.
|
||||
#
|
||||
# THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
||||
# IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
||||
# FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
|
||||
# AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
||||
# LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
|
||||
# OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
|
||||
# SOFTWARE.
|
||||
|
||||
|
||||
import subprocess
|
||||
import os.path
|
||||
import argparse
|
||||
import shutil
|
||||
|
||||
# The mingw path matches where Fedora 21 installs mingw32; this is the default
|
||||
# fallback if no other search path is specified in $MINGW_BUNDLEDLLS_SEARCH_PATH
|
||||
DEFAULT_PATH_PREFIXES = [
|
||||
"", "/usr/bin", "/usr/i686-w64-mingw32/sys-root/mingw/bin", "/mingw64/bin",
|
||||
"/usr/i686-w64-mingw32/sys-root/mingw/lib",
|
||||
"C:\\msys64\\mingw64\\bin",
|
||||
"D:\\a\\_temp\\msys64\\mingw64\\bin\\" # Github workflow's MSYS2 install
|
||||
]
|
||||
|
||||
env_path_prefixes = os.environ.get('MINGW_BUNDLEDLLS_SEARCH_PATH', None)
|
||||
if env_path_prefixes is not None:
|
||||
path_prefixes = [path for path in env_path_prefixes.split(os.pathsep) if path]
|
||||
else:
|
||||
path_prefixes = DEFAULT_PATH_PREFIXES
|
||||
|
||||
# This blacklist may need extending
|
||||
blacklist = [
|
||||
"advapi32.dll", "kernel32.dll", "msvcrt.dll", "ole32.dll", "user32.dll",
|
||||
"ws2_32.dll", "comdlg32.dll", "gdi32.dll", "imm32.dll", "oleaut32.dll",
|
||||
"shell32.dll", "winmm.dll", "winspool.drv", "wldap32.dll",
|
||||
"ntdll.dll", "d3d9.dll", "mpr.dll", "crypt32.dll", "dnsapi.dll",
|
||||
"shlwapi.dll", "version.dll", "iphlpapi.dll", "msimg32.dll", "setupapi.dll",
|
||||
"opengl32.dll", "dwmapi.dll", "uxtheme.dll", "secur32.dll", "gdiplus.dll",
|
||||
"usp10.dll", "comctl32.dll", "wsock32.dll", "netapi32.dll", "userenv.dll",
|
||||
"avicap32.dll", "avrt.dll", "psapi.dll", "mswsock.dll", "glu32.dll",
|
||||
"bcrypt.dll", "rpcrt4.dll", "hid.dll",
|
||||
# directx 3d 11
|
||||
"d3d11.dll", "dxgi.dll", "dwrite.dll"
|
||||
]
|
||||
|
||||
|
||||
def find_full_path(filename, path_prefixes):
|
||||
for path_prefix in path_prefixes:
|
||||
path = os.path.join(path_prefix, filename)
|
||||
path_low = os.path.join(path_prefix, filename.lower())
|
||||
if os.path.exists(path):
|
||||
return path
|
||||
if os.path.exists(path_low):
|
||||
return path_low
|
||||
|
||||
else:
|
||||
raise RuntimeError(
|
||||
"Can't find " + filename + ". If it is an inbuilt Windows DLL, "
|
||||
"please add it to the blacklist variable in the script and send "
|
||||
"a pull request!"
|
||||
)
|
||||
|
||||
|
||||
def gather_deps(path, path_prefixes, seen):
|
||||
ret = [path]
|
||||
output = subprocess.check_output(["objdump", "-p", path]).decode(
|
||||
"utf-8", "replace").split("\n")
|
||||
for line in output:
|
||||
if not line.startswith("\tDLL Name: "):
|
||||
continue
|
||||
|
||||
dep = line.split("DLL Name: ")[1].strip()
|
||||
ldep = dep.lower()
|
||||
|
||||
if ldep in blacklist:
|
||||
continue
|
||||
|
||||
if ldep in seen:
|
||||
continue
|
||||
|
||||
dep_path = find_full_path(dep, path_prefixes)
|
||||
seen.add(ldep)
|
||||
subdeps = gather_deps(dep_path, path_prefixes, seen)
|
||||
ret.extend(subdeps)
|
||||
|
||||
return ret
|
||||
|
||||
|
||||
def main():
|
||||
parser = argparse.ArgumentParser()
|
||||
parser.add_argument(
|
||||
"exe_file",
|
||||
help="EXE or DLL file that you need to bundle dependencies for"
|
||||
)
|
||||
parser.add_argument(
|
||||
"--copy",
|
||||
action="store_true",
|
||||
help="In addition to printing out the dependencies, also copy them next to the exe_file"
|
||||
)
|
||||
parser.add_argument(
|
||||
"--upx",
|
||||
action="store_true",
|
||||
help="Only valid if --copy is provided. Run UPX on all the DLLs and EXE."
|
||||
)
|
||||
args = parser.parse_args()
|
||||
|
||||
if args.upx and not args.copy:
|
||||
raise RuntimeError("Can't run UPX if --copy hasn't been provided.")
|
||||
|
||||
all_deps = set(gather_deps(args.exe_file, path_prefixes, set()))
|
||||
all_deps.remove(args.exe_file)
|
||||
|
||||
print("\n".join(all_deps))
|
||||
|
||||
if args.copy:
|
||||
print("Copying enabled, will now copy all dependencies next to the exe_file.\n")
|
||||
|
||||
parent_dir = os.path.dirname(os.path.abspath(args.exe_file))
|
||||
|
||||
for dep in all_deps:
|
||||
target = os.path.join(parent_dir, os.path.basename(dep))
|
||||
|
||||
try:
|
||||
print("Copying '%s' to '%s'" % (dep, target))
|
||||
shutil.copy(dep, parent_dir)
|
||||
|
||||
except shutil.SameFileError:
|
||||
print("Dependency '%s' was already in target directory, "
|
||||
"skipping..." % (dep))
|
||||
|
||||
if args.upx:
|
||||
subprocess.call(["upx", target])
|
||||
|
||||
|
||||
if __name__ == "__main__":
|
||||
main()
|
||||
|
|
@ -1,3 +1,5 @@
|
|||
SetCompressor lzma
|
||||
|
||||
!include "MUI2.nsh"
|
||||
|
||||
!define MUI_ICON "..\packaging\icon.ico"
|
||||
|
|
|
|||
19
packaging/windows_portable.sh
Normal file
19
packaging/windows_portable.sh
Normal file
|
|
@ -0,0 +1,19 @@
|
|||
#!/bin/bash
|
||||
|
||||
# This script relies on windows_release.sh being run to prepare the release/ directory
|
||||
|
||||
touch release/portable.txt
|
||||
|
||||
cp ../packaging/play_community_level.bat release/
|
||||
|
||||
cp -r ../data-{pc,shared}/ release/
|
||||
|
||||
# juggling time
|
||||
mv principia.exe principia_exe.exe
|
||||
mv release/ Principia/
|
||||
|
||||
7z a principia-portable.7z Principia/
|
||||
|
||||
# switch it back
|
||||
mv Principia/ release/
|
||||
mv principia_exe.exe principia.exe
|
||||
|
|
@ -1,6 +1,6 @@
|
|||
#!/bin/bash
|
||||
|
||||
# Commented out because I prefer doing the compilation mzself
|
||||
#./go --clean --release
|
||||
# This script assumes you already have built the executable
|
||||
|
||||
rm -rf release
|
||||
mkdir -p release
|
||||
|
|
@ -11,16 +11,16 @@ cd release
|
|||
# collect up GTK3 junk to make it work
|
||||
PIXBUF_DIR="lib/gdk-pixbuf-2.0/2.10.0"
|
||||
mkdir -p $PIXBUF_DIR/loaders/
|
||||
cp /mingw64/$PIXBUF_DIR/loaders.cache $PIXBUF_DIR/
|
||||
cp /mingw64/$PIXBUF_DIR/loaders/libpixbufloader-{jpeg,png}.dll $PIXBUF_DIR/loaders/
|
||||
cp $MINGW_PREFIX/$PIXBUF_DIR/loaders.cache $PIXBUF_DIR/
|
||||
cp $MINGW_PREFIX/$PIXBUF_DIR/loaders/libpixbufloader-{jpeg,png}.dll $PIXBUF_DIR/loaders/
|
||||
|
||||
SCHEMAS_DIR="share/glib-2.0/schemas"
|
||||
mkdir -p $SCHEMAS_DIR
|
||||
cp /mingw64/$SCHEMAS_DIR/{gschema.dtd,gschemas.compiled} $SCHEMAS_DIR/
|
||||
cp $MINGW_PREFIX/$SCHEMAS_DIR/{gschema.dtd,gschemas.compiled} $SCHEMAS_DIR/
|
||||
|
||||
cd ..
|
||||
|
||||
../packaging/mingw-bundledlls release/principia.exe --copy
|
||||
../packaging/bundledlls release/principia.exe release/
|
||||
|
||||
cp ../packaging/principia_install.nsi .
|
||||
cp -r ../packaging/installer/ .
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue