summaryrefslogtreecommitdiffstats
path: root/bin/update/create_build_config.py
diff options
context:
space:
mode:
Diffstat (limited to 'bin/update/create_build_config.py')
-rwxr-xr-xbin/update/create_build_config.py59
1 files changed, 59 insertions, 0 deletions
diff --git a/bin/update/create_build_config.py b/bin/update/create_build_config.py
new file mode 100755
index 0000000000..de39b645ce
--- /dev/null
+++ b/bin/update/create_build_config.py
@@ -0,0 +1,59 @@
+#! /usr/bin/env python3
+
+import json
+import sys
+import os
+
+from tools import replace_variables_in_string
+
+
+def update_all_url_entries(data, **kwargs):
+ data['complete']['url'] = replace_variables_in_string(data['complete']['url'], **kwargs)
+
+ if sys.platform != "cygwin":
+ for language in data['languages']:
+ language['complete']['url'] = replace_variables_in_string(language['complete']['url'], **kwargs)
+
+ if 'partials' in data:
+ for partial in data['partials']:
+ partial['file']['url'] = replace_variables_in_string(partial['file']['url'], **kwargs)
+
+ if sys.platform == "cygwin":
+ continue
+
+ for lang, lang_file in partial['languages'].items():
+ lang_file['url'] = replace_variables_in_string(lang_file['url'], **kwargs)
+
+
+def main(argv):
+ if len(argv) < 7:
+ print("Usage: create_build_config.py $PRODUCTNAME $VERSION $BUILDID $PLATFORM $TARGETDIR $CHANNEL")
+ sys.exit(1)
+
+ data = {'productName': argv[1],
+ 'version': argv[2],
+ 'buildNumber': argv[3],
+ 'updateChannel': argv[6],
+ 'platform': argv[4]
+ }
+
+ extra_data_files = ['complete_info.json', 'partial_update_info.json']
+ if sys.platform != "cygwin":
+ extra_data_files.append('complete_lang_info.json')
+
+ for extra_file in extra_data_files:
+ extra_file_path = os.path.join(argv[5], extra_file)
+ if not os.path.exists(extra_file_path):
+ continue
+ with open(extra_file_path, "r") as f:
+ extra_data = json.load(f)
+ data.update(extra_data)
+
+ update_all_url_entries(data, channel=argv[6], platform=argv[4], buildid=argv[3], version=argv[2])
+
+ with open(os.path.join(argv[5], "build_config.json"), "w") as f:
+ json.dump(data, f, indent=4)
+
+
+if __name__ == "__main__":
+ main(sys.argv)