| Index: bindings/scripts/blink_idl_lexer.py
|
| diff --git a/bindings/scripts/blink_idl_lexer.py b/bindings/scripts/blink_idl_lexer.py
|
| new file mode 100644
|
| index 0000000000000000000000000000000000000000..bbde34268b44c0b97fd797d19523eef48f586005
|
| --- /dev/null
|
| +++ b/bindings/scripts/blink_idl_lexer.py
|
| @@ -0,0 +1,127 @@
|
| +# Copyright (C) 2013 Google Inc. 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.
|
| +
|
| +"""Lexer for Blink IDL.
|
| +
|
| +The lexer uses the PLY (Python Lex-Yacc) library to build a tokenizer which
|
| +understands the Blink dialect of Web IDL and produces a token stream suitable
|
| +for the Blink IDL parser.
|
| +
|
| +Blink IDL is identical to Web IDL at the token level, but the base lexer
|
| +does not discard comments. We need to override (and not include comments in
|
| +the token stream), as otherwise comments must be explicitly included in the
|
| +phrase grammar of the parser.
|
| +
|
| +FIXME: Change base lexer to discard comments, and simply used the base
|
| +lexer, eliminating this separate lexer.
|
| +
|
| +Web IDL:
|
| + http://www.w3.org/TR/WebIDL/
|
| +Web IDL Grammar:
|
| + http://www.w3.org/TR/WebIDL/#idl-grammar
|
| +PLY:
|
| + http://www.dabeaz.com/ply/
|
| +
|
| +Design doc:
|
| +http://www.chromium.org/developers/design-documents/idl-compiler#TOC-Front-end
|
| +"""
|
| +
|
| +# Disable attribute validation, as lint can't import parent class to check
|
| +# pylint: disable=E1101
|
| +
|
| +import os.path
|
| +import sys
|
| +
|
| +# PLY is in Chromium src/third_party/ply
|
| +module_path, module_name = os.path.split(__file__)
|
| +third_party = os.path.join(module_path, os.pardir, os.pardir, os.pardir, os.pardir)
|
| +# Insert at front to override system libraries, and after path[0] == script dir
|
| +sys.path.insert(1, third_party)
|
| +from ply import lex
|
| +
|
| +# Base lexer is in Chromium src/tools/idl_parser
|
| +tools_dir = os.path.join(third_party, os.pardir, 'tools')
|
| +sys.path.append(tools_dir)
|
| +from idl_parser.idl_lexer import IDLLexer
|
| +
|
| +REMOVE_TOKENS = ['COMMENT']
|
| +
|
| +
|
| +class BlinkIDLLexer(IDLLexer):
|
| + # ignore comments
|
| + def t_COMMENT(self, t):
|
| + r'(/\*(.|\n)*?\*/)|(//.*(\n[ \t]*//.*)*)'
|
| + self.AddLines(t.value.count('\n'))
|
| +
|
| + # Analogs to _AddToken/_AddTokens in base lexer
|
| + # Needed to remove COMMENT token, since comments ignored
|
| + def _RemoveToken(self, token):
|
| + if token in self.tokens:
|
| + self.tokens.remove(token)
|
| +
|
| + def _RemoveTokens(self, tokens):
|
| + for token in tokens:
|
| + self._RemoveToken(token)
|
| +
|
| + def __init__(self, debug=False, optimize=True, outputdir=None):
|
| + if debug:
|
| + # Turn off optimization and caching to help debugging
|
| + optimize = False
|
| + outputdir = None
|
| + if outputdir:
|
| + # Need outputdir in path because lex imports the cached lex table
|
| + # as a Python module
|
| + sys.path.append(outputdir)
|
| +
|
| + IDLLexer.__init__(self)
|
| + # Overrides to parent class
|
| + self._RemoveTokens(REMOVE_TOKENS)
|
| + # Optimized mode substantially decreases startup time (by disabling
|
| + # error checking), and also allows use of Python's optimized mode.
|
| + # See: Optimized Mode
|
| + # http://www.dabeaz.com/ply/ply.html#ply_nn15
|
| + self._lexobj = lex.lex(object=self,
|
| + debug=debug,
|
| + optimize=optimize,
|
| + outputdir=outputdir)
|
| +
|
| +
|
| +################################################################################
|
| +
|
| +def main(argv):
|
| + # If file itself executed, build and cache lex table
|
| + try:
|
| + outputdir = argv[1]
|
| + except IndexError as err:
|
| + print 'Usage: %s OUTPUT_DIR' % argv[0]
|
| + return 1
|
| + lexer = BlinkIDLLexer(outputdir=outputdir)
|
| +
|
| +
|
| +if __name__ == '__main__':
|
| + sys.exit(main(sys.argv))
|
|
|