WebHTTPBody: Keep track of whether the data includes passwords.
[WebKit-https.git] / Source / WebKit / chromium / gyp_webkit
1 #!/usr/bin/env python
2 # Copyright (C) 2009 Google Inc. All rights reserved.
3 #
4 # Redistribution and use in source and binary forms, with or without
5 # modification, are permitted provided that the following conditions are
6 # met:
7 #
8 #   * Redistributions of source code must retain the above copyright notice,
9 #     this list of conditions and the following disclaimer.
10 #   * Redistributions in binary form must reproduce the above copyright
11 #     notice, this list of conditions and the following disclaimer in the
12 #     documentation and/or other materials provided with the distribution.
13 #   * Neither the name of Google Inc. nor the names of its contributors
14 #     may be used to endorse or promote products derived from this software
15 #     without specific prior written permission.
16 #
17 # THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
18 # "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
19 # LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
20 # A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
21 # OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
22 # SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
23 # LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
24 # DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
25 # THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
26 # (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
27 # OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
28 #
29
30 # This file is used by gclient execute gyp with the proper command
31 # line arguments.
32
33 import glob
34 import os
35 import shlex
36 import subprocess
37 import sys
38
39 script_dir = os.path.dirname(__file__)
40 chrome_src = os.path.abspath(script_dir)
41
42 sys.path.insert(0, os.path.join(chrome_src, 'tools', 'gyp', 'pylib'))
43 import gyp
44
45 # Add tools/grit so that pymod_do_main(grit_info ...) can find grit_info.py.
46 sys.path.insert(1, os.path.join(chrome_src, 'tools', 'grit'))
47
48 def additional_include_files(args=[]):
49   """
50   Returns a list of additional (.gypi) files to include, without
51   duplicating ones that are already specified on the command line.
52   """
53   # Determine the include files specified on the command line.
54   # This doesn't cover all the different option formats you can use,
55   # but it's mainly intended to avoid duplicating flags on the automatic
56   # makefile regeneration which only uses this format.
57   specified_includes = set()
58   for arg in args:
59     if arg.startswith('-I') and len(arg) > 2:
60       specified_includes.add(os.path.realpath(arg[2:]))
61
62   result = []
63   def AddInclude(path):
64     if os.path.realpath(path) not in specified_includes:
65       result.append(path)
66
67   # Always include common.gypi
68   AddInclude(os.path.join(script_dir, 'build', 'common.gypi'))
69
70   # Optionally add supplemental .gypi files if present.
71   supplements = glob.glob(os.path.join(script_dir, '*', 'supplement.gypi'))
72   for supplement in supplements:
73     AddInclude(supplement)
74
75   return result
76
77 if __name__ == '__main__':
78
79   args = sys.argv[1:]
80
81   # When building the WebKit Chromium port for Android, we have to cross-compile
82   # the source to ARM, check for the right Android NDK and set the appropriate
83   # GYP flags. Chromium's envsetup.sh script will handle these steps, but as it
84   # exports variables and commands we have to re-call ourselves afterwards.
85   if 'WEBKIT_ANDROID_BUILD' in os.environ:
86     if not '--no-envsetup-recursion' in args:
87       envsetup_location = os.path.join(chrome_src, 'build', 'android', 'envsetup.sh')
88       exit(subprocess.call(['bash', '-c', 'source %s && python gyp_webkit --no-envsetup-recursion %s' % (envsetup_location, ' '.join(args))]))
89     else:
90       os.environ['CC.target'] = os.environ['CROSS_CC']
91       args.remove('--no-envsetup-recursion')
92
93   # Add includes.
94   args.extend(['-I' + i for i in additional_include_files(args)])
95
96   # There shouldn't be a circular dependency relationship between .gyp files,
97   # but in Chromium's .gyp files, on non-Mac platforms, circular relationships
98   # currently exist.  The check for circular dependencies is currently
99   # bypassed on other platforms, but is left enabled on the Mac, where a
100   # violation of the rule causes Xcode to misbehave badly.
101   # http://crbug.com/35878.
102   if sys.platform not in ('darwin',):
103     args.append('--no-circular-check')
104
105   generators = os.environ.get('GYP_GENERATORS', '')
106   if 'ninja' in generators:
107     args.extend([ '--toplevel-dir=../../..' ])
108   elif (sys.platform.startswith('linux') or
109       'WEBKIT_ANDROID_BUILD' in os.environ or
110       (sys.platform == 'darwin' and 'make' in generators)):
111     args.extend(['-fmake',
112                  '--suffix=.chromium',
113                  '--toplevel-dir=../../..',
114                  # auto_regeneration doesn't work with toplevel-dir
115                  '-Gauto_regeneration=0'])
116
117   # Other command args:
118   args.extend([
119                # gyp variable defines.
120                '-Dinside_chromium_build=0',
121                '-Dv8_use_snapshot=false',
122                '-Dmsvs_use_common_release=0',
123
124                # WebKit doesn't use the chromium style checker.
125                '-Dmake_clang_dir=Source/WebKit/chromium/third_party/llvm-build/Release+Asserts',
126                '-Dclang_use_chrome_plugins=0',
127
128                # gyp hack: otherwise gyp assumes its in chromium's src/ dir.
129                '--depth=./',
130
131                # gyp file to execute.
132                'All.gyp'])
133
134   print 'Updating webkit projects from gyp files...'
135   sys.stdout.flush()
136
137   # Off we go...
138   sys.exit(gyp.main(args))