1
0
mirror of https://github.com/cmur2/joe-syntax.git synced 2024-11-10 14:56:14 +01:00

Apply patches from upstream

This commit is contained in:
cn 2015-03-03 14:16:53 +01:00
parent 773af6fae2
commit 2298bcf9e1
3 changed files with 181 additions and 99 deletions

View File

@ -1,7 +1,6 @@
# JOE syntax highlight file for JAVA # JOE syntax highlight file for JAVA
# Needs: \uXXXX for unicode in strings # Needs: improve escape parsing
# improve escape parsing
=Idle =Idle
=Comment green =Comment green
@ -122,15 +121,23 @@
:string_escape Escape :string_escape Escape
* string * string
"x" string_hex1 "u" string_uni1
"0-7" string_octal2 "0-7" string_octal2
"\n" string recolor=-2 "\n" string recolor=-2
:string_hex1 Escape :string_uni1 Escape
* string noeat * string noeat
"0-9a-fA-F" string_hex2 "0-9a-fA-F" string_uni2
:string_hex2 Escape :string_uni2 Escape
* string noeat
"0-9a-fA-F" string_uni3
:string_uni3 Escape
* string noeat
"0-9a-fA-F" string_uni4
:string_uni4 Escape
* string noeat * string noeat
"0-9a-fA-F" string "0-9a-fA-F" string
@ -155,15 +162,23 @@
:char_escape Escape :char_escape Escape
* char * char
"x" char_hex1 "u" char_uni1
"0-7" char_octal2 "0-7" char_octal2
"\n" char recolor=-2 "\n" char recolor=-2
:char_hex1 Escape :char_uni1 Escape
* char noeat * char noeat
"0-9a-fA-F" char_hex2 "0-9a-fA-F" char_uni2
:char_hex2 Escape :char_uni2 Escape
* char noeat
"0-9a-fA-F" char_uni3
:char_uni3 Escape
* char noeat
"0-9a-fA-F" char_uni4
:char_uni4 Escape
* char noeat * char noeat
"0-9a-fA-F" char "0-9a-fA-F" char

View File

