/loggerhead/trunk

To get this branch, use:
bzr branch http://gegoxaren.bato24.eu/bzr/loggerhead/trunk

« back to all changes in this revision

Viewing changes to loggerhead/highlight.py

  • Committer: Michael Hudson
  • Date: 2009-03-02 04:10:16 UTC
  • mfrom: (277.1.18 syntax-highlighting)
  • Revision ID: michael.hudson@canonical.com-20090302041016-chnkvh4vby0hg1l9
syntax highlighting for the annotate view (Peter Bui)
not tested in IE yet, should probably do that...

Show diffs side-by-side

added added

removed removed

Lines of Context:
 
1
#
 
2
# Copyright (C) 2009  Peter Bui <pnutzh4x0r@gmail.com>
 
3
#
 
4
# This program is free software; you can redistribute it and/or modify
 
5
# it under the terms of the GNU General Public License as published by
 
6
# the Free Software Foundation; either version 2 of the License, or
 
7
# (at your option) any later version.
 
8
#
 
9
# This program is distributed in the hope that it will be useful,
 
10
# but WITHOUT ANY WARRANTY; without even the implied warranty of
 
11
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 
12
# GNU General Public License for more details.
 
13
#
 
14
# You should have received a copy of the GNU General Public License
 
15
# along with this program; if not, write to the Free Software
 
16
# Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA
 
17
#
 
18
 
 
19
from pygments import highlight as _highlight_func
 
20
from pygments.lexers import guess_lexer, guess_lexer_for_filename, TextLexer
 
21
from pygments.formatters import HtmlFormatter
 
22
from pygments.util import ClassNotFound
 
23
 
 
24
DEFAULT_PYGMENT_STYLE = 'colorful'
 
25
 
 
26
 
 
27
def highlight(path, text, style=DEFAULT_PYGMENT_STYLE):
 
28
    """
 
29
    Returns a list of highlighted (i.e. HTML formatted) strings.
 
30
    """
 
31
 
 
32
    formatter = HtmlFormatter(style=style, nowrap=True, classprefix='pyg-')
 
33
 
 
34
    encoding = 'utf-8'
 
35
    try:
 
36
        text = text.decode(encoding)
 
37
    except UnicodeDecodeError:
 
38
        encoding = 'iso-8859-15'
 
39
        text = text.decode(encoding)
 
40
 
 
41
    try:
 
42
        lexer = guess_lexer_for_filename(path, text, encoding=encoding)
 
43
    except (ClassNotFound, ValueError):
 
44
        try:
 
45
            lexer = guess_lexer(text, encoding=encoding)
 
46
        except (ClassNotFound, ValueError):
 
47
            lexer = TextLexer(encoding=encoding)
 
48
 
 
49
    hl_lines = _highlight_func(text, lexer, formatter).split('\n')
 
50
 
 
51
    return hl_lines