|
@ -62,7 +62,14 @@ generator_wants_sorted_dependencies = False |
|
|
|
|
|
|
|
|
def GetFlavor(params): |
|
|
def GetFlavor(params): |
|
|
"""Returns |params.flavor| if it's set, the system's default flavor else.""" |
|
|
"""Returns |params.flavor| if it's set, the system's default flavor else.""" |
|
|
return params.get('flavor', 'mac' if sys.platform == 'darwin' else 'linux') |
|
|
flavors = { |
|
|
|
|
|
'darwin': 'mac', |
|
|
|
|
|
'sunos5': 'solaris', |
|
|
|
|
|
'freebsd7': 'freebsd', |
|
|
|
|
|
'freebsd8': 'freebsd', |
|
|
|
|
|
} |
|
|
|
|
|
flavor = flavors.get(sys.platform, 'linux') |
|
|
|
|
|
return params.get('flavor', flavor) |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
def CalculateVariables(default_variables, params): |
|
|
def CalculateVariables(default_variables, params): |
|
@ -71,7 +78,8 @@ def CalculateVariables(default_variables, params): |
|
|
default_variables['LINKER_SUPPORTS_ICF'] = \ |
|
|
default_variables['LINKER_SUPPORTS_ICF'] = \ |
|
|
gyp.system_test.TestLinkerSupportsICF(cc_command=cc_target) |
|
|
gyp.system_test.TestLinkerSupportsICF(cc_command=cc_target) |
|
|
|
|
|
|
|
|
if GetFlavor(params) == 'mac': |
|
|
flavor = GetFlavor(params) |
|
|
|
|
|
if flavor == 'mac': |
|
|
default_variables.setdefault('OS', 'mac') |
|
|
default_variables.setdefault('OS', 'mac') |
|
|
default_variables.setdefault('SHARED_LIB_SUFFIX', '.dylib') |
|
|
default_variables.setdefault('SHARED_LIB_SUFFIX', '.dylib') |
|
|
default_variables.setdefault('SHARED_LIB_DIR', |
|
|
default_variables.setdefault('SHARED_LIB_DIR', |
|
@ -94,7 +102,10 @@ def CalculateVariables(default_variables, params): |
|
|
global COMPILABLE_EXTENSIONS |
|
|
global COMPILABLE_EXTENSIONS |
|
|
COMPILABLE_EXTENSIONS.update({'.m': 'objc', '.mm' : 'objcxx'}) |
|
|
COMPILABLE_EXTENSIONS.update({'.m': 'objc', '.mm' : 'objcxx'}) |
|
|
else: |
|
|
else: |
|
|
default_variables.setdefault('OS', 'linux') |
|
|
operating_system = flavor |
|
|
|
|
|
if flavor == 'android': |
|
|
|
|
|
operating_system = 'linux' # Keep this legacy behavior for now. |
|
|
|
|
|
default_variables.setdefault('OS', operating_system) |
|
|
default_variables.setdefault('SHARED_LIB_SUFFIX', '.so') |
|
|
default_variables.setdefault('SHARED_LIB_SUFFIX', '.so') |
|
|
default_variables.setdefault('SHARED_LIB_DIR','$(builddir)/lib.$(TOOLSET)') |
|
|
default_variables.setdefault('SHARED_LIB_DIR','$(builddir)/lib.$(TOOLSET)') |
|
|
default_variables.setdefault('LIB_DIR', '$(obj).$(TOOLSET)') |
|
|
default_variables.setdefault('LIB_DIR', '$(obj).$(TOOLSET)') |
|
@ -349,7 +360,7 @@ cmd_cc = $(CC.$(TOOLSET)) $(GYP_CFLAGS) $(DEPFLAGS) $(CFLAGS.$(TOOLSET)) -c -o $ |
|
|
|
|
|
|
|
|
quiet_cmd_cxx = CXX($(TOOLSET)) $@ |
|
|
quiet_cmd_cxx = CXX($(TOOLSET)) $@ |
|
|
cmd_cxx = $(CXX.$(TOOLSET)) $(GYP_CXXFLAGS) $(DEPFLAGS) $(CXXFLAGS.$(TOOLSET)) -c -o $@ $< |
|
|
cmd_cxx = $(CXX.$(TOOLSET)) $(GYP_CXXFLAGS) $(DEPFLAGS) $(CXXFLAGS.$(TOOLSET)) -c -o $@ $< |
|
|
%(mac_commands)s |
|
|
%(extra_commands)s |
|
|
quiet_cmd_touch = TOUCH $@ |
|
|
quiet_cmd_touch = TOUCH $@ |
|
|
cmd_touch = touch $@ |
|
|
cmd_touch = touch $@ |
|
|
|
|
|
|
|
@ -480,6 +491,14 @@ quiet_cmd_mac_package_framework = PACKAGE FRAMEWORK $@ |
|
|
cmd_mac_package_framework = ./gyp-mac-tool package-framework "$@" $(4) |
|
|
cmd_mac_package_framework = ./gyp-mac-tool package-framework "$@" $(4) |
|
|
""" |
|
|
""" |
|
|
|
|
|
|
|
|
|
|
|
SHARED_HEADER_SUN_COMMANDS = """ |
|
|
|
|
|
# gyp-sun-tool is written next to the root Makefile by gyp. |
|
|
|
|
|
# Use $(4) for the command, since $(2) and $(3) are used as flag by do_cmd |
|
|
|
|
|
# already. |
|
|
|
|
|
quiet_cmd_sun_tool = SUNTOOL $(4) $< |
|
|
|
|
|
cmd_sun_tool = ./gyp-sun-tool $(4) $< "$@" |
|
|
|
|
|
""" |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
def WriteRootHeaderSuffixRules(writer): |
|
|
def WriteRootHeaderSuffixRules(writer): |
|
|
extensions = sorted(COMPILABLE_EXTENSIONS.keys(), key=str.lower) |
|
|
extensions = sorted(COMPILABLE_EXTENSIONS.keys(), key=str.lower) |
|
@ -2407,11 +2426,13 @@ $(obj).$(TOOLSET)/$(TARGET)/%%.o: $(obj)/%%%s FORCE_DO_CMD |
|
|
env['UNLOCALIZED_RESOURCES_FOLDER_PATH'] = \ |
|
|
env['UNLOCALIZED_RESOURCES_FOLDER_PATH'] = \ |
|
|
self.xcode_settings.GetBundleResourceFolder() |
|
|
self.xcode_settings.GetBundleResourceFolder() |
|
|
env['INFOPLIST_PATH'] = self.xcode_settings.GetBundlePlistPath() |
|
|
env['INFOPLIST_PATH'] = self.xcode_settings.GetBundlePlistPath() |
|
|
|
|
|
env['WRAPPER_NAME'] = self.xcode_settings.GetWrapperName() |
|
|
|
|
|
|
|
|
# TODO(thakis): Remove this. |
|
|
# TODO(thakis): Remove this. |
|
|
env['EXECUTABLE_PATH'] = QuoteSpaces(env['EXECUTABLE_PATH']) |
|
|
env['EXECUTABLE_PATH'] = QuoteSpaces(env['EXECUTABLE_PATH']) |
|
|
env['CONTENTS_FOLDER_PATH'] = QuoteSpaces(env['CONTENTS_FOLDER_PATH']) |
|
|
env['CONTENTS_FOLDER_PATH'] = QuoteSpaces(env['CONTENTS_FOLDER_PATH']) |
|
|
env['INFOPLIST_PATH'] = QuoteSpaces(env['INFOPLIST_PATH']) |
|
|
env['INFOPLIST_PATH'] = QuoteSpaces(env['INFOPLIST_PATH']) |
|
|
|
|
|
env['WRAPPER_NAME'] = QuoteSpaces(env['WRAPPER_NAME']) |
|
|
|
|
|
|
|
|
return env |
|
|
return env |
|
|
|
|
|
|
|
@ -2576,17 +2597,32 @@ def RunSystemTests(flavor): |
|
|
'LINK_flags': link_flags } |
|
|
'LINK_flags': link_flags } |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
def CopyMacTool(out_path): |
|
|
def CopyTool(flavor, out_path): |
|
|
"""Finds mac_tool.gyp in the gyp directory and copies it to |out_path|.""" |
|
|
"""Finds (mac|sun)_tool.gyp in the gyp directory and copies it |
|
|
|
|
|
to |out_path|.""" |
|
|
|
|
|
prefix = { 'solaris': 'sun', 'mac': 'mac' }.get(flavor, None) |
|
|
|
|
|
if not prefix: |
|
|
|
|
|
return |
|
|
|
|
|
|
|
|
|
|
|
tool_path = os.path.join(out_path, 'gyp-%s-tool' % prefix) |
|
|
|
|
|
if os.path.exists(tool_path): |
|
|
|
|
|
os.remove(tool_path) |
|
|
|
|
|
|
|
|
|
|
|
# Slurp input file. |
|
|
source_path = os.path.join( |
|
|
source_path = os.path.join( |
|
|
os.path.dirname(os.path.abspath(__file__)), '..', 'mac_tool.py') |
|
|
os.path.dirname(os.path.abspath(__file__)), '..', '%s_tool.py' % prefix) |
|
|
source_file = open(source_path) |
|
|
source_file = open(source_path) |
|
|
source = source_file.readlines() |
|
|
source = source_file.readlines() |
|
|
source_file.close() |
|
|
source_file.close() |
|
|
mactool_file = open(out_path, 'w') |
|
|
|
|
|
mactool_file.write( |
|
|
# Add header and write it out. |
|
|
|
|
|
tool_file = open(tool_path, 'w') |
|
|
|
|
|
tool_file.write( |
|
|
''.join([source[0], '# Generated by gyp. Do not edit.\n'] + source[1:])) |
|
|
''.join([source[0], '# Generated by gyp. Do not edit.\n'] + source[1:])) |
|
|
mactool_file.close() |
|
|
tool_file.close() |
|
|
|
|
|
|
|
|
|
|
|
# Make file executable. |
|
|
|
|
|
os.chmod(tool_path, 0755) |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
def GenerateOutput(target_list, target_dicts, data, params): |
|
|
def GenerateOutput(target_list, target_dicts, data, params): |
|
@ -2641,7 +2677,7 @@ def GenerateOutput(target_list, target_dicts, data, params): |
|
|
'flock': flock_command, |
|
|
'flock': flock_command, |
|
|
'flock_index': 1, |
|
|
'flock_index': 1, |
|
|
'link_commands': LINK_COMMANDS_LINUX, |
|
|
'link_commands': LINK_COMMANDS_LINUX, |
|
|
'mac_commands': '', |
|
|
'extra_commands': '', |
|
|
'srcdir': srcdir, |
|
|
'srcdir': srcdir, |
|
|
} |
|
|
} |
|
|
if flavor == 'mac': |
|
|
if flavor == 'mac': |
|
@ -2650,12 +2686,22 @@ def GenerateOutput(target_list, target_dicts, data, params): |
|
|
'flock': flock_command, |
|
|
'flock': flock_command, |
|
|
'flock_index': 2, |
|
|
'flock_index': 2, |
|
|
'link_commands': LINK_COMMANDS_MAC, |
|
|
'link_commands': LINK_COMMANDS_MAC, |
|
|
'mac_commands': SHARED_HEADER_MAC_COMMANDS, |
|
|
'extra_commands': SHARED_HEADER_MAC_COMMANDS, |
|
|
}) |
|
|
}) |
|
|
if flavor == 'android': |
|
|
elif flavor == 'android': |
|
|
header_params.update({ |
|
|
header_params.update({ |
|
|
'link_commands': LINK_COMMANDS_ANDROID, |
|
|
'link_commands': LINK_COMMANDS_ANDROID, |
|
|
}) |
|
|
}) |
|
|
|
|
|
elif flavor == 'solaris': |
|
|
|
|
|
header_params.update({ |
|
|
|
|
|
'flock': './gyp-sun-tool flock', |
|
|
|
|
|
'flock_index': 2, |
|
|
|
|
|
'extra_commands': SHARED_HEADER_SUN_COMMANDS, |
|
|
|
|
|
}) |
|
|
|
|
|
elif flavor == 'freebsd': |
|
|
|
|
|
header_params.update({ |
|
|
|
|
|
'flock': 'lockf', |
|
|
|
|
|
}) |
|
|
header_params.update(RunSystemTests(flavor)) |
|
|
header_params.update(RunSystemTests(flavor)) |
|
|
|
|
|
|
|
|
build_file, _, _ = gyp.common.ParseQualifiedTarget(target_list[0]) |
|
|
build_file, _, _ = gyp.common.ParseQualifiedTarget(target_list[0]) |
|
@ -2693,13 +2739,8 @@ def GenerateOutput(target_list, target_dicts, data, params): |
|
|
WriteRootHeaderSuffixRules(root_makefile) |
|
|
WriteRootHeaderSuffixRules(root_makefile) |
|
|
|
|
|
|
|
|
# Put mac_tool next to the root Makefile. |
|
|
# Put mac_tool next to the root Makefile. |
|
|
if flavor == 'mac': |
|
|
dest_path = os.path.dirname(makefile_path) |
|
|
mactool_path = os.path.join(os.path.dirname(makefile_path), 'gyp-mac-tool') |
|
|
CopyTool(flavor, dest_path) |
|
|
if os.path.exists(mactool_path): |
|
|
|
|
|
os.remove(mactool_path) |
|
|
|
|
|
CopyMacTool(mactool_path) |
|
|
|
|
|
# Make file executable. |
|
|
|
|
|
os.chmod(mactool_path, 0755) |
|
|
|
|
|
|
|
|
|
|
|
# Find the list of targets that derive from the gyp file(s) being built. |
|
|
# Find the list of targets that derive from the gyp file(s) being built. |
|
|
needed_targets = set() |
|
|
needed_targets = set() |
|
|