added some XML junk

--HG--
branch : pmacs2
This commit is contained in:
moculus 2009-02-17 04:40:11 +00:00
parent 9998febf3d
commit 050f68bc69
1 changed files with 60 additions and 3 deletions

View File

@ -1,5 +1,40 @@
import color, method, mode import color, method, mode
from lex import Grammar, PatternRule, RegionRule from lex import Grammar, Rule, PatternRule, RegionRule
class PatternGroupRule(PatternRule):
def __init__(self, name, *args):
assert args and len(args) % 2 == 0
i = 0
pairs = []
while i < len(args):
tokname, pattern = args[i], args[i+1]
pairs.append((tokname, re.compile(pattern, self.reflags)))
i += 2
Rule.__init__(self, name)
self.pairs = tuple(pairs)
def match(self, lexer, parent):
(x, y) = (lexer.x, lexer.y)
matches = []
for (tokname, tokre) in self.pairs:
if y >= len(lexer.lines):
return []
line = self.get_line(lexer, y)
m = tokre.match(line, x)
if m:
x += len(m.group(0))
if x >= len(line):
x = 0
y += 1
matches.append((tokname, m))
else:
return []
assert len(matches) == len(self.pairs)
return matches
def lex(self, lexer, parent, matches):
if matches:
for (tokname, m) in matches:
yield self.make_token(lexer, m.group(0), tokname, parent, m.groupdict())
raise StopIteration
class StringGrammar1(Grammar): class StringGrammar1(Grammar):
rules = [ rules = [
@ -12,6 +47,8 @@ class StringGrammar2(Grammar):
PatternRule(r'escaped', r'&[a-z]+;'), PatternRule(r'escaped', r'&[a-z]+;'),
] ]
class CDataGrammar(Grammar):
rules = [PatternRule(r'data', r'(?:[^\]]|\](?!\])|\]\](?!>))+')]
class CommentGrammar(Grammar): class CommentGrammar(Grammar):
rules = [PatternRule(r'data', r'(?:[^-]|-(?!-)|--(?!>))+')] rules = [PatternRule(r'data', r'(?:[^-]|-(?!-)|--(?!>))+')]
class MetadataGrammar(Grammar): class MetadataGrammar(Grammar):
@ -35,7 +72,8 @@ class XMLGrammar(Grammar):
PatternRule(r'data', r'[^<& \n]+'), PatternRule(r'data', r'[^<& \n]+'),
PatternRule(r'spaces', r' +'), PatternRule(r'spaces', r' +'),
RegionRule(r'comment', r'<!--', CommentGrammar, r'-->'), RegionRule(r'comment', r'<!--', CommentGrammar, r'-->'),
RegionRule(r'xml_tag', r'<(?!\?)', TagGrammar, r'/?>'), RegionRule(r'xml_cdata', r'<!\[CDATA\[', CDataGrammar, r'\]\]>'),
RegionRule(r'xml_tag', r'<(?![?!])', TagGrammar, r'/?>'),
PatternRule(r'xml_entity', r'&[a-z]+;'), PatternRule(r'xml_entity', r'&[a-z]+;'),
PatternRule(r'eol', r'\n'), PatternRule(r'eol', r'\n'),
RegionRule(r'xml_metadata', r'<\?', MetadataGrammar, r'\?>'), RegionRule(r'xml_metadata', r'<\?', MetadataGrammar, r'\?>'),
@ -58,6 +96,22 @@ class XmlCreateTag(method.Method):
w.insert_string_at_cursor("</%s>" % t) w.insert_string_at_cursor("</%s>" % t)
w.goto(p) w.goto(p)
class XmlCreateComment(method.Method):
'''Create an opening and closing tag'''
def _execute(self, w, **vargs):
w.insert_string_at_cursor("<!-- ")
p = w.logical_cursor()
w.insert_string_at_cursor(" -->")
w.goto(p)
class XmlCreateCdata(method.Method):
'''Create an opening and closing tag'''
def _execute(self, w, **vargs):
w.insert_string_at_cursor("<![CDATA[")
p = w.logical_cursor()
w.insert_string_at_cursor("]]>")
w.goto(p)
class XML(mode.Fundamental): class XML(mode.Fundamental):
modename = 'XML' modename = 'XML'
extensions = ['.xml', '.xml.in', '.xsl', '.xsd'] extensions = ['.xml', '.xml.in', '.xsl', '.xsd']
@ -75,8 +129,11 @@ class XML(mode.Fundamental):
'xml_tag.string.end': ('green', 'default', 'bold'), 'xml_tag.string.end': ('green', 'default', 'bold'),
'xml_tag.end': ('default', 'default', 'bold'), 'xml_tag.end': ('default', 'default', 'bold'),
'xml_entity': ('magenta', 'default', 'bold'), 'xml_entity': ('magenta', 'default', 'bold'),
'xml_cdata.start': ('magenta', 'default', 'bold'),
'xml_cdata.data': ('green', 'default', 'bold'),
'xml_cdata.end': ('magenta', 'default', 'bold'),
} }
actions = [XmlValidate, XmlCreateTag] actions = [XmlValidate, XmlCreateTag, XmlCreateComment, XmlCreateCdata]
_bindings = { _bindings = {
'xml-create-tag': ('M-t',), 'xml-create-tag': ('M-t',),
} }