summaryrefslogtreecommitdiffstats
path: root/TOOLS/osxbundle.py
diff options
context:
space:
mode:
Diffstat (limited to 'TOOLS/osxbundle.py')
-rwxr-xr-xTOOLS/osxbundle.py46
1 files changed, 27 insertions, 19 deletions
diff --git a/TOOLS/osxbundle.py b/TOOLS/osxbundle.py
index bf08061c31..fc8379c748 100755
--- a/TOOLS/osxbundle.py
+++ b/TOOLS/osxbundle.py
@@ -3,6 +3,7 @@ import os
import shutil
import sys
import fileinput
+import dylib_unhell
from optparse import OptionParser
def sh(command):
@@ -24,11 +25,11 @@ def target_binary(binary_name):
return os.path.join(target_directory(binary_name),
os.path.basename(binary_name))
-def copy_bundle(binary_name):
+def copy_bundle(binary_name, src_path):
if os.path.isdir(bundle_path(binary_name)):
shutil.rmtree(bundle_path(binary_name))
shutil.copytree(
- os.path.join('TOOLS', 'osxbundle', bundle_name(binary_name)),
+ os.path.join(src_path, 'TOOLS', 'osxbundle', bundle_name(binary_name)),
bundle_path(binary_name))
def copy_binary(binary_name):
@@ -38,22 +39,25 @@ def apply_plist_template(plist_file, version):
for line in fileinput.input(plist_file, inplace=1):
print(line.rstrip().replace('${VERSION}', version))
-def create_bundle_symlink(binary_name, symlink_name):
- os.symlink(os.path.basename(binary_name),
- os.path.join(target_directory(binary_name), symlink_name))
-
-def bundle_version():
- if os.path.exists('VERSION'):
- x = open('VERSION')
+def sign_bundle(binary_name):
+ sign_directories = ['Contents/Frameworks', 'Contents/MacOS']
+ for dir in sign_directories:
+ resolved_dir = os.path.join(bundle_path(binary_name), dir)
+ for root, _dirs, files in os.walk(resolved_dir):
+ for f in files:
+ sh('codesign --force -s - ' + os.path.join(root, f))
+ sh('codesign --force -s - ' + bundle_path(binary_name))
+
+def bundle_version(src_path):
+ version = 'UNKNOWN'
+ version_path = os.path.join(src_path, 'VERSION')
+ if os.path.exists(version_path):
+ x = open(version_path)
version = x.read()
x.close()
- else:
- version = sh("./version.sh").strip()
return version
def main():
- version = bundle_version().rstrip()
-
usage = "usage: %prog [options] arg"
parser = OptionParser(usage)
parser.add_option("-s", "--skip-deps", action="store_false", dest="deps",
@@ -62,24 +66,28 @@ def main():
(options, args) = parser.parse_args()
- if len(args) != 1:
+ if len(args) < 1 or len(args) > 2:
parser.error("incorrect number of arguments")
else:
binary_name = args[0]
+ src_path = args[1] if len(args) > 1 else "."
- print("Creating Mac OS X application bundle (version: %s)..." % version)
+ version = bundle_version(src_path).rstrip()
+
+ print("Creating macOS application bundle (version: %s)..." % version)
print("> copying bundle skeleton")
- copy_bundle(binary_name)
+ copy_bundle(binary_name, src_path)
print("> copying binary")
copy_binary(binary_name)
- print("> create bundle symlink")
- create_bundle_symlink(binary_name, "mpv-bundle")
print("> generating Info.plist")
apply_plist_template(target_plist(binary_name), version)
if options.deps:
print("> bundling dependencies")
- print(sh(" ".join(["TOOLS/dylib-unhell.py", target_binary(binary_name)])))
+ dylib_unhell.process(target_binary(binary_name))
+
+ print("> signing bundle with ad-hoc pseudo identity")
+ sign_bundle(binary_name)
print("done.")