1
0
forked from VimPlug/jedi

Improved grammar loading API.

This commit is contained in:
Dave Halter
2017-03-13 20:33:29 +01:00
parent 595ffc24d4
commit 9b5e6d16da
2 changed files with 19 additions and 12 deletions

View File

@@ -12,11 +12,8 @@ from jedi.parser import tokenize
class ParserGenerator(object): class ParserGenerator(object):
def __init__(self, filename): def __init__(self, bnf_text):
with open(filename) as f: self.generator = tokenize.source_tokens(bnf_text)
code = f.read()
self.filename = filename
self.generator = tokenize.source_tokens(code)
self.gettoken() # Initialize lookahead self.gettoken() # Initialize lookahead
self.dfas, self.startsymbol = self.parse() self.dfas, self.startsymbol = self.parse()
self.first = {} # map from symbol name to set of tokens self.first = {} # map from symbol name to set of tokens
@@ -384,6 +381,6 @@ class DFAState(object):
__hash__ = None # For Py3 compatibility. __hash__ = None # For Py3 compatibility.
def generate_grammar(filename="Grammar.txt"): def generate_grammar(bnf_text):
p = ParserGenerator(filename) p = ParserGenerator(bnf_text)
return p.make_grammar() return p.make_grammar()

View File

@@ -9,9 +9,16 @@ from jedi.parser.tokenize import source_tokens
_loaded_grammars = {} _loaded_grammars = {}
def load_grammar(version='3.6'): def load_grammar(version=None):
# For now we only support two different Python syntax versions: The latest """
# Python 3 and Python 2. This may change. Loads a Python grammar. The default version is always the latest.
If you need support for a specific version, please use e.g.
`version='3.3'`.
"""
if version is None:
version = '3.6'
if version in ('3.2', '3.3'): if version in ('3.2', '3.3'):
version = '3.4' version = '3.4'
elif version == '2.6': elif version == '2.6':
@@ -25,7 +32,10 @@ def load_grammar(version='3.6'):
return _loaded_grammars[path] return _loaded_grammars[path]
except KeyError: except KeyError:
try: try:
return _loaded_grammars.setdefault(path, generate_grammar(path)) with open(path) as f:
bnf_text = f.read()
grammar = generate_grammar(bnf_text)
return _loaded_grammars.setdefault(path, grammar)
except FileNotFoundError: except FileNotFoundError:
# Just load the default if the file does not exist. # Just load the default if the file does not exist.
return load_grammar() return load_grammar()
@@ -40,4 +50,4 @@ def parse(source, grammar=None, error_recovery=False):
parser = ParserWithRecovery parser = ParserWithRecovery
else: else:
parser = Parser parser = Parser
parser(grammar, tokens) return parser(grammar, tokens).get_root_node()