diff options
author | Georg Brandl <georg@python.org> | 2010-02-18 16:39:01 +0100 |
---|---|---|
committer | Georg Brandl <georg@python.org> | 2010-02-18 16:39:01 +0100 |
commit | 1fd98861b9d75594516ac0dbbfed6b28b5271c22 (patch) | |
tree | 78f148a89ee02cead2ccba52e23b0348819208cb /pygments/lexer.py | |
parent | e679aa7202885b20703921c0565db8b660e38986 (diff) | |
download | pygments-1fd98861b9d75594516ac0dbbfed6b28b5271c22.tar.gz |
- Added the ``ensurenl`` lexer option, which can be used to suppress the
automatic addition of a newline to the lexer input.
- Fixed a bug in `do_insertions()` used for multi-lexer languages.
- Added tests for standard lexer whitespace options.
Diffstat (limited to 'pygments/lexer.py')
-rw-r--r-- | pygments/lexer.py | 15 |
1 files changed, 13 insertions, 2 deletions
diff --git a/pygments/lexer.py b/pygments/lexer.py index 7e86841a..fbcc39a6 100644 --- a/pygments/lexer.py +++ b/pygments/lexer.py @@ -46,6 +46,10 @@ class Lexer(object): ``stripall`` Strip all leading and trailing whitespace from the input (default: False). + ``ensurenl`` + Make sure that the input ends with a newline (default: True). This + is required for some lexers that consume input linewise. + *New in Pygments 1.3.* ``tabsize`` If given and greater than 0, expand tabs in the input (default: 0). ``encoding`` @@ -77,6 +81,7 @@ class Lexer(object): self.options = options self.stripnl = get_bool_opt(options, 'stripnl', True) self.stripall = get_bool_opt(options, 'stripall', False) + self.ensurenl = get_bool_opt(options, 'ensurenl', True) self.tabsize = get_int_opt(options, 'tabsize', 0) self.encoding = options.get('encoding', 'latin1') # self.encoding = options.get('inencoding', None) or self.encoding @@ -150,7 +155,7 @@ class Lexer(object): text = text.strip('\n') if self.tabsize > 0: text = text.expandtabs(self.tabsize) - if not text.endswith('\n'): + if self.ensurenl and not text.endswith('\n'): text += '\n' def streamer(): @@ -641,9 +646,15 @@ def do_insertions(insertions, tokens): realpos += len(v) - oldi # leftover tokens - if insleft: + while insleft: # no normal tokens, set realpos to zero realpos = realpos or 0 for p, t, v in itokens: yield realpos, t, v realpos += len(v) + try: + index, itokens = insertions.next() + except StopIteration: + insleft = False + break # not strictly necessary + |