aboutsummaryrefslogtreecommitdiffstats
path: root/components/script/dom/bindings/codegen/GlobalGen.py
diff options
context:
space:
mode:
authorbors-servo <metajack+bors@gmail.com>2015-09-01 13:53:49 -0600
committerbors-servo <metajack+bors@gmail.com>2015-09-01 13:53:49 -0600
commit493da96cae7cc0e3b533fc1f01cc0c5e38a27e02 (patch)
treeedff3b3ead2a60d38ea4370aab18fa7ec71e1825 /components/script/dom/bindings/codegen/GlobalGen.py
parentdcaf66397a06246b9b4fdca3a10af1508a11f1e8 (diff)
parent447fbdcb492dcadd7b71226bde88f836b029de6f (diff)
downloadservo-493da96cae7cc0e3b533fc1f01cc0c5e38a27e02.tar.gz
servo-493da96cae7cc0e3b533fc1f01cc0c5e38a27e02.zip
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 -->
Diffstat (limited to 'components/script/dom/bindings/codegen/GlobalGen.py')
-rw-r--r--components/script/dom/bindings/codegen/GlobalGen.py34
1 files changed, 15 insertions, 19 deletions
diff --git a/components/script/dom/bindings/codegen/GlobalGen.py b/components/script/dom/bindings/codegen/GlobalGen.py
index b3ed1e25b12..537883fae57 100644
--- a/components/script/dom/bindings/codegen/GlobalGen.py
+++ b/components/script/dom/bindings/codegen/GlobalGen.py
@@ -28,7 +28,7 @@ def generate_file(config, name, filename):
def main():
# Parse arguments.
from optparse import OptionParser
- usageString = "usage: %prog [options] webidldir [files]"
+ usageString = "usage: %prog [options] configFile outputdir webidldir [files]"
o = OptionParser(usage=usageString)
o.add_option("--cachedir", dest='cachedir', default=None,
help="Directory in which to cache lex/parse tables.")
@@ -40,8 +40,9 @@ def main():
o.error(usageString)
configFile = args[0]
- baseDir = args[1]
- fileList = args[2:]
+ outputdir = args[1]
+ baseDir = args[2]
+ fileList = args[3:]
# Parse the WebIDL.
parser = WebIDL.Parser(options.cachedir)
@@ -59,22 +60,17 @@ def main():
# Load the configuration.
config = Configuration(configFile, parserResults)
- # Generate the prototype list.
- generate_file(config, 'PrototypeList', 'PrototypeList.rs')
-
- # Generate the common code.
- generate_file(config, 'RegisterBindings', 'RegisterBindings.rs')
-
- # 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')
+ to_generate = [
+ ('PrototypeList', 'PrototypeList.rs'),
+ ('RegisterBindings', 'RegisterBindings.rs'),
+ ('InterfaceTypes', 'InterfaceTypes.rs'),
+ ('InheritTypes', 'InheritTypes.rs'),
+ ('Bindings', 'Bindings/mod.rs'),
+ ('UnionTypes', 'UnionTypes.rs'),
+ ]
+
+ for name, filename in to_generate:
+ generate_file(config, name, os.path.join(outputdir, filename))
if __name__ == '__main__':
main()