@ -1,9 +1,5 @@
# JOE syntax highlight file for Python # JOE syntax highlight file for Python
# TODO:
# * octal escape sequences
# * highlight function and class names?
=Idle =Idle
=Comment green =Comment green
=Docstring green =Docstring green
@ -17,13 +13,13 @@
=PrivateMember yellow #fg_310 # brown =PrivateMember yellow #fg_310 # brown
=Decorator red =Decorator red
=Declaration bold blue
:idle Idle :idle Idle
* idle * idle
"#" comment recolor=-1 "#" comment recolor=-1
"0-9" first_digit recolor=-1 "0-9" first_digit recolor=-1
"'" string_sq_1 recolor=-1 "'\"" string_quot_1 recolor=-1 save_c
"\"" string_dq_1 recolor=-1
"a-zA-Z_" ident noeat "a-zA-Z_" ident noeat
"{}" brace recolor=-1 "{}" brace recolor=-1
"@" decorator recolor=-1 "@" decorator recolor=-1
@ -39,111 +35,40 @@
:comment Comment :comment Comment
* comment * comment
# might be TODO label # might be TODO label
"BFHNTX" comment noeat call=commend_todo.comment_todo() "BFHNTX" comment noeat call=comment_todo.comment_todo()
"\n" idle "\n" idle
:string_sq_1 Constant
* string_sq noeat
"'" string_sq_2
:string_sq_2 Constant
* idle noeat
"'" docstr_sq recolor=-3
:string_sq Constant
* string_sq
"\'" idle
"\\" string_sq_esc recolor=-1
:string_sq_esc Escape
* string_sq
"\n" string_sq recolor=-2
:docstr_sq Docstring
* docstr_sq
# might be TODO label
"BFHNTX" docstr_sq noeat call=.comment_todo_docstr()
"\\" docstr_sq_esc recolor=-1
"'" docstr_sq_1
:docstr_sq_1 Docstring
* docstr_sq noeat
"'" docstr_sq_2
:docstr_sq_2 Docstring
* docstr_sq noeat
"'" idle
:docstr_sq_esc DocEscape
* docstr_sq
"\n" docstr_sq recolor=-2
:string_dq_1 Constant
* string_dq noeat
"\"" string_dq_2
:string_dq_2 Constant
* idle noeat
"\"" docstr_dq recolor=-3
:string_dq Constant
* string_dq
"\"" idle
"\\" string_dq_esc recolor=-1
:string_dq_esc Escape
* string_dq
"\n" string_dq recolor=-2
:docstr_dq Docstring
* docstr_dq
# might be TODO label
"BFHNTX" docstr_dq noeat call=.comment_todo_docstr()
"\\" docstr_dq_esc recolor=-1
"\"" docstr_dq_1
:docstr_dq_1 Docstring
* docstr_dq noeat
"\"" docstr_dq_2
:docstr_dq_2 Docstring
* docstr_dq noeat
"\"" idle
:docstr_dq_esc DocEscape
* docstr_dq
"\n" docstr_dq recolor=-2
:first_digit Constant :first_digit Constant
* idle noeat * idle noeat
"xX" hex "xX" hex
"." float "." float
"eE" epart
"0-9" first_number "0-9" first_number
:hex Constant :hex Constant
* idle noeat * idle noeat
"0-9A-Fa-f" hex "0-9A-Fa-f" hex
:first_number Constant :first_number Constant
* idle noeat * idle noeat
"0-9" first_number "0-9" first_number
"." float "." float
:maybe_float Constant :maybe_float Constant
* idle recolor=-2 noeat * idle recolor=-2 noeat
"0-9" float recolor=-2 "0-9" float recolor=-2
:float Constant :float Constant
* idle noeat * idle noeat
"eE" epart "eE" epart
"0-9" float "0-9" float
:epart Constant :epart Constant
* idle noeat * idle noeat
"0-9+\-" enum "0-9+\-" enum
:enum Constant :enum Constant
* idle noeat * idle noeat
"0-9" enum "0-9" enum
:ident Idle :ident Idle
@ -153,11 +78,12 @@
:ident1 Idle :ident1 Idle
* idle noeat strings * idle noeat strings
"and" kw "and" kw
"as" kw
"assert" kw "assert" kw
"break" kw "break" kw
"class" kw "class" declkw
"continue" kw "continue" kw
"def" kw "def" declkw
"del" kw "del" kw
"elif" kw "elif" kw
"else" kw "else" kw
@ -180,11 +106,20 @@
"return" kw "return" kw
"try" kw "try" kw
"while" kw "while" kw
"with" kw
"yield" kw "yield" kw
# quasi-keywords # quasi-keywords
"False" lit "False" lit
"None" lit "None" lit
"True" lit "True" lit
done
"'\"" idle noeat istrings
"u" string_pre
"b" string_pre
"r" string_raw_pre
"br" string_raw_pre
"rb" string_raw_pre
done done
"a-zA-Z0-9_" ident1 "a-zA-Z0-9_" ident1
@ -194,10 +129,142 @@ done
:lit Keyword :lit Keyword
* idle noeat * idle noeat
:declkw Keyword
* idle noeat recolor=-1
"a-zA-Z" declkw
" \t" declname_1
:declname_1 Declaration
* declname
"_" priv_member recolor=-1
:declname Declaration
* idle noeat recolor=-1
"a-zA-Z0-9_" declname
:priv_member PrivateMember :priv_member PrivateMember
* idle noeat * idle noeat
"a-zA-Z0-9_" priv_member "a-zA-Z0-9_" priv_member
# Handle string prefixes up to the string itself.
:string_pre Constant
* idle noeat
"'\"" string_quot_1 save_c
:string_raw_pre Constant
* idle noeat
"'\"" string_quot_raw_1 save_c
# Differentiate between docstrings and regular strings, carrying with it raw state
:string_quot_1 Constant
* idle call=.string() noeat
& string_quot_2
:string_quot_2 Constant
* idle noeat
& idle call=.string(docstring) recolor=-3
:string_quot_raw_1 Constant
* idle call=.string(raw)
& string_quot_raw_2
:string_quot_raw_2 Constant
* idle noeat
& idle call=.string(docstring raw) recolor=-3
.subr string
.ifdef docstring # Long strings
:string Docstring
* string
"BFHNTX" string noeat call=.comment_todo_docstr()
.ifdef raw
.else
"\\" string_esc mark
.endif
& doc_end_1
:doc_end_1 Docstring
* string noeat
& doc_end_2
:doc_end_2 Docstring
* string noeat
& string return
.else # Short strings
:string Constant
* string
"\n" string return
.ifdef raw
.else
"\\" string_esc mark
.endif
& string return
.endif
:string_esc Constant
* string_esc_done
"x" string_hex2
"u" string_hex4
"U" string_hex8
"0-7" string_octal2
"\n" string_esc_done
# Recolor whole escape sequence based on whether this is a docstring.
:string_esc_done Constant
* string_esc_really_done noeat markend recolormark
.ifdef docstring
:string_esc_really_done DocEscape
* string noeat
.else
:string_esc_really_done Escape
* string noeat
.endif
:string_hex1 Escape
* string_esc_done noeat
"0-9a-fA-F" string_esc_done
:string_hex2 Escape
* string_esc_done noeat
"0-9a-fA-F" string_hex1
:string_hex3 Escape
* string_esc_done noeat
"0-9a-fA-F" string_hex2
:string_hex4 Escape
* string_esc_done noeat
"0-9a-fA-F" string_hex3
:string_hex5 Escape
* string_esc_done noeat
"0-9a-fA-F" string_hex4
:string_hex6 Escape
* string_esc_done noeat
"0-9a-fA-F" string_hex5
:string_hex7 Escape
* string_esc_done noeat
"0-9a-fA-F" string_hex6
:string_hex8 Escape
* string_esc_done noeat
"0-9a-fA-F" string_hex7
:string_octal1 Escape
* string_esc_done noeat
"0-7" string_esc_done
:string_octal2 Escape
* string_esc_done noeat
"0-7" string_octal1
.subr comment_todo_docstr .subr comment_todo_docstr
# initial state # initial state
:comment_todo_init Docstring :comment_todo_init Docstring

View File

@ -455,7 +455,7 @@ done
:pstring Idle :pstring Idle
* match noeat * match noeat
" \t" after_term noeat " \t" after_term noeat
"xrqQwW" match "xrsqQwW" match
.ifdef erb .ifdef erb
">" NULL recolor=-2 return ">" NULL recolor=-2 return
.endif .endif