Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(356)

Side by Side Diff: mojo/public/tools/bindings/pylib/mojom/parse/lexer.py

Issue 443293003: Mojo: Add PRESUBMIT.py to mojo/. (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: Created 6 years, 4 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch | Annotate | Revision Log
OLDNEW
1 # Copyright 2014 The Chromium Authors. All rights reserved. 1 # Copyright 2014 The Chromium Authors. All rights reserved.
2 # Use of this source code is governed by a BSD-style license that can be 2 # Use of this source code is governed by a BSD-style license that can be
3 # found in the LICENSE file. 3 # found in the LICENSE file.
4 4
5 import imp 5 import imp
6 import os.path 6 import os.path
7 import sys 7 import sys
8 8
9 # Disable lint check for finding modules:
10 # pylint: disable=F0401
11
12 def _GetDirAbove(dirname): 9 def _GetDirAbove(dirname):
13 """Returns the directory "above" this file containing |dirname| (which must 10 """Returns the directory "above" this file containing |dirname| (which must
14 also be "above" this file).""" 11 also be "above" this file)."""
15 path = os.path.abspath(__file__) 12 path = os.path.abspath(__file__)
16 while True: 13 while True:
17 path, tail = os.path.split(path) 14 path, tail = os.path.split(path)
18 assert tail 15 assert tail
19 if tail == dirname: 16 if tail == dirname:
20 return path 17 return path
21 18
22 try: 19 try:
23 imp.find_module("ply") 20 imp.find_module("ply")
24 except ImportError: 21 except ImportError:
25 sys.path.append(os.path.join(_GetDirAbove("mojo"), "third_party")) 22 sys.path.append(os.path.join(_GetDirAbove("mojo"), "third_party"))
26 from ply.lex import TOKEN 23 from ply.lex import TOKEN
27 24
28 from ..error import Error 25 from ..error import Error
29 26
30 27
31 # Disable lint check for exceptions deriving from Exception:
32 # pylint: disable=W0710
33 class LexError(Error): 28 class LexError(Error):
34 """Class for errors from the lexer.""" 29 """Class for errors from the lexer."""
35 30
36 def __init__(self, filename, message, lineno): 31 def __init__(self, filename, message, lineno):
37 Error.__init__(self, filename, message, lineno=lineno) 32 Error.__init__(self, filename, message, lineno=lineno)
38 33
39 34
40 # We have methods which look like they could be functions: 35 # We have methods which look like they could be functions:
41 # pylint: disable=R0201 36 # pylint: disable=R0201
42 class Lexer(object): 37 class Lexer(object):
(...skipping 201 matching lines...) Expand 10 before | Expand all | Expand 10 after
244 return t 239 return t
245 240
246 # Ignore C and C++ style comments 241 # Ignore C and C++ style comments
247 def t_COMMENT(self, t): 242 def t_COMMENT(self, t):
248 r'(/\*(.|\n)*?\*/)|(//.*(\n[ \t]*//.*)*)' 243 r'(/\*(.|\n)*?\*/)|(//.*(\n[ \t]*//.*)*)'
249 t.lexer.lineno += t.value.count("\n") 244 t.lexer.lineno += t.value.count("\n")
250 245
251 def t_error(self, t): 246 def t_error(self, t):
252 msg = "Illegal character %s" % repr(t.value[0]) 247 msg = "Illegal character %s" % repr(t.value[0])
253 self._error(msg, t) 248 self._error(msg, t)
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698