minor refactor of language and lexer creation

This commit is contained in:
Alan Hamlett 2017-02-26 15:21:16 -08:00
parent de83239073
commit d85448b563
1 changed files with 21 additions and 20 deletions

View File

@ -44,9 +44,7 @@ def get_file_stats(file_name, entity_type='file', lineno=None, cursorpos=None,
'cursorpos': cursorpos,
}
else:
language = standardize_language(language, plugin)
lexer = get_lexer(language)
language, lexer = standardize_language(language, plugin)
if not language:
language, lexer = guess_language(file_name)
@ -63,19 +61,6 @@ def get_file_stats(file_name, entity_type='file', lineno=None, cursorpos=None,
return stats
def get_lexer(language):
"""Return a Pygments Lexer object for the given language string."""
if not language:
return None
lexer_cls = find_lexer_class(language)
if lexer_cls:
return lexer_cls()
return None
def guess_language(file_name):
"""Guess lexer and language for a file.
@ -204,21 +189,37 @@ def number_lines_in_file(file_name):
def standardize_language(language, plugin):
"""Maps a string to the equivalent Pygments language."""
"""Maps a string to the equivalent Pygments language.
Returns a tuple of (language_name, lexer_object).
"""
if not language:
return None
return None, None
# standardize language for this plugin
if plugin:
plugin = plugin.split(' ')[-1].split('/')[0].split('-')[0]
standardized = get_language_from_json(language, plugin)
if standardized is not None:
return standardized
return standardized, get_lexer(standardized)
# standardize language against default languages
standardized = get_language_from_json(language, 'default')
return standardized
return standardized, get_lexer(standardized)
def get_lexer(language):
"""Return a Pygments Lexer object for the given language string."""
if not language:
return None
lexer_cls = find_lexer_class(language)
if lexer_cls:
return lexer_cls()
return None
def get_language_from_json(language, key):