vim-detailed icon indicating copy to clipboard operation
vim-detailed copied to clipboard

Detail Python

Open rking opened this issue 12 years ago • 2 comments

ane from #go-nuts

rking avatar Dec 04 '12 16:12 rking

Well that was quick!

ane avatar Dec 04 '12 16:12 ane

@neersighted - Do you want to tackle this?

The task has already been done for Go and Shell. You can just mimic how they do it, basically for this stuff:

syn keyword pythonStatement False, None, True
syn keyword pythonStatement as assert break continue del exec global
syn keyword pythonStatement lambda nonlocal pass print return with yield
syn keyword pythonStatement class def nextgroup=pythonFunction skipwhite
syn keyword pythonConditional   elif else if
syn keyword pythonRepeat    for while
syn keyword pythonOperator  and in is not or
syn keyword pythonException except finally raise try
syn keyword pythonInclude   from import

" Decorators (new in Python 2.4)
syn match   pythonDecorator "@" display nextgroup=pythonFunction skipwhite
" The zero-length non-grouping match before the function name is
" extremely important in pythonFunction.  Without it, everything is
" interpreted as a function inside the contained environment of
" doctests.
" A dot must be allowed because of @MyClass.myfunc decorators.
syn match   pythonFunction
      \ "\%(\%(def\s\|class\s\|@\)\s*\)\@<=\h\%(\w\|\.\)*" contained

syn match   pythonComment   "#.*$" contains=pythonTodo,@Spell
syn keyword pythonTodo      FIXME NOTE NOTES TODO XXX contained

