ba9fc3d7bc
Reason for revert:
I think that this CL breaks chromium compilation on windows with clang (). All other CLs in the list looks trivial and don't change test/unittest/BUILD.gn.
[42456/47924] CXX obj/v8/test/unittests/unittests/value-serializer-unittest.obj
[42457/47924] LINK unittests.exe unittests.exe.pdb
FAILED: unittests.exe unittests.exe.pdb
E:/b/depot_tools/python276_bin/python.exe ../../build/toolchain/win/tool_wrapper.py link-wrapper environment.x64 False link.exe /nologo /OUT:./unittests.exe /PDB:./unittests.exe.pdb @./unittests.exe.rsp
bitmap-unittest.obj : error LNK2019: unresolved external symbol "public: void __cdecl v8::internal::List<class v8::internal::AllocationObserver *,class v8::internal::FreeStoreAllocationPolicy>::Add(class v8::internal::AllocationObserver * const &,class v8::internal::FreeStoreAllocationPolicy)" (?Add@?$List@PEAVAllocationObserver@internal@v8@@VFreeStoreAllocationPolicy@23@@internal@v8@@QEAAXAEBQEAVAllocationObserver@23@VFreeStoreAllocationPolicy@23@@Z) referenced in function "public: virtual void __cdecl v8::internal::Space::AddAllocationObserver(class v8::internal::AllocationObserver *)" (?AddAllocationObserver@Space@internal@v8@@UEAAXPEAVAllocationObserver@23@@Z)
slot-set-unittest.obj : error LNK2001: unresolved external symbol "public: void __cdecl v8::internal::List<class v8::internal::AllocationObserver *,class v8::internal::FreeStoreAllocationPolicy>::Add(class v8::internal::AllocationObserver * const &,class v8::internal::FreeStoreAllocationPolicy)" (?Add@?$List@PEAVAllocationObserver@internal@v8@@VFreeStoreAllocationPolicy@23@@internal@v8@@QEAAXAEBQEAVAllocationObserver@23@VFreeStoreAllocationPolicy@23@@Z)
bitmap-unittest.obj : error LNK2019: unresolved external symbol "public: bool __cdecl v8::internal::List<class v8::internal::AllocationObserver *,class v8::internal::FreeStoreAllocationPolicy>::RemoveElement(class v8::internal::AllocationObserver * const &)" (?RemoveElement@?$List@PEAVAllocationObserver@internal@v8@@VFreeStoreAllocationPolicy@23@@internal@v8@@QEAA_NAEBQEAVAllocationObserver@23@@Z) referenced in function "public: virtual void __cdecl v8::internal::Space::RemoveAllocationObserver(class v8::internal::AllocationObserver *)" (?RemoveAllocationObserver@Space@internal@v8@@UEAAXPEAVAllocationObserver@23@@Z)
slot-set-unittest.obj : error LNK2001: unresolved external symbol "public: bool __cdecl v8::internal::List<class v8::internal::AllocationObserver *,class v8::internal::FreeStoreAllocationPolicy>::RemoveElement(class v8::internal::AllocationObserver * const &)" (?RemoveElement@?$List@PEAVAllocationObserver@internal@v8@@VFreeStoreAllocationPolicy@23@@internal@v8@@QEAA_NAEBQEAVAllocationObserver@23@@Z)
./unittests.exe : fatal error LNK1120: 2 unresolved externals
Original issue's description:
> [snapshot] Move builtins generation into mksnapshot
>
> and out of the main library. This saves about 5% of binary size
> (800KB on x64, 373KB on android_arm).
>
> Only the GN build is supported; the GYP build is maintained working
> but does not support the feature.
>
> BUG=v8:6055
> CQ_INCLUDE_TRYBOTS=master.tryserver.v8:v8_linux_nosnap_rel;
>
> Review-Url: https://codereview.chromium.org/2760233005
> Cr-Commit-Position: refs/heads/master@{#44412}
> Committed: 4782bc0df8
TBR=jgruber@chromium.org,rmcilroy@chromium.org,machenbach@chromium.org,jkummerow@chromium.org
# Skipping CQ checks because original CL landed less than 1 days ago.
NOPRESUBMIT=true
NOTREECHECKS=true
NOTRY=true
BUG=v8:6055
Review-Url: https://codereview.chromium.org/2803903002
Cr-Commit-Position: refs/heads/master@{#44422}
182 lines
4.9 KiB
Python
Executable File
182 lines
4.9 KiB
Python
Executable File
#!/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, 'src', 'd8.gyp'),
|
|
os.path.join(V8_BASE, 'src', 'v8.gyp'),
|
|
os.path.join(V8_BASE, 'src', 'inspector', 'inspector.gypi'),
|
|
os.path.join(V8_BASE, 'src', 'third_party', 'vtune', 'v8vtune.gyp'),
|
|
os.path.join(V8_BASE, 'samples', 'samples.gyp'),
|
|
os.path.join(V8_BASE, 'test', 'cctest', 'cctest.gyp'),
|
|
os.path.join(V8_BASE, 'test', 'fuzzer', 'fuzzer.gyp'),
|
|
os.path.join(V8_BASE, 'test', 'unittests', 'unittests.gyp'),
|
|
os.path.join(V8_BASE, 'test', 'inspector', 'inspector.gyp'),
|
|
os.path.join(V8_BASE, 'testing', 'gmock.gyp'),
|
|
os.path.join(V8_BASE, 'testing', 'gtest.gyp'),
|
|
os.path.join(V8_BASE, 'tools', 'parser-shell.gyp'),
|
|
]
|
|
|
|
ALL_GYP_PREFIXES = [
|
|
'..',
|
|
'common',
|
|
os.path.join('src', 'third_party', 'vtune'),
|
|
'src',
|
|
'samples',
|
|
'testing',
|
|
'tools',
|
|
os.path.join('test', 'cctest'),
|
|
os.path.join('test', 'common'),
|
|
os.path.join('test', 'fuzzer'),
|
|
os.path.join('test', 'unittests'),
|
|
os.path.join('test', 'inspector'),
|
|
]
|
|
|
|
GYP_UNSUPPORTED_FEATURES = [
|
|
'gcmole',
|
|
]
|
|
|
|
GN_FILES = [
|
|
os.path.join(V8_BASE, 'BUILD.gn'),
|
|
os.path.join(V8_BASE, 'build', 'secondary', 'testing', 'gmock', 'BUILD.gn'),
|
|
os.path.join(V8_BASE, 'build', 'secondary', 'testing', 'gtest', 'BUILD.gn'),
|
|
os.path.join(V8_BASE, 'src', 'inspector', 'BUILD.gn'),
|
|
os.path.join(V8_BASE, 'test', 'cctest', 'BUILD.gn'),
|
|
os.path.join(V8_BASE, 'test', 'unittests', 'BUILD.gn'),
|
|
os.path.join(V8_BASE, 'test', 'inspector', 'BUILD.gn'),
|
|
os.path.join(V8_BASE, 'tools', 'BUILD.gn'),
|
|
]
|
|
|
|
GN_UNSUPPORTED_FEATURES = [
|
|
'aix',
|
|
'cygwin',
|
|
'freebsd',
|
|
'gcmole',
|
|
'openbsd',
|
|
'ppc',
|
|
'qnx',
|
|
'solaris',
|
|
'vtune',
|
|
'x87',
|
|
]
|
|
|
|
ALL_GN_PREFIXES = [
|
|
'..',
|
|
os.path.join('src', 'inspector'),
|
|
'src',
|
|
'testing',
|
|
os.path.join('test', 'cctest'),
|
|
os.path.join('test', 'unittests'),
|
|
os.path.join('test', 'inspector'),
|
|
]
|
|
|
|
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())
|