import os import sys from enum import Enum # Colors are disabled in non-TTY environments such as pipes. This means # that if output is redirected to a file, it won't contain color codes. # Colors are always enabled on continuous integration. _colorize = bool(sys.stdout.isatty() or os.environ.get("CI")) class ANSI(Enum): """ Enum class for adding ansi colorcodes directly into strings. Automatically converts values to strings representing their internal value, or an empty string in a non-colorized scope. """ RESET = "\x1b[0m" BOLD = "\x1b[1m" ITALIC = "\x1b[3m" UNDERLINE = "\x1b[4m" STRIKETHROUGH = "\x1b[9m" REGULAR = "\x1b[22;23;24;29m" BLACK = "\x1b[30m" RED = "\x1b[31m" GREEN = "\x1b[32m" YELLOW = "\x1b[33m" BLUE = "\x1b[34m" MAGENTA = "\x1b[35m" CYAN = "\x1b[36m" WHITE = "\x1b[37m" PURPLE = "\x1b[38;5;93m" PINK = "\x1b[38;5;206m" ORANGE = "\x1b[38;5;214m" GRAY = "\x1b[38;5;244m" def __str__(self) -> str: global _colorize return str(self.value) if _colorize else "" def no_verbose(env): colors = [ANSI.BLUE, ANSI.BOLD, ANSI.REGULAR, ANSI.RESET] # There is a space before "..." to ensure that source file names can be # Ctrl + clicked in the VS Code terminal. compile_source_message = "{}Compiling {}$SOURCE{} ...{}".format(*colors) java_compile_source_message = "{}Compiling {}$SOURCE{} ...{}".format(*colors) compile_shared_source_message = "{}Compiling shared {}$SOURCE{} ...{}".format(*colors) link_program_message = "{}Linking Program {}$TARGET{} ...{}".format(*colors) link_library_message = "{}Linking Static Library {}$TARGET{} ...{}".format(*colors) ranlib_library_message = "{}Ranlib Library {}$TARGET{} ...{}".format(*colors) link_shared_library_message = "{}Linking Shared Library {}$TARGET{} ...{}".format(*colors) java_library_message = "{}Creating Java Archive {}$TARGET{} ...{}".format(*colors) compiled_resource_message = "{}Creating Compiled Resource {}$TARGET{} ...{}".format(*colors) generated_file_message = "{}Generating {}$TARGET{} ...{}".format(*colors) env["CXXCOMSTR"] = compile_source_message env["CCCOMSTR"] = compile_source_message env["SHCCCOMSTR"] = compile_shared_source_message env["SHCXXCOMSTR"] = compile_shared_source_message env["ARCOMSTR"] = link_library_message env["RANLIBCOMSTR"] = ranlib_library_message env["SHLINKCOMSTR"] = link_shared_library_message env["LINKCOMSTR"] = link_program_message env["JARCOMSTR"] = java_library_message env["JAVACCOMSTR"] = java_compile_source_message env["RCCOMSTR"] = compiled_resource_message env["GENCOMSTR"] = generated_file_message def disable_warnings(self): # 'self' is the environment if self["platform"] == "windows" and not self["use_mingw"]: # We have to remove existing warning level defines before appending /w, # otherwise we get: "warning D9025 : overriding '/W3' with '/w'" warn_flags = ["/Wall", "/W4", "/W3", "/W2", "/W1", "/WX"] self.Append(CCFLAGS=["/w"]) self.Append(CFLAGS=["/w"]) self.Append(CXXFLAGS=["/w"]) self["CCFLAGS"] = [x for x in self["CCFLAGS"] if x not in warn_flags] self["CFLAGS"] = [x for x in self["CFLAGS"] if x not in warn_flags] self["CXXFLAGS"] = [x for x in self["CXXFLAGS"] if x not in warn_flags] else: self.Append(CCFLAGS=["-w"]) self.Append(CFLAGS=["-w"]) self.Append(CXXFLAGS=["-w"]) def make_icu_data(target, source, env): dst = target[0].srcnode().abspath with open(dst, "w", encoding="utf-8", newline="\n") as g: g.write("/* THIS FILE IS GENERATED DO NOT EDIT */\n") g.write("/* (C) 2016 and later: Unicode, Inc. and others. */\n") g.write("/* License & terms of use: https://www.unicode.org/copyright.html */\n") g.write("#ifndef _ICU_DATA_H\n") g.write("#define _ICU_DATA_H\n") g.write('#include "unicode/utypes.h"\n') g.write('#include "unicode/udata.h"\n') g.write('#include "unicode/uversion.h"\n') with open(source[0].srcnode().abspath, "rb") as f: buf = f.read() g.write('extern "C" U_EXPORT const size_t U_ICUDATA_SIZE = ' + str(len(buf)) + ";\n") g.write('extern "C" U_EXPORT const unsigned char U_ICUDATA_ENTRY_POINT[] = {\n') for i in range(len(buf)): g.write("\t" + str(buf[i]) + ",\n") g.write("};\n") g.write("#endif") def write_macos_plist(target, binary_name, identifier, name): os.makedirs(f"{target}/Resource/", exist_ok=True) with open(f"{target}/Resource/Info.plist", "w", encoding="utf-8", newline="\n") as f: f.write(f"""\ CFBundleExecutable {binary_name} CFBundleIdentifier {identifier} CFBundleInfoDictionaryVersion 6.0 CFBundleName {name} CFBundlePackageType FMWK CFBundleShortVersionString 1.0.0 CFBundleSupportedPlatforms MacOSX CFBundleVersion 1.0.0 LSMinimumSystemVersion 10.14 """)