diff --git a/addons/rearm/XEH_preStart.sqf b/addons/rearm/XEH_preStart.sqf index 022888575ed..b092699f9b9 100644 --- a/addons/rearm/XEH_preStart.sqf +++ b/addons/rearm/XEH_preStart.sqf @@ -1,3 +1,9 @@ #include "script_component.hpp" #include "XEH_PREP.hpp" + +// Test binarization one time at startup - ref https://github.com/acemod/ACE3/pull/8093 +private _test = getText (configFile >> "Cfg3DEN" >> "Object" >> "AttributeCategories" >> "ace_attributes" >> "Attributes" >> "ace_rearm_rearmCargo" >> "defaultValue"); +if (!("else {" in _test)) then { + ERROR("3den attribute has ERROR [check binarization]"); +}; diff --git a/docs/wiki/development/setting-up-the-development-environment.md b/docs/wiki/development/setting-up-the-development-environment.md index 5c537ebd1c8..6d72173f521 100644 --- a/docs/wiki/development/setting-up-the-development-environment.md +++ b/docs/wiki/development/setting-up-the-development-environment.md @@ -17,10 +17,9 @@ This page describes how you can setup your development environment for ACE3, all - P-drive - Run Arma 3 and Arma 3 Tools directly from steam once to install registry entries (and again after every update) - [Python 3.x](https://www.python.org/) -- [Mikero Tools](https://mikero.bytex.digital/Downloads): DePbo, DeOgg, Rapify, MakePbo, PboProject >=1.70 +- [Mikero Tools](https://mikero.bytex.digital/Downloads): DePbo, DeOgg, Rapify, MakePbo, PboProject >=3.16 - `*.hpp` removed from PboProject's "Exclude From Pbo" list - `-F rebuild RequiredAddons` disabled - - `-B Don't binarise cpp or sqm` enabled - Python, Mikero Tools and Git in PATH environment variable - [CBA](https://github.com/CBATeam/CBA_A3/releases/latest) mod (release or development version) diff --git a/tools/make.py b/tools/make.py index 33d57c9f98b..1efa84cf33a 100644 --- a/tools/make.py +++ b/tools/make.py @@ -514,9 +514,31 @@ def backup_config(module): return True +def convert_config(module): + # Backup config to config.backup, then run the CfgConvert preprocessor to create a new pre-processed config.cpp + try: + os.chdir(work_drive) + os.rename(os.path.join(work_drive, prefix, module, "config.cpp"), os.path.join(work_drive, prefix, module, "config.backup")) + cmd = [os.path.join(arma3tools_path, "CfgConvert", "CfgConvert.exe"), "-pcpp", "-dst", os.path.join(work_drive, prefix, module, "config.cpp"), os.path.join(work_drive, prefix, module, "config.backup")] + ret = subprocess.call(cmd) + if ret != 0: + raise Exception(f"CfgConvert return {ret}") + except Exception as e: + print_error(f"convert_config error: {e}") + return False + + return True + def addon_restore(modulePath): - #restore original $PBOPREFIX$ + #restore original $PBOPREFIX$ and config.cpp try: + if os.path.isfile(os.path.join(modulePath, "config.backup")): + if os.path.isfile(os.path.join(modulePath, "config.cpp")): + os.remove(os.path.join(modulePath, "config.cpp")) + os.rename(os.path.join(modulePath, "config.backup"), os.path.join(modulePath, "config.cpp")) + + if os.path.isfile(os.path.join(modulePath, "texHeaders.bin")): + os.remove(os.path.join(modulePath, "texHeaders.bin")) if os.path.isfile(os.path.join(modulePath, "$PBOPREFIX$.backup")): if os.path.isfile(os.path.join(modulePath, "$PBOPREFIX$")): os.remove(os.path.join(modulePath, "$PBOPREFIX$")) @@ -1286,14 +1308,23 @@ def main(argv): except: pass + # Detect $FORCE_ADDONMAKER$ and do not binarize if found. (This overrides build_tool choice!) + if os.path.isfile(os.path.join(work_drive, prefix, module, "$FORCE_ADDONMAKER$")): + force_addonmaker = True + print("$FORCE_ADDONMAKER$ file found in module, packing only with Addon Maker") + else: + force_addonmaker = False # Run build tool build_successful = False - if build_tool == "pboproject": + if build_tool == "pboproject" and not force_addonmaker: try: nobinFilePath = os.path.join(work_drive, prefix, module, "$NOBIN$") backup_config(module) + if not os.path.isfile(nobinFilePath): + convert_config(module) + version_stamp_pboprefix(module,commit_id) if os.path.isfile(nobinFilePath): @@ -1301,7 +1332,7 @@ def main(argv): cmd = [makepboTool, "-P","-A","-X=*.backup", os.path.join(work_drive, prefix, module),os.path.join(module_root, release_dir, project,"addons")] else: - cmd = [pboproject, "-B", "-P", os.path.join(work_drive, prefix, module), "+Engine=Arma3", "-S", "+Noisy", "+Clean", "-Warnings", "+Mod="+os.path.join(module_root, release_dir, project), "-Key"] + cmd = [pboproject, "+B", "-P", os.path.join(work_drive, prefix, module), "+Engine=Arma3", "-S", "+Noisy", "+Clean", "-Warnings", "+Mod="+os.path.join(module_root, release_dir, project), "-Key"] color("grey") if quiet: @@ -1353,7 +1384,7 @@ def main(argv): finally: addon_restore(os.path.join(work_drive, prefix, module)) - elif build_tool== "addonbuilder": + elif build_tool== "addonbuilder" or force_addonmaker: # Detect $NOBIN$ and do not binarize if found. if os.path.isfile(os.path.join(work_drive, prefix, module, "$NOBIN$")): do_binarize = False @@ -1378,10 +1409,10 @@ def main(argv): else: previousDirectory = os.getcwd() os.chdir(arma3tools_path) - print_error("Current directory - {}".format(os.getcwd())) + print("Current directory - {}".format(os.getcwd())) ret = subprocess.call(cmd) os.chdir(previousDirectory) - print_error("Current directory - {}".format(os.getcwd())) + print("Current directory - {}".format(os.getcwd())) color("reset") print_green("completed") # Prettyprefix rename the PBO if requested.