" Triple-quoted strings can contain doctests.
syn region  pythonString
      \ start=+[uU]\=\z(['"]\)+ end="\z1" skip="\\\\\|\\\z1"
      \ contains=pythonEscape,@Spell
syn region  pythonString
      \ start=+[uU]\=\z('''\|"""\)+ end="\z1" keepend
      \ contains=pythonEscape,pythonSpaceError,pythonDoctest,@Spell
syn region  pythonRawString
      \ start=+[uU]\=[rR]\z(['"]\)+ end="\z1" skip="\\\\\|\\\z1"
      \ contains=@Spell
syn region  pythonRawString
      \ start=+[uU]\=[rR]\z('''\|"""\)+ end="\z1" keepend
      \ contains=pythonSpaceError,pythonDoctest,@Spell

syn match   pythonEscape    +\\[abfnrtv'"\\]+ contained
syn match   pythonEscape    "\\\o\{1,3}" contained
syn match   pythonEscape    "\\x\x\{2}" contained
syn match   pythonEscape    "\%(\\u\x\{4}\|\\U\x\{8}\)" contained
" Python allows case-insensitive Unicode IDs: http://www.unicode.org/charts/
syn match   pythonEscape    "\\N{\a\+\%(\s\a\+\)*}" contained
syn match   pythonEscape    "\\$"

if exists("python_highlight_all")
  if exists("python_no_builtin_highlight")
    unlet python_no_builtin_highlight
  endif
  if exists("python_no_doctest_code_highlight")
    unlet python_no_doctest_code_highlight
  endif
  if exists("python_no_doctest_highlight")
    unlet python_no_doctest_highlight
  endif
  if exists("python_no_exception_highlight")
    unlet python_no_exception_highlight
  endif
  if exists("python_no_number_highlight")
    unlet python_no_number_highlight
  endif
  let python_space_error_highlight = 1
endif

" It is very important to understand all details before changing the
" regular expressions below or their order.
" The word boundaries are *not* the floating-point number boundaries
" because of a possible leading or trailing decimal point.
" The expressions below ensure that all valid number literals are
" highlighted, and invalid number literals are not.  For example,
"
" - a decimal point in '4.' at the end of a line is highlighted,
" - a second dot in 1.0.0 is not highlighted,
" - 08 is not highlighted,
" - 08e0 or 08j are highlighted,
"
" and so on, as specified in the 'Python Language Reference'.
" http://docs.python.org/reference/lexical_analysis.html#numeric-literals
if !exists("python_no_number_highlight")
  " numbers (including longs and complex)
  syn match   pythonNumber  "\<0[oO]\=\o\+[Ll]\=\>"
  syn match   pythonNumber  "\<0[xX]\x\+[Ll]\=\>"
  syn match   pythonNumber  "\<0[bB][01]\+[Ll]\=\>"
  syn match   pythonNumber  "\<\%([1-9]\d*\|0\)[Ll]\=\>"
  syn match   pythonNumber  "\<\d\+[jJ]\>"
  syn match   pythonNumber  "\<\d\+[eE][+-]\=\d\+[jJ]\=\>"
  syn match   pythonNumber
        \ "\<\d\+\.\%([eE][+-]\=\d\+\)\=[jJ]\=\%(\W\|$\)\@="
  syn match   pythonNumber
        \ "\%(^\|\W\)\@<=\d*\.\d\+\%([eE][+-]\=\d\+\)\=[jJ]\=\>"
endif

" Group the built-ins in the order in the 'Python Library Reference' for
" easier comparison.
" http://docs.python.org/library/constants.html
" http://docs.python.org/library/functions.html
" http://docs.python.org/library/functions.html#non-essential-built-in-functions
" Python built-in functions are in alphabetical order.
if !exists("python_no_builtin_highlight")
  " built-in constants
  " 'False', 'True', and 'None' are also reserved words in Python 3.0
  syn keyword pythonBuiltin False True None
  syn keyword pythonBuiltin NotImplemented Ellipsis __debug__
  " built-in functions
  syn keyword pythonBuiltin abs all any bin bool chr classmethod
  syn keyword pythonBuiltin compile complex delattr dict dir divmod
  syn keyword pythonBuiltin enumerate eval filter float format
  syn keyword pythonBuiltin frozenset getattr globals hasattr hash
  syn keyword pythonBuiltin help hex id input int isinstance
  syn keyword pythonBuiltin issubclass iter len list locals map max
  syn keyword pythonBuiltin min next object oct open ord pow print
  syn keyword pythonBuiltin property range repr reversed round set
  syn keyword pythonBuiltin setattr slice sorted staticmethod str
  syn keyword pythonBuiltin sum super tuple type vars zip __import__
  " Python 2.6 only
  syn keyword pythonBuiltin basestring callable cmp execfile file
  syn keyword pythonBuiltin long raw_input reduce reload unichr
  syn keyword pythonBuiltin unicode xrange
  " Python 3.0 only
  syn keyword pythonBuiltin ascii bytearray bytes exec memoryview
  " non-essential built-in functions; Python 2.6 only
  syn keyword pythonBuiltin apply buffer coerce intern
endif

" From the 'Python Library Reference' class hierarchy at the bottom.
" http://docs.python.org/library/exceptions.html
if !exists("python_no_exception_highlight")
  " builtin base exceptions (only used as base classes for other exceptions)
  syn keyword pythonExceptions  BaseException Exception
  syn keyword pythonExceptions  ArithmeticError EnvironmentError
  syn keyword pythonExceptions  LookupError
  " builtin base exception removed in Python 3.0
  syn keyword pythonExceptions  StandardError
  " builtin exceptions (actually raised)
  syn keyword pythonExceptions  AssertionError AttributeError BufferError
  syn keyword pythonExceptions  EOFError FloatingPointError GeneratorExit
  syn keyword pythonExceptions  IOError ImportError IndentationError
  syn keyword pythonExceptions  IndexError KeyError KeyboardInterrupt
  syn keyword pythonExceptions  MemoryError NameError NotImplementedError
  syn keyword pythonExceptions  OSError OverflowError ReferenceError
  syn keyword pythonExceptions  RuntimeError StopIteration SyntaxError
  syn keyword pythonExceptions  SystemError SystemExit TabError TypeError
  syn keyword pythonExceptions  UnboundLocalError UnicodeError
  syn keyword pythonExceptions  UnicodeDecodeError UnicodeEncodeError
  syn keyword pythonExceptions  UnicodeTranslateError ValueError VMSError
  syn keyword pythonExceptions  WindowsError ZeroDivisionError
  " builtin warnings
  syn keyword pythonExceptions  BytesWarning DeprecationWarning FutureWarning
  syn keyword pythonExceptions  ImportWarning PendingDeprecationWarning
  syn keyword pythonExceptions  RuntimeWarning SyntaxWarning UnicodeWarning
  syn keyword pythonExceptions  UserWarning Warning
endif

if exists("python_space_error_highlight")
  " trailing whitespace
  syn match   pythonSpaceError  display excludenl "\s\+$"
  " mixed tabs and spaces
  syn match   pythonSpaceError  display " \+\t"
  syn match   pythonSpaceError  display "\t\+ "
endif

" Do not spell doctests inside strings.
" Notice that the end of a string, either ''', or """, will end the contained
" doctest too.  Thus, we do *not* need to have it as an end pattern.
if !exists("python_no_doctest_highlight")
  if !exists("python_no_doctest_code_higlight")
    syn region pythonDoctest
          \ start="^\s*>>>\s" end="^\s*$"
          \ contained contains=ALLBUT,pythonDoctest,@Spell
    syn region pythonDoctestValue
          \ start=+^\s*\%(>>>\s\|\.\.\.\s\|"""\|'''\)\@!\S\++ end="$"
          \ contained
  else
    syn region pythonDoctest
          \ start="^\s*>>>" end="^\s*$"
          \ contained contains=@NoSpell
  endif
endif

rking avatar Jan 17 '13 04:01 rking