Merged improvements for Textmate converter script by Daniel Hahler

This commit is contained in:
Holger Rapp 2011-03-14 20:22:16 +01:00
commit f970651dfb

View File

@ -6,6 +6,9 @@ import re
from xml.etree import ElementTree from xml.etree import ElementTree
from xml.parsers.expat import ExpatError from xml.parsers.expat import ExpatError
import htmlentitydefs import htmlentitydefs
import os
import glob
_UNESCAPE = re.compile(ur'&\w+?;', re.UNICODE) _UNESCAPE = re.compile(ur'&\w+?;', re.UNICODE)
def unescape(s): def unescape(s):
@ -13,12 +16,43 @@ def unescape(s):
return "" return ""
def fixup(m): def fixup(m):
ent = m.group(0)[1:-1] ent = m.group(0)[1:-1]
print ent
return unichr(htmlentitydefs.name2codepoint[ent]) return unichr(htmlentitydefs.name2codepoint[ent])
try: try:
return _UNESCAPE.sub(fixup,s.decode("utf-8")).encode("utf-8") return _UNESCAPE.sub(fixup,s)
except: except:
print repr(s) print "unescape failed: %s" % repr(s)
raise
class UnknownVariable(Exception):
pass
class UnsupportedVariableExpression(Exception):
pass
def replace_vars(m):
""" Replace vars in 'content' portion.
:m: match object
:returns: string"""
var = m.group(1)
default = m.group(2)
if not re.match(r'\w+$', var):
raise UnsupportedVariableExpression(var)
translate_vars = {
'TM_PHP_OPEN_TAG_WITH_ECHO': 'g:UltiSnipsOpenTagWithEcho',
'TM_PHP_OPEN_TAG': 'g:UltiSnipsOpenTag',
'PHPDOC_AUTHOR': 'g:snips_author',
}
# TODO: TM_SELECTED_TEXT/([\t ]*).*/$1/m
if var in translate_vars:
newvar = translate_vars[var]
else:
# TODO: this could be autogenerated
raise UnknownVariable(var)
return "`!v exists('%s') ? %s : '%s'`" % (newvar, newvar, default)
def parse_content(c): def parse_content(c):
try: try:
@ -28,12 +62,22 @@ def parse_content(c):
for k,v in zip(data[::2], data[1::2]): for k,v in zip(data[::2], data[1::2]):
rv[k.text] = unescape(v.text) rv[k.text] = unescape(v.text)
if re.search( r'\$\{\D', rv["content"] ):
rv["content"] = re.sub(r'\$\{([^\d}][^}:]*)(?::([^}]*))?\}', replace_vars, rv["content"])
return rv return rv
except ExpatError: except (ExpatError, ElementTree.ParseError) as detail:
print " Syntax Error" print " Syntax Error: %s" % (detail,)
print c
return None
except UnknownVariable as detail:
print " Unknown variable: %s" % (detail,)
return None
except UnsupportedVariableExpression as detail:
print " Unsupported variable expression: %s" % (detail,)
return None return None
def fetch_snippets(name): def fetch_snippets_from_svn(name):
base_url = "http://svn.textmate.org/trunk/Bundles/" + name + ".tmbundle/" base_url = "http://svn.textmate.org/trunk/Bundles/" + name + ".tmbundle/"
snippet_idx = base_url + "Snippets/" snippet_idx = base_url + "Snippets/"
@ -57,6 +101,20 @@ def fetch_snippets(name):
return rv return rv
def fetch_snippets_from_dir(path):
""" Fetch snippets from a given path"""
rv = []
for filename in glob.glob(os.path.join(path, '*.tmSnippet')):
print "Reading file %s" % filename
f = open(filename)
content = f.read()
cont = parse_content(content)
if cont:
name = os.path.splitext(os.path.basename(filename))[0]
rv.append((name, cont))
return rv
def write_snippets(snip_descr, f): def write_snippets(snip_descr, f):
@ -64,6 +122,10 @@ def write_snippets(snip_descr, f):
if "tabTrigger" not in d: if "tabTrigger" not in d:
continue continue
if "content" not in d or d["content"] is None:
print "SKIP: %s (no content)" % (d,)
continue
f.write('snippet %s "%s"\n' % (d["tabTrigger"], name)) f.write('snippet %s "%s"\n' % (d["tabTrigger"], name))
f.write(d["content"].encode("utf-8") + "\n") f.write(d["content"].encode("utf-8") + "\n")
f.write("endsnippet\n\n") f.write("endsnippet\n\n")
@ -74,6 +136,13 @@ if __name__ == '__main__':
import sys import sys
bundle = sys.argv[1] bundle = sys.argv[1]
rv = fetch_snippets(bundle)
write_snippets(rv, open("tm_" + bundle.lower() + ".snippets","w")) if os.path.isdir(bundle):
name = sys.argv[2]
rv = fetch_snippets_from_dir(bundle)
else:
rv = fetch_snippets_from_svn(bundle)
name = bundle.lower()
write_snippets(rv, open("tm_" + name + ".snippets","w"))