mirror of
https://github.com/servo/servo.git
synced 2025-08-01 11:40:30 +01:00
Auto merge of #7209 - frewsxcv:codegen-build-cleanup, r=metajack
Cleanup/refactor build scripts for DOM codegen Prior to this commit, the script codegen makefile relied on an intermediary pythonpath.py file that handled python dependencies and incorporated a couple hacks to get the codegen building working. This commit removes that intermediary file and attempts to make the script codegen build process cleaner. <!-- Reviewable:start --> [<img src="https://reviewable.io/review_button.png" height=40 alt="Review on Reviewable"/>](https://reviewable.io/reviews/servo/servo/7209) <!-- Reviewable:end -->
This commit is contained in:
commit
493da96cae
3 changed files with 27 additions and 89 deletions
|
@ -28,7 +28,7 @@ def generate_file(config, name, filename):
|
||||||
def main():
|
def main():
|
||||||
# Parse arguments.
|
# Parse arguments.
|
||||||
from optparse import OptionParser
|
from optparse import OptionParser
|
||||||
usageString = "usage: %prog [options] webidldir [files]"
|
usageString = "usage: %prog [options] configFile outputdir webidldir [files]"
|
||||||
o = OptionParser(usage=usageString)
|
o = OptionParser(usage=usageString)
|
||||||
o.add_option("--cachedir", dest='cachedir', default=None,
|
o.add_option("--cachedir", dest='cachedir', default=None,
|
||||||
help="Directory in which to cache lex/parse tables.")
|
help="Directory in which to cache lex/parse tables.")
|
||||||
|
@ -40,8 +40,9 @@ def main():
|
||||||
o.error(usageString)
|
o.error(usageString)
|
||||||
|
|
||||||
configFile = args[0]
|
configFile = args[0]
|
||||||
baseDir = args[1]
|
outputdir = args[1]
|
||||||
fileList = args[2:]
|
baseDir = args[2]
|
||||||
|
fileList = args[3:]
|
||||||
|
|
||||||
# Parse the WebIDL.
|
# Parse the WebIDL.
|
||||||
parser = WebIDL.Parser(options.cachedir)
|
parser = WebIDL.Parser(options.cachedir)
|
||||||
|
@ -59,22 +60,17 @@ def main():
|
||||||
# Load the configuration.
|
# Load the configuration.
|
||||||
config = Configuration(configFile, parserResults)
|
config = Configuration(configFile, parserResults)
|
||||||
|
|
||||||
# Generate the prototype list.
|
to_generate = [
|
||||||
generate_file(config, 'PrototypeList', 'PrototypeList.rs')
|
('PrototypeList', 'PrototypeList.rs'),
|
||||||
|
('RegisterBindings', 'RegisterBindings.rs'),
|
||||||
|
('InterfaceTypes', 'InterfaceTypes.rs'),
|
||||||
|
('InheritTypes', 'InheritTypes.rs'),
|
||||||
|
('Bindings', 'Bindings/mod.rs'),
|
||||||
|
('UnionTypes', 'UnionTypes.rs'),
|
||||||
|
]
|
||||||
|
|
||||||
# Generate the common code.
|
for name, filename in to_generate:
|
||||||
generate_file(config, 'RegisterBindings', 'RegisterBindings.rs')
|
generate_file(config, name, os.path.join(outputdir, filename))
|
||||||
|
|
||||||
# Generate the type list.
|
|
||||||
generate_file(config, 'InterfaceTypes', 'InterfaceTypes.rs')
|
|
||||||
|
|
||||||
# Generate the type list.
|
|
||||||
generate_file(config, 'InheritTypes', 'InheritTypes.rs')
|
|
||||||
|
|
||||||
# Generate the module declarations.
|
|
||||||
generate_file(config, 'Bindings', 'Bindings/mod.rs')
|
|
||||||
|
|
||||||
generate_file(config, 'UnionTypes', 'UnionTypes.rs')
|
|
||||||
|
|
||||||
if __name__ == '__main__':
|
if __name__ == '__main__':
|
||||||
main()
|
main()
|
||||||
|
|
|
@ -1,61 +0,0 @@
|
||||||
# This Source Code Form is subject to the terms of the Mozilla Public
|
|
||||||
# License, v. 2.0. If a copy of the MPL was not distributed with this
|
|
||||||
# file, You can obtain one at http://mozilla.org/MPL/2.0/.
|
|
||||||
|
|
||||||
"""
|
|
||||||
Run a python script, adding extra directories to the python path.
|
|
||||||
"""
|
|
||||||
|
|
||||||
|
|
||||||
def main(args):
|
|
||||||
def usage():
|
|
||||||
print >>sys.stderr, "pythonpath.py -I directory script.py [args...]"
|
|
||||||
sys.exit(150)
|
|
||||||
|
|
||||||
paths = []
|
|
||||||
|
|
||||||
while True:
|
|
||||||
try:
|
|
||||||
arg = args[0]
|
|
||||||
except IndexError:
|
|
||||||
usage()
|
|
||||||
|
|
||||||
if arg == '-I':
|
|
||||||
args.pop(0)
|
|
||||||
try:
|
|
||||||
path = args.pop(0)
|
|
||||||
except IndexError:
|
|
||||||
usage()
|
|
||||||
|
|
||||||
paths.append(os.path.abspath(path))
|
|
||||||
continue
|
|
||||||
|
|
||||||
if arg.startswith('-I'):
|
|
||||||
paths.append(os.path.abspath(args.pop(0)[2:]))
|
|
||||||
continue
|
|
||||||
|
|
||||||
if arg.startswith('-D'):
|
|
||||||
os.chdir(args.pop(0)[2:])
|
|
||||||
continue
|
|
||||||
|
|
||||||
break
|
|
||||||
|
|
||||||
script = args[0]
|
|
||||||
|
|
||||||
sys.path[0:0] = [os.path.abspath(os.path.dirname(script))] + paths
|
|
||||||
sys.argv = args
|
|
||||||
sys.argc = len(args)
|
|
||||||
|
|
||||||
frozenglobals['__name__'] = '__main__'
|
|
||||||
frozenglobals['__file__'] = script
|
|
||||||
|
|
||||||
execfile(script, frozenglobals)
|
|
||||||
|
|
||||||
# Freeze scope here ... why this makes things work I have no idea ...
|
|
||||||
frozenglobals = globals()
|
|
||||||
|
|
||||||
import sys
|
|
||||||
import os
|
|
||||||
|
|
||||||
if __name__ == '__main__':
|
|
||||||
main(sys.argv[1:])
|
|
|
@ -10,6 +10,8 @@ WEBIDLS = $(call rwildcard,$(WEBIDLS_SRC),*.webidl)
|
||||||
BINDINGS = $(patsubst %.webidl,%Binding.rs,$(WEBIDLS))
|
BINDINGS = $(patsubst %.webidl,%Binding.rs,$(WEBIDLS))
|
||||||
AUTOGEN_SRC = $(foreach var,$(BINDINGS),$(subst $(WEBIDLS_SRC),$(OUT_DIR)/Bindings,$(var)))
|
AUTOGEN_SRC = $(foreach var,$(BINDINGS),$(subst $(WEBIDLS_SRC),$(OUT_DIR)/Bindings,$(var)))
|
||||||
|
|
||||||
|
export PYTHONPATH := $(BINDINGS_SRC)/parser:$(BINDINGS_SRC)/ply:$(PYTHONPATH)
|
||||||
|
|
||||||
CACHE_DIR = $(OUT_DIR)/_cache
|
CACHE_DIR = $(OUT_DIR)/_cache
|
||||||
|
|
||||||
bindinggen_dependencies := $(addprefix $(BINDINGS_SRC)/,BindingGen.py Bindings.conf Configuration.py CodegenRust.py parser/WebIDL.py) $(OUT_DIR)/ParserResults.pkl $(OUT_DIR)/Bindings/.done
|
bindinggen_dependencies := $(addprefix $(BINDINGS_SRC)/,BindingGen.py Bindings.conf Configuration.py CodegenRust.py parser/WebIDL.py) $(OUT_DIR)/ParserResults.pkl $(OUT_DIR)/Bindings/.done
|
||||||
|
@ -28,18 +30,19 @@ $(CACHE_DIR)/.done:
|
||||||
touch $@
|
touch $@
|
||||||
|
|
||||||
$(OUT_DIR)/ParserResults.pkl: $(globalgen_dependencies) $(WEBIDLS)
|
$(OUT_DIR)/ParserResults.pkl: $(globalgen_dependencies) $(WEBIDLS)
|
||||||
$(PYTHON) -B $(BINDINGS_SRC)/pythonpath.py \
|
$(PYTHON) \
|
||||||
-I$(BINDINGS_SRC)/parser -I$(BINDINGS_SRC)/ply \
|
$(BINDINGS_SRC)/GlobalGen.py \
|
||||||
-D$(OUT_DIR) \
|
|
||||||
$(BINDINGS_SRC)/GlobalGen.py $(BINDINGS_SRC)/Bindings.conf . \
|
|
||||||
--cachedir=$(CACHE_DIR) \
|
--cachedir=$(CACHE_DIR) \
|
||||||
|
$(BINDINGS_SRC)/Bindings.conf \
|
||||||
|
$(OUT_DIR) \
|
||||||
|
. \
|
||||||
$(WEBIDLS)
|
$(WEBIDLS)
|
||||||
|
|
||||||
$(AUTOGEN_SRC): $(OUT_DIR)/Bindings/%Binding.rs: $(bindinggen_dependencies) \
|
$(AUTOGEN_SRC): $(OUT_DIR)/Bindings/%Binding.rs: $(bindinggen_dependencies) \
|
||||||
$(addprefix $(WEBIDLS_SRC)/,%.webidl)
|
$(addprefix $(WEBIDLS_SRC)/,%.webidl)
|
||||||
$(PYTHON) -B $(BINDINGS_SRC)/pythonpath.py \
|
$(PYTHON) \
|
||||||
-I$(BINDINGS_SRC)/parser -I$(BINDINGS_SRC)/ply \
|
|
||||||
-D$(OUT_DIR) \
|
|
||||||
$(BINDINGS_SRC)/BindingGen.py \
|
$(BINDINGS_SRC)/BindingGen.py \
|
||||||
$(BINDINGS_SRC)/Bindings.conf Bindings/$*Binding $(addprefix $(WEBIDLS_SRC)/,$*.webidl)
|
$(BINDINGS_SRC)/Bindings.conf \
|
||||||
|
$(OUT_DIR)/Bindings/$*Binding \
|
||||||
|
$(addprefix $(WEBIDLS_SRC)/,$*.webidl)
|
||||||
touch $@
|
touch $@
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue