aboutsummaryrefslogtreecommitdiffstats
path: root/tools
diff options
context:
space:
mode:
Diffstat (limited to 'tools')
-rw-r--r--tools/make-locale-safari.py39
-rw-r--r--tools/make-safari-meta.py74
-rw-r--r--tools/make-safari.sh2
3 files changed, 75 insertions, 40 deletions
diff --git a/tools/make-locale-safari.py b/tools/make-locale-safari.py
deleted file mode 100644
index 62c8198..0000000
--- a/tools/make-locale-safari.py
+++ /dev/null
@@ -1,39 +0,0 @@
-#!/usr/bin/env python3
-
-import os
-import json
-import sys
-from shutil import rmtree
-from collections import OrderedDict
-
-if not sys.argv[1]:
- raise SystemExit('Build dir missing.')
-
-
-def mkdirs(path):
- try:
- os.makedirs(path)
- finally:
- return os.path.exists(path)
-
-
-build_dir = os.path.abspath(sys.argv[1])
-locale_dir = os.path.join(build_dir, '_locales')
-
-for alpha2 in os.listdir(locale_dir):
- locale_path = os.path.join(locale_dir, alpha2, 'messages.json')
- with open(locale_path, encoding='utf-8') as f:
- string_data = json.load(f, object_pairs_hook=OrderedDict)
-
- for string_name in string_data:
- string_data[string_name] = string_data[string_name]['message']
-
- rmtree(os.path.join(locale_dir, alpha2))
-
- alpha2 = alpha2.replace('_', '-')
- locale_path = os.path.join(locale_dir, alpha2 + '.json')
-
- mkdirs(os.path.join(locale_dir))
-
- with open(locale_path, 'wt', encoding='utf-8', newline='\n') as f:
- json.dump(string_data, f, ensure_ascii=False)
diff --git a/tools/make-safari-meta.py b/tools/make-safari-meta.py
new file mode 100644
index 0000000..eb0b701
--- /dev/null
+++ b/tools/make-safari-meta.py
@@ -0,0 +1,74 @@
+#!/usr/bin/env python3
+
+import os
+import json
+import sys
+from time import time
+from shutil import rmtree
+from collections import OrderedDict
+
+if not sys.argv[1]:
+ raise SystemExit('Build dir missing.')
+
+
+def mkdirs(path):
+ try:
+ os.makedirs(path)
+ finally:
+ return os.path.exists(path)
+
+pj = os.path.join
+build_dir = os.path.abspath(sys.argv[1])
+
+description = ''
+
+# locales
+locale_dir = pj(build_dir, '_locales')
+
+for alpha2 in os.listdir(locale_dir):
+ locale_path = pj(locale_dir, alpha2, 'messages.json')
+ with open(locale_path, encoding='utf-8') as f:
+ string_data = json.load(f, object_pairs_hook=OrderedDict)
+
+ if alpha2 == 'en':
+ description = string_data['extShortDesc']['message']
+
+ for string_name in string_data:
+ string_data[string_name] = string_data[string_name]['message']
+
+ rmtree(pj(locale_dir, alpha2))
+
+ alpha2 = alpha2.replace('_', '-')
+ locale_path = pj(locale_dir, alpha2 + '.json')
+
+ mkdirs(pj(locale_dir))
+
+ with open(locale_path, 'wt', encoding='utf-8', newline='\n') as f:
+ json.dump(string_data, f, ensure_ascii=False)
+
+
+# update Info.plist
+proj_dir = pj(os.path.split(os.path.abspath(__file__))[0], '..')
+chromium_manifest = pj(proj_dir, 'platform', 'chromium', 'manifest.json')
+
+with open(chromium_manifest, encoding='utf-8') as m:
+ manifest = json.load(m)
+
+manifest['buildNumber'] = int(time())
+manifest['description'] = description
+
+with open(pj(build_dir, 'Info.plist'), 'r+t', encoding='utf-8', newline='\n') as f:
+ info_plist = f.read()
+ f.seek(0)
+
+ f.write(info_plist.format(**manifest))
+
+# update Update.plist
+update_plist = pj(proj_dir, 'platform', 'safari', 'Update.plist')
+update_plist_build = pj(build_dir, '..', os.path.basename(update_plist))
+
+with open(update_plist_build, 'wt', encoding='utf-8', newline='\n') as f:
+ with open(update_plist, encoding='utf-8') as u:
+ update_plist = u.read()
+
+ f.write(update_plist.format(**manifest))
diff --git a/tools/make-safari.sh b/tools/make-safari.sh
index 1b9840a..bb8d5cd 100644
--- a/tools/make-safari.sh
+++ b/tools/make-safari.sh
@@ -20,6 +20,6 @@ cp platform/safari/Info.plist $DES/
cp platform/safari/Settings.plist $DES/
echo "*** uBlock_xpi: Generating locales"
-python tools/make-locale-safari.py $DES/
+python tools/make-safari-meta.py $DES/
echo "*** uBlock.safariextension: Package done."