mirror of
https://github.com/nodejs/node.git
synced 2024-11-21 10:59:27 +00:00
tools: git rm -r tools/v8_gypfiles/broken
PR-URL: https://github.com/nodejs/node/pull/30149 Reviewed-By: Michaël Zasso <targos@protonmail.com> Reviewed-By: Ben Noordhuis <info@bnoordhuis.nl> Reviewed-By: Richard Lau <riclau@uk.ibm.com> Reviewed-By: Colin Ihrig <cjihrig@gmail.com> Reviewed-By: Luigi Pinca <luigipinca@gmail.com> Reviewed-By: Jiawen Geng <technicalcute@gmail.com>
This commit is contained in:
parent
99c1238f54
commit
1f080fcb47
@ -1,29 +0,0 @@
|
||||
# Copyright 2011 the V8 project authors. All rights reserved.
|
||||
# Use of this source code is governed by a BSD-style license that can be
|
||||
# found in the LICENSE file.
|
||||
|
||||
{
|
||||
'targets': [
|
||||
{
|
||||
'target_name': 'All',
|
||||
'type': 'none',
|
||||
'dependencies': [
|
||||
'd8.gyp:d8',
|
||||
'mkgrokdump.gyp:*',
|
||||
],
|
||||
'conditions': [
|
||||
['component!="shared_library"', {
|
||||
'dependencies': [
|
||||
'parser-shell.gyp:parser-shell',
|
||||
],
|
||||
}],
|
||||
# These items don't compile for Android on Mac.
|
||||
['host_os!="mac" or OS!="android"', {
|
||||
'dependencies': [
|
||||
'samples.gyp:*',
|
||||
],
|
||||
}],
|
||||
]
|
||||
}
|
||||
]
|
||||
}
|
@ -1,38 +0,0 @@
|
||||
#!/usr/bin/env python
|
||||
# Copyright 2016 the V8 project authors. All rights reserved.
|
||||
# Use of this source code is governed by a BSD-style license that can be
|
||||
# found in the LICENSE file.
|
||||
|
||||
# CC/CXX wrapper script that excludes certain file patterns from coverage
|
||||
# instrumentation.
|
||||
|
||||
import re
|
||||
import subprocess
|
||||
import sys
|
||||
|
||||
exclusions = [
|
||||
'buildtools',
|
||||
'src/third_party',
|
||||
'third_party',
|
||||
'test',
|
||||
'testing',
|
||||
]
|
||||
|
||||
def remove_if_exists(string_list, item):
|
||||
if item in string_list:
|
||||
string_list.remove(item)
|
||||
|
||||
args = sys.argv[1:]
|
||||
text = ' '.join(sys.argv[2:])
|
||||
for exclusion in exclusions:
|
||||
if re.search(r'\-o obj/%s[^ ]*\.o' % exclusion, text):
|
||||
remove_if_exists(args, '-fprofile-arcs')
|
||||
remove_if_exists(args, '-ftest-coverage')
|
||||
remove_if_exists(args, '-fsanitize-coverage=func')
|
||||
remove_if_exists(args, '-fsanitize-coverage=bb')
|
||||
remove_if_exists(args, '-fsanitize-coverage=edge')
|
||||
remove_if_exists(args, '-fsanitize-coverage=trace-pc-guard')
|
||||
remove_if_exists(args, '-fsanitize-coverage=bb,trace-pc-guard')
|
||||
break
|
||||
|
||||
sys.exit(subprocess.check_call(args))
|
@ -1,57 +0,0 @@
|
||||
# Copyright 2015 the V8 project authors. All rights reserved.
|
||||
# Use of this source code is governed by a BSD-style license that can be
|
||||
# found in the LICENSE file.
|
||||
|
||||
"""
|
||||
Sets up various automatic gyp environment variables. These are used by
|
||||
gyp_v8 and landmines.py which run at different stages of runhooks. To
|
||||
make sure settings are consistent between them, all setup should happen here.
|
||||
"""
|
||||
|
||||
import os
|
||||
import sys
|
||||
|
||||
SCRIPT_DIR = os.path.dirname(os.path.realpath(__file__))
|
||||
V8_ROOT = os.path.abspath(os.path.join(SCRIPT_DIR, os.pardir))
|
||||
|
||||
|
||||
def apply_gyp_environment(file_path=None):
|
||||
"""
|
||||
Reads in a *.gyp_env file and applies the valid keys to os.environ.
|
||||
"""
|
||||
if not file_path or not os.path.exists(file_path):
|
||||
return
|
||||
file_contents = open(file_path).read()
|
||||
try:
|
||||
file_data = eval(file_contents, {'__builtins__': None}, None)
|
||||
except SyntaxError, e:
|
||||
e.filename = os.path.abspath(file_path)
|
||||
raise
|
||||
supported_vars = ( 'V8_GYP_FILE',
|
||||
'V8_GYP_SYNTAX_CHECK',
|
||||
'GYP_DEFINES',
|
||||
'GYP_GENERATORS',
|
||||
'GYP_GENERATOR_FLAGS',
|
||||
'GYP_GENERATOR_OUTPUT', )
|
||||
for var in supported_vars:
|
||||
val = file_data.get(var)
|
||||
if val:
|
||||
if var in os.environ:
|
||||
print 'INFO: Environment value for "%s" overrides value in %s.' % (
|
||||
var, os.path.abspath(file_path)
|
||||
)
|
||||
else:
|
||||
os.environ[var] = val
|
||||
|
||||
|
||||
def set_environment():
|
||||
"""Sets defaults for GYP_* variables."""
|
||||
|
||||
if 'SKIP_V8_GYP_ENV' not in os.environ:
|
||||
# Update the environment based on v8.gyp_env
|
||||
gyp_env_path = os.path.join(os.path.dirname(V8_ROOT), 'v8.gyp_env')
|
||||
apply_gyp_environment(gyp_env_path)
|
||||
|
||||
if not os.environ.get('GYP_GENERATORS'):
|
||||
# Default to ninja on all platforms.
|
||||
os.environ['GYP_GENERATORS'] = 'ninja'
|
@ -1,189 +0,0 @@
|
||||
#!/usr/bin/env python
|
||||
#
|
||||
# Copyright 2012 the V8 project authors. All rights reserved.
|
||||
# Redistribution and use in source and binary forms, with or without
|
||||
# modification, are permitted provided that the following conditions are
|
||||
# met:
|
||||
#
|
||||
# * Redistributions of source code must retain the above copyright
|
||||
# notice, this list of conditions and the following disclaimer.
|
||||
# * Redistributions in binary form must reproduce the above
|
||||
# copyright notice, this list of conditions and the following
|
||||
# disclaimer in the documentation and/or other materials provided
|
||||
# with the distribution.
|
||||
# * Neither the name of Google Inc. nor the names of its
|
||||
# contributors may be used to endorse or promote products derived
|
||||
# from this software without specific prior written permission.
|
||||
#
|
||||
# THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
|
||||
# "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
|
||||
# LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
|
||||
# A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
|
||||
# OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
|
||||
# SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
|
||||
# LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
|
||||
# DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
|
||||
# THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
|
||||
# (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
|
||||
# OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
||||
|
||||
# This script is wrapper for V8 that adds some support for how GYP
|
||||
# is invoked by V8 beyond what can be done in the gclient hooks.
|
||||
|
||||
import argparse
|
||||
import glob
|
||||
import os
|
||||
import platform
|
||||
import shlex
|
||||
import sys
|
||||
|
||||
script_dir = os.path.dirname(os.path.realpath(__file__))
|
||||
sys.path.insert(0, script_dir)
|
||||
import gyp_environment
|
||||
|
||||
v8_root = os.path.abspath(os.path.join(script_dir, os.pardir))
|
||||
|
||||
sys.path.insert(0, os.path.join(v8_root, 'tools', 'gyp', 'pylib'))
|
||||
import gyp
|
||||
|
||||
# Add paths so that pymod_do_main(...) can import files.
|
||||
sys.path.insert(
|
||||
1, os.path.abspath(os.path.join(v8_root, 'tools', 'generate_shim_headers')))
|
||||
sys.path.append(
|
||||
os.path.abspath(os.path.join(v8_root, 'third_party', 'binutils')))
|
||||
|
||||
def GetOutputDirectory():
|
||||
"""Returns the output directory that GYP will use."""
|
||||
|
||||
# Handle command line generator flags.
|
||||
parser = argparse.ArgumentParser()
|
||||
parser.add_argument('-G', dest='genflags', default=[], action='append')
|
||||
genflags = parser.parse_known_args()[0].genflags
|
||||
|
||||
# Handle generator flags from the environment.
|
||||
genflags += shlex.split(os.environ.get('GYP_GENERATOR_FLAGS', ''))
|
||||
|
||||
needle = 'output_dir='
|
||||
for item in genflags:
|
||||
if item.startswith(needle):
|
||||
return item[len(needle):]
|
||||
|
||||
return 'out'
|
||||
|
||||
|
||||
def additional_include_files(args=[]):
|
||||
"""
|
||||
Returns a list of additional (.gypi) files to include, without
|
||||
duplicating ones that are already specified on the command line.
|
||||
"""
|
||||
# Determine the include files specified on the command line.
|
||||
# This doesn't cover all the different option formats you can use,
|
||||
# but it's mainly intended to avoid duplicating flags on the automatic
|
||||
# makefile regeneration which only uses this format.
|
||||
specified_includes = set()
|
||||
for arg in args:
|
||||
if arg.startswith('-I') and len(arg) > 2:
|
||||
specified_includes.add(os.path.realpath(arg[2:]))
|
||||
|
||||
result = []
|
||||
def AddInclude(path):
|
||||
if os.path.realpath(path) not in specified_includes:
|
||||
result.append(path)
|
||||
|
||||
# Always include standalone.gypi
|
||||
AddInclude(os.path.join(v8_root, 'gypfiles', 'standalone.gypi'))
|
||||
|
||||
# Optionally add supplemental .gypi files if present.
|
||||
supplements = glob.glob(os.path.join(v8_root, '*', 'supplement.gypi'))
|
||||
for supplement in supplements:
|
||||
AddInclude(supplement)
|
||||
|
||||
return result
|
||||
|
||||
|
||||
def run_gyp(args):
|
||||
if gyp.main(args) != 0:
|
||||
print 'Error running GYP'
|
||||
sys.exit(rc)
|
||||
|
||||
|
||||
if __name__ == '__main__':
|
||||
args = sys.argv[1:]
|
||||
|
||||
gyp_chromium_no_action = os.environ.get('GYP_CHROMIUM_NO_ACTION')
|
||||
if gyp_chromium_no_action == '1':
|
||||
print 'Skipping gyp_v8 due to GYP_CHROMIUM_NO_ACTION env var.'
|
||||
sys.exit(0)
|
||||
|
||||
running_as_hook = '--running-as-hook'
|
||||
if running_as_hook in args and gyp_chromium_no_action != '0':
|
||||
print 'GYP is now disabled by default in runhooks.\n'
|
||||
print 'If you really want to run this, either run '
|
||||
print '`python gypfiles/gyp_v8` explicitly by hand '
|
||||
print 'or set the environment variable GYP_CHROMIUM_NO_ACTION=0.'
|
||||
sys.exit(0)
|
||||
|
||||
if running_as_hook in args:
|
||||
args.remove(running_as_hook)
|
||||
|
||||
gyp_environment.set_environment()
|
||||
|
||||
# This could give false positives since it doesn't actually do real option
|
||||
# parsing. Oh well.
|
||||
gyp_file_specified = False
|
||||
for arg in args:
|
||||
if arg.endswith('.gyp'):
|
||||
gyp_file_specified = True
|
||||
break
|
||||
|
||||
# If we didn't get a file, check an env var, and then fall back to
|
||||
# assuming 'all.gyp' from the same directory as the script.
|
||||
if not gyp_file_specified:
|
||||
gyp_file = os.environ.get('V8_GYP_FILE')
|
||||
if gyp_file:
|
||||
# Note that V8_GYP_FILE values can't have backslashes as
|
||||
# path separators even on Windows due to the use of shlex.split().
|
||||
args.extend(shlex.split(gyp_file))
|
||||
else:
|
||||
args.append(os.path.join(script_dir, 'all.gyp'))
|
||||
|
||||
args.extend(['-I' + i for i in additional_include_files(args)])
|
||||
|
||||
# There shouldn't be a circular dependency relationship between .gyp files
|
||||
args.append('--no-circular-check')
|
||||
|
||||
# Set the GYP DEPTH variable to the root of the V8 project.
|
||||
args.append('--depth=' + os.path.relpath(v8_root))
|
||||
|
||||
# If V8_GYP_SYNTAX_CHECK is set to 1, it will invoke gyp with --check
|
||||
# to enfore syntax checking.
|
||||
syntax_check = os.environ.get('V8_GYP_SYNTAX_CHECK')
|
||||
if syntax_check and int(syntax_check):
|
||||
args.append('--check')
|
||||
|
||||
print 'Updating projects from gyp files...'
|
||||
sys.stdout.flush()
|
||||
|
||||
# Generate for the architectures supported on the given platform.
|
||||
gyp_args = list(args)
|
||||
gyp_args.extend(['-D', 'gyp_output_dir=' + GetOutputDirectory()])
|
||||
gyp_generators = os.environ.get('GYP_GENERATORS', '')
|
||||
if platform.system() == 'Linux' and gyp_generators != 'ninja':
|
||||
# Work around for crbug.com/331475.
|
||||
for f in glob.glob(os.path.join(v8_root, 'out', 'Makefile.*')):
|
||||
os.unlink(f)
|
||||
# --generator-output defines where the Makefile goes.
|
||||
gyp_args.append('--generator-output=out')
|
||||
# -Goutput_dir defines where the build output goes, relative to the
|
||||
# Makefile. Set it to . so that the build output doesn't end up in out/out.
|
||||
gyp_args.append('-Goutput_dir=.')
|
||||
|
||||
gyp_defines = os.environ.get('GYP_DEFINES', '')
|
||||
|
||||
# Automatically turn on crosscompile support for platforms that need it.
|
||||
if all(('ninja' in gyp_generators,
|
||||
'OS=android' in gyp_defines,
|
||||
'GYP_CROSSCOMPILE' not in os.environ)):
|
||||
os.environ['GYP_CROSSCOMPILE'] = '1'
|
||||
|
||||
run_gyp(gyp_args)
|
@ -1,41 +0,0 @@
|
||||
# Copyright 2013 the V8 project authors. All rights reserved.
|
||||
# Redistribution and use in source and binary forms, with or without
|
||||
# modification, are permitted provided that the following conditions are
|
||||
# met:
|
||||
#
|
||||
# * Redistributions of source code must retain the above copyright
|
||||
# notice, this list of conditions and the following disclaimer.
|
||||
# * Redistributions in binary form must reproduce the above
|
||||
# copyright notice, this list of conditions and the following
|
||||
# disclaimer in the documentation and/or other materials provided
|
||||
# with the distribution.
|
||||
# * Neither the name of Google Inc. nor the names of its
|
||||
# contributors may be used to endorse or promote products derived
|
||||
# from this software without specific prior written permission.
|
||||
#
|
||||
# THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
|
||||
# "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
|
||||
# LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
|
||||
# A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
|
||||
# OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
|
||||
# SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
|
||||
# LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
|
||||
# DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
|
||||
# THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
|
||||
# (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
|
||||
# OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
||||
|
||||
# This file is (possibly, depending on python version) imported by
|
||||
# gyp_v8 when GYP_PARALLEL=1 and it creates sub-processes through the
|
||||
# multiprocessing library.
|
||||
|
||||
# Importing in Python 2.6 (fixed in 2.7) on Windows doesn't search for imports
|
||||
# that don't end in .py (and aren't directories with an __init__.py). This
|
||||
# wrapper makes "import gyp_v8" work with those old versions and makes it
|
||||
# possible to execute gyp_v8.py directly on Windows where the extension is
|
||||
# useful.
|
||||
|
||||
import os
|
||||
|
||||
path = os.path.abspath(os.path.split(__file__)[0])
|
||||
execfile(os.path.join(path, 'gyp_v8'))
|
@ -1,31 +0,0 @@
|
||||
# Copyright 2015 the V8 project authors. All rights reserved.
|
||||
# Use of this source code is governed by a BSD-style license that can be
|
||||
# found in the LICENSE file.
|
||||
|
||||
{
|
||||
'targets': [
|
||||
{
|
||||
'target_name': 'asan_dynamic_runtime',
|
||||
'toolsets': ['target', 'host'],
|
||||
'type': 'none',
|
||||
'variables': {
|
||||
# Every target is going to depend on asan_dynamic_runtime, so allow
|
||||
# this one to depend on itself.
|
||||
'prune_self_dependency': 1,
|
||||
# Path is relative to this GYP file.
|
||||
'asan_rtl_mask_path':
|
||||
'../../third_party/llvm-build/Release+Asserts/lib/clang/*/lib/darwin',
|
||||
'asan_osx_dynamic':
|
||||
'<(asan_rtl_mask_path)/libclang_rt.asan_osx_dynamic.dylib',
|
||||
},
|
||||
'copies': [
|
||||
{
|
||||
'destination': '<(PRODUCT_DIR)',
|
||||
'files': [
|
||||
'<!(/bin/ls <(asan_osx_dynamic))',
|
||||
],
|
||||
},
|
||||
],
|
||||
},
|
||||
],
|
||||
}
|
@ -1,27 +0,0 @@
|
||||
# Copyright 2017 the V8 project authors. All rights reserved.
|
||||
# Use of this source code is governed by a BSD-style license that can be
|
||||
# found in the LICENSE file.
|
||||
|
||||
{
|
||||
'variables': {
|
||||
'v8_code': 1,
|
||||
},
|
||||
'includes': ['toolchain.gypi', 'features.gypi'],
|
||||
'targets': [
|
||||
{
|
||||
'target_name': 'mkgrokdump',
|
||||
'type': 'executable',
|
||||
'dependencies': [
|
||||
'v8.gyp:v8',
|
||||
'v8.gyp:v8_libbase',
|
||||
'v8.gyp:v8_libplatform',
|
||||
],
|
||||
'include_dirs': [
|
||||
'..',
|
||||
],
|
||||
'sources': [
|
||||
'../test/mkgrokdump/mkgrokdump.cc',
|
||||
],
|
||||
},
|
||||
],
|
||||
}
|
@ -1,60 +0,0 @@
|
||||
# Copyright 2013 the V8 project authors. All rights reserved.
|
||||
# Redistribution and use in source and binary forms, with or without
|
||||
# modification, are permitted provided that the following conditions are
|
||||
# met:
|
||||
#
|
||||
# * Redistributions of source code must retain the above copyright
|
||||
# notice, this list of conditions and the following disclaimer.
|
||||
# * Redistributions in binary form must reproduce the above
|
||||
# copyright notice, this list of conditions and the following
|
||||
# disclaimer in the documentation and/or other materials provided
|
||||
# with the distribution.
|
||||
# * Neither the name of Google Inc. nor the names of its
|
||||
# contributors may be used to endorse or promote products derived
|
||||
# from this software without specific prior written permission.
|
||||
#
|
||||
# THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
|
||||
# "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
|
||||
# LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
|
||||
# A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
|
||||
# OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
|
||||
# SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
|
||||
# LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
|
||||
# DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
|
||||
# THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
|
||||
# (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
|
||||
# OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
||||
|
||||
{
|
||||
'variables': {
|
||||
'v8_code': 1,
|
||||
'v8_enable_i18n_support%': 1,
|
||||
},
|
||||
'includes': ['toolchain.gypi', 'features.gypi'],
|
||||
'targets': [
|
||||
{
|
||||
'target_name': 'parser-shell',
|
||||
'type': 'executable',
|
||||
'dependencies': [
|
||||
'v8.gyp:v8',
|
||||
'v8.gyp:v8_libbase',
|
||||
'v8.gyp:v8_libplatform',
|
||||
],
|
||||
'conditions': [
|
||||
['v8_enable_i18n_support==1', {
|
||||
'dependencies': [
|
||||
'<(icu_gyp_path):icui18n',
|
||||
'<(icu_gyp_path):icuuc',
|
||||
],
|
||||
}],
|
||||
],
|
||||
'include_dirs+': [
|
||||
'..',
|
||||
],
|
||||
'sources': [
|
||||
'../tools/parser-shell.cc',
|
||||
'../tools/shell-utils.h',
|
||||
],
|
||||
},
|
||||
],
|
||||
}
|
@ -1,61 +0,0 @@
|
||||
# Copyright 2012 the V8 project authors. All rights reserved.
|
||||
# Use of this source code is governed by a BSD-style license that can be
|
||||
# found in the LICENSE file.
|
||||
|
||||
{
|
||||
'variables': {
|
||||
'v8_code': 1,
|
||||
'v8_enable_i18n_support%': 1,
|
||||
'v8_toolset_for_shell%': 'target',
|
||||
},
|
||||
'includes': ['toolchain.gypi', 'features.gypi'],
|
||||
'target_defaults': {
|
||||
'type': 'executable',
|
||||
'dependencies': [
|
||||
'v8.gyp:v8',
|
||||
'v8.gyp:v8_libbase',
|
||||
'v8.gyp:v8_libplatform',
|
||||
],
|
||||
'include_dirs': [
|
||||
'..',
|
||||
],
|
||||
'conditions': [
|
||||
['v8_enable_i18n_support==1', {
|
||||
'dependencies': [
|
||||
'<(icu_gyp_path):icui18n',
|
||||
'<(icu_gyp_path):icuuc',
|
||||
],
|
||||
}],
|
||||
['OS=="win" and v8_enable_i18n_support==1', {
|
||||
'dependencies': [
|
||||
'<(icu_gyp_path):icudata',
|
||||
],
|
||||
}],
|
||||
],
|
||||
},
|
||||
'targets': [
|
||||
{
|
||||
'target_name': 'v8_shell',
|
||||
'sources': [
|
||||
'../samples/shell.cc',
|
||||
],
|
||||
'conditions': [
|
||||
[ 'want_separate_host_toolset==1', {
|
||||
'toolsets': [ '<(v8_toolset_for_shell)', ],
|
||||
}],
|
||||
],
|
||||
},
|
||||
{
|
||||
'target_name': 'hello-world',
|
||||
'sources': [
|
||||
'../samples/hello-world.cc',
|
||||
],
|
||||
},
|
||||
{
|
||||
'target_name': 'process',
|
||||
'sources': [
|
||||
'../samples/process.cc',
|
||||
],
|
||||
},
|
||||
],
|
||||
}
|
@ -1,59 +0,0 @@
|
||||
# Copyright 2016 the V8 project authors. All rights reserved.
|
||||
# Copyright (c) 2014 The Chromium Authors. All rights reserved.
|
||||
# Use of this source code is governed by a BSD-style license that can be
|
||||
# found in the LICENSE file.
|
||||
|
||||
# This file is meant to be included to set clang-specific compiler flags.
|
||||
# To use this the following variable can be defined:
|
||||
# clang_warning_flags: list: Compiler flags to pass to clang.
|
||||
# clang_warning_flags_unset: list: Compiler flags to not pass to clang.
|
||||
#
|
||||
# Only use this in third-party code. In chromium_code, fix your code to not
|
||||
# warn instead!
|
||||
#
|
||||
# Note that the gypi file is included in target_defaults, so it does not need
|
||||
# to be explicitly included.
|
||||
#
|
||||
# Warning flags set by this will be used on all platforms. If you want to set
|
||||
# warning flags on only some platforms, you have to do so manually.
|
||||
#
|
||||
# To use this, create a gyp target with the following form:
|
||||
# {
|
||||
# 'target_name': 'my_target',
|
||||
# 'variables': {
|
||||
# 'clang_warning_flags': ['-Wno-awesome-warning'],
|
||||
# 'clang_warning_flags_unset': ['-Wpreviously-set-flag'],
|
||||
# }
|
||||
# }
|
||||
|
||||
{
|
||||
'variables': {
|
||||
'clang_warning_flags_unset%': [], # Provide a default value.
|
||||
},
|
||||
'conditions': [
|
||||
['clang==1', {
|
||||
# This uses >@ instead of @< to also see clang_warning_flags set in
|
||||
# targets directly, not just the clang_warning_flags in target_defaults.
|
||||
'cflags': [ '>@(clang_warning_flags)' ],
|
||||
'cflags!': [ '>@(clang_warning_flags_unset)' ],
|
||||
'xcode_settings': {
|
||||
'WARNING_CFLAGS': ['>@(clang_warning_flags)'],
|
||||
'WARNING_CFLAGS!': ['>@(clang_warning_flags_unset)'],
|
||||
},
|
||||
'msvs_settings': {
|
||||
'VCCLCompilerTool': {
|
||||
'AdditionalOptions': [ '>@(clang_warning_flags)' ],
|
||||
'AdditionalOptions!': [ '>@(clang_warning_flags_unset)' ],
|
||||
},
|
||||
},
|
||||
}],
|
||||
['clang==0 and host_clang==1', {
|
||||
'target_conditions': [
|
||||
['_toolset=="host"', {
|
||||
'cflags': [ '>@(clang_warning_flags)' ],
|
||||
'cflags!': [ '>@(clang_warning_flags_unset)' ],
|
||||
}],
|
||||
],
|
||||
}],
|
||||
],
|
||||
}
|
@ -1,73 +0,0 @@
|
||||
# Copyright 2013 the V8 project authors. All rights reserved.
|
||||
# Redistribution and use in source and binary forms, with or without
|
||||
# modification, are permitted provided that the following conditions are
|
||||
# met:
|
||||
#
|
||||
# * Redistributions of source code must retain the above copyright
|
||||
# notice, this list of conditions and the following disclaimer.
|
||||
# * Redistributions in binary form must reproduce the above
|
||||
# copyright notice, this list of conditions and the following
|
||||
# disclaimer in the documentation and/or other materials provided
|
||||
# with the distribution.
|
||||
# * Neither the name of Google Inc. nor the names of its
|
||||
# contributors may be used to endorse or promote products derived
|
||||
# from this software without specific prior written permission.
|
||||
#
|
||||
# THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
|
||||
# "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
|
||||
# LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
|
||||
# A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
|
||||
# OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
|
||||
# SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
|
||||
# LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
|
||||
# DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
|
||||
# THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
|
||||
# (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
|
||||
# OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
||||
|
||||
# This file is meant to be included into a target to handle shim headers
|
||||
# in a consistent manner. To use this the following variables need to be
|
||||
# defined:
|
||||
# headers_root_path: string: path to directory containing headers
|
||||
# header_filenames: list: list of header file names
|
||||
|
||||
{
|
||||
'variables': {
|
||||
'shim_headers_path': '<(SHARED_INTERMEDIATE_DIR)/shim_headers/<(_target_name)/<(_toolset)',
|
||||
'shim_generator_additional_args%': [],
|
||||
},
|
||||
'include_dirs++': [
|
||||
'<(shim_headers_path)',
|
||||
],
|
||||
'all_dependent_settings': {
|
||||
'include_dirs+++': [
|
||||
'<(shim_headers_path)',
|
||||
],
|
||||
},
|
||||
'actions': [
|
||||
{
|
||||
'variables': {
|
||||
'generator_path': '<(DEPTH)/tools/generate_shim_headers/generate_shim_headers.py',
|
||||
'generator_args': [
|
||||
'--headers-root', '<(headers_root_path)',
|
||||
'--output-directory', '<(shim_headers_path)',
|
||||
'<@(shim_generator_additional_args)',
|
||||
'<@(header_filenames)',
|
||||
],
|
||||
},
|
||||
'action_name': 'generate_<(_target_name)_shim_headers',
|
||||
'inputs': [
|
||||
'<(generator_path)',
|
||||
],
|
||||
'outputs': [
|
||||
'<!@pymod_do_main(generate_shim_headers <@(generator_args) --outputs)',
|
||||
],
|
||||
'action': ['python',
|
||||
'<(generator_path)',
|
||||
'<@(generator_args)',
|
||||
'--generate',
|
||||
],
|
||||
'message': 'Generating <(_target_name) shim headers.',
|
||||
},
|
||||
],
|
||||
}
|
File diff suppressed because it is too large
Load Diff
@ -1,12 +0,0 @@
|
||||
#!/bin/sh
|
||||
# Copyright 2017 the V8 project authors. All rights reserved.
|
||||
# Use of this source code is governed by a BSD-style license that can be
|
||||
# found in the LICENSE file.
|
||||
|
||||
# This is for backwards-compatibility after:
|
||||
# https://codereview.chromium.org/2900193003
|
||||
|
||||
for entry in $@; do
|
||||
echo -L$entry
|
||||
echo -Wl,-rpath-link=$entry
|
||||
done | xargs echo
|
@ -1,55 +0,0 @@
|
||||
# Copyright 2018 the V8 project authors. All rights reserved.
|
||||
# Use of this source code is governed by a BSD-style license that can be
|
||||
# found in the LICENSE file.
|
||||
|
||||
{
|
||||
'variables': {
|
||||
'v8_code': 1,
|
||||
'v8_random_seed%': 314159265,
|
||||
'v8_vector_stores%': 0,
|
||||
'v8_embed_script%': "",
|
||||
'v8_extra_library_files%': [],
|
||||
'mksnapshot_exec': '<(PRODUCT_DIR)/<(EXECUTABLE_PREFIX)mksnapshot<(EXECUTABLE_SUFFIX)',
|
||||
'v8_os_page_size%': 0,
|
||||
},
|
||||
'includes': ['toolchain.gypi', 'features.gypi', 'inspector.gypi'],
|
||||
'targets': [
|
||||
{
|
||||
'target_name': 'v8_monolith',
|
||||
'type': 'none',
|
||||
'direct_dependent_settings': {
|
||||
'include_dirs': [
|
||||
'../include/',
|
||||
],
|
||||
},
|
||||
'actions': [
|
||||
{
|
||||
'action_name': 'build_with_gn',
|
||||
'inputs': [
|
||||
'../tools//node/build_gn.py',
|
||||
],
|
||||
'outputs': [
|
||||
'<(INTERMEDIATE_DIR)/gn/obj/libv8_monolith.a',
|
||||
'<(INTERMEDIATE_DIR)/gn/args.gn',
|
||||
],
|
||||
'action': [
|
||||
'../tools//node/build_gn.py',
|
||||
'--mode', '<(CONFIGURATION_NAME)',
|
||||
'--v8_path', '../',
|
||||
'--build_path', '<(INTERMEDIATE_DIR)/gn',
|
||||
'--host_os', '<(host_os)',
|
||||
'--flag', 'v8_promise_internal_field_count=<(v8_promise_internal_field_count)',
|
||||
'--flag', 'target_cpu="<(target_arch)"',
|
||||
'--flag', 'target_os="<(OS)"',
|
||||
'--flag', 'v8_target_cpu="<(v8_target_arch)"',
|
||||
'--flag', 'v8_embedder_string="<(v8_embedder_string)"',
|
||||
'--flag', 'v8_use_snapshot=<(v8_use_snapshot)',
|
||||
'--flag', 'v8_optimized_debug=<(v8_optimized_debug)',
|
||||
'--flag', 'v8_enable_disassembler=<(v8_enable_disassembler)',
|
||||
'--flag', 'v8_postmortem_support=<(v8_postmortem_support)',
|
||||
],
|
||||
},
|
||||
],
|
||||
},
|
||||
],
|
||||
}
|
@ -1,172 +0,0 @@
|
||||
#!/usr/bin/env python
|
||||
# Copyright 2015 the V8 project authors. All rights reserved.
|
||||
# Use of this source code is governed by a BSD-style license that can be
|
||||
# found in the LICENSE file.
|
||||
|
||||
"""
|
||||
Script to print potentially missing source dependencies based on the actual
|
||||
.h and .cc files in the source tree and which files are included in the gyp
|
||||
and gn files. The latter inclusion is overapproximated.
|
||||
|
||||
TODO(machenbach): If two source files with the same name exist, but only one
|
||||
is referenced from a gyp/gn file, we won't necessarily detect it.
|
||||
"""
|
||||
|
||||
import itertools
|
||||
import re
|
||||
import os
|
||||
import subprocess
|
||||
import sys
|
||||
|
||||
|
||||
V8_BASE = os.path.dirname(os.path.dirname(os.path.realpath(__file__)))
|
||||
|
||||
GYP_FILES = [
|
||||
os.path.join(V8_BASE, 'gypfiles', 'd8.gyp'),
|
||||
os.path.join(V8_BASE, 'gypfiles', 'v8.gyp'),
|
||||
os.path.join(V8_BASE, 'gypfiles', 'inspector.gypi'),
|
||||
os.path.join(V8_BASE, 'gypfiles', 'v8vtune.gyp'),
|
||||
os.path.join(V8_BASE, 'gypfiles', 'samples.gyp'),
|
||||
os.path.join(V8_BASE, 'gypfiles', 'mkgrokdump.gyp'),
|
||||
os.path.join(V8_BASE, 'gypfiles', 'parser-shell.gyp'),
|
||||
]
|
||||
|
||||
ALL_GYP_PREFIXES = [
|
||||
'..',
|
||||
'common',
|
||||
os.path.join('src', 'third_party', 'vtune'),
|
||||
'src',
|
||||
'samples',
|
||||
'testing',
|
||||
'tools',
|
||||
os.path.join('test', 'common'),
|
||||
os.path.join('test', 'inspector'),
|
||||
os.path.join('test', 'mkgrokdump'),
|
||||
]
|
||||
|
||||
GYP_UNSUPPORTED_FEATURES = [
|
||||
'gcmole',
|
||||
'setup-isolate-deserialize.cc',
|
||||
'v8-version.h'
|
||||
]
|
||||
|
||||
GN_FILES = [
|
||||
os.path.join(V8_BASE, 'BUILD.gn'),
|
||||
os.path.join(V8_BASE, 'src', 'inspector', 'BUILD.gn'),
|
||||
os.path.join(V8_BASE, 'test', 'inspector', 'BUILD.gn'),
|
||||
os.path.join(V8_BASE, 'test', 'mkgrokdump', 'BUILD.gn'),
|
||||
os.path.join(V8_BASE, 'tools', 'BUILD.gn'),
|
||||
]
|
||||
|
||||
GN_UNSUPPORTED_FEATURES = [
|
||||
'aix',
|
||||
'cygwin',
|
||||
'freebsd',
|
||||
'gcmole',
|
||||
'openbsd',
|
||||
'ppc',
|
||||
'qnx',
|
||||
'solaris',
|
||||
'vtune',
|
||||
'v8-version.h',
|
||||
]
|
||||
|
||||
ALL_GN_PREFIXES = [
|
||||
'..',
|
||||
os.path.join('src', 'inspector'),
|
||||
'src',
|
||||
'testing',
|
||||
os.path.join('test', 'inspector'),
|
||||
os.path.join('test', 'mkgrokdump'),
|
||||
]
|
||||
|
||||
def pathsplit(path):
|
||||
return re.split('[/\\\\]', path)
|
||||
|
||||
def path_no_prefix(path, prefixes):
|
||||
for prefix in prefixes:
|
||||
if path.startswith(prefix + os.sep):
|
||||
return path_no_prefix(path[len(prefix) + 1:], prefixes)
|
||||
return path
|
||||
|
||||
|
||||
def isources(prefixes):
|
||||
cmd = ['git', 'ls-tree', '-r', 'HEAD', '--full-name', '--name-only']
|
||||
for f in subprocess.check_output(cmd, universal_newlines=True).split('\n'):
|
||||
if not (f.endswith('.h') or f.endswith('.cc')):
|
||||
continue
|
||||
yield path_no_prefix(os.path.join(*pathsplit(f)), prefixes)
|
||||
|
||||
|
||||
def iflatten(obj):
|
||||
if isinstance(obj, dict):
|
||||
for value in obj.values():
|
||||
for i in iflatten(value):
|
||||
yield i
|
||||
elif isinstance(obj, list):
|
||||
for value in obj:
|
||||
for i in iflatten(value):
|
||||
yield i
|
||||
elif isinstance(obj, basestring):
|
||||
yield path_no_prefix(os.path.join(*pathsplit(obj)), ALL_GYP_PREFIXES)
|
||||
|
||||
|
||||
def iflatten_gyp_file(gyp_file):
|
||||
"""Overaproximates all values in the gyp file.
|
||||
|
||||
Iterates over all string values recursively. Removes '../' path prefixes.
|
||||
"""
|
||||
with open(gyp_file) as f:
|
||||
return iflatten(eval(f.read()))
|
||||
|
||||
|
||||
def iflatten_gn_file(gn_file):
|
||||
"""Overaproximates all values in the gn file.
|
||||
|
||||
Iterates over all double quoted strings.
|
||||
"""
|
||||
with open(gn_file) as f:
|
||||
for line in f.read().splitlines():
|
||||
match = re.match(r'.*"([^"]*)".*', line)
|
||||
if match:
|
||||
yield path_no_prefix(
|
||||
os.path.join(*pathsplit(match.group(1))), ALL_GN_PREFIXES)
|
||||
|
||||
|
||||
def icheck_values(values, prefixes):
|
||||
for source_file in isources(prefixes):
|
||||
if source_file not in values:
|
||||
yield source_file
|
||||
|
||||
|
||||
def missing_gyp_files():
|
||||
gyp_values = set(itertools.chain(
|
||||
*[iflatten_gyp_file(gyp_file) for gyp_file in GYP_FILES]
|
||||
))
|
||||
gyp_files = sorted(icheck_values(gyp_values, ALL_GYP_PREFIXES))
|
||||
return filter(
|
||||
lambda x: not any(i in x for i in GYP_UNSUPPORTED_FEATURES), gyp_files)
|
||||
|
||||
|
||||
def missing_gn_files():
|
||||
gn_values = set(itertools.chain(
|
||||
*[iflatten_gn_file(gn_file) for gn_file in GN_FILES]
|
||||
))
|
||||
|
||||
gn_files = sorted(icheck_values(gn_values, ALL_GN_PREFIXES))
|
||||
return filter(
|
||||
lambda x: not any(i in x for i in GN_UNSUPPORTED_FEATURES), gn_files)
|
||||
|
||||
|
||||
def main():
|
||||
print "----------- Files not in gyp: ------------"
|
||||
for i in missing_gyp_files():
|
||||
print i
|
||||
|
||||
print "\n----------- Files not in gn: -------------"
|
||||
for i in missing_gn_files():
|
||||
print i
|
||||
return 0
|
||||
|
||||
if '__main__' == __name__:
|
||||
sys.exit(main())
|
Loading…
Reference in New Issue
Block a user