From 281781fcee848d18ddcaa9e49271a2e257871826 Mon Sep 17 00:00:00 2001 From: Phillip Berndt Date: Wed, 13 Jul 2011 14:19:17 +0200 Subject: [PATCH] Added snipmate's Filename() helper to UltiSnips.vim --- plugin/UltiSnips.vim | 9 +++++++++ utils/get_snipmate_snippets.py | 17 +---------------- 2 files changed, 10 insertions(+), 16 deletions(-) diff --git a/plugin/UltiSnips.vim b/plugin/UltiSnips.vim index bd7f464..8e3a9fb 100644 --- a/plugin/UltiSnips.vim +++ b/plugin/UltiSnips.vim @@ -12,6 +12,15 @@ if exists('did_UltiSnips_vim') || &cp || version < 700 || !has("python") finish endif +" Snipmate compatibilty: Filename function, taken from +" snipMate.vim {{{ +fun! Filename(...) + let filename = expand('%:t:r') + if filename == '' | return a:0 == 2 ? a:2 : '' | endif + return !a:0 || a:1 == '' ? filename : substitute(a:1, '$1', filename, 'g') +endf +" }}} + " Global Variables {{{ " The trigger used to expand a snippet. diff --git a/utils/get_snipmate_snippets.py b/utils/get_snipmate_snippets.py index 5606a51..668dff8 100755 --- a/utils/get_snipmate_snippets.py +++ b/utils/get_snipmate_snippets.py @@ -8,21 +8,9 @@ import sys import re import os -def global_code_as_required(content): - " Return some global code for the resulting snippet. Only python support here.. " - if "`!p snip.rv = Filename" in content: - return "import os\n" + \ - """def Filename(fn, *args): - filename = os.path.splitext(fn)[0] - if filename == "": - return args[1] if len(args) == 2 else "" - return filename if len(args) == 0 or args[0] == "" else args[1].replace("$1", filename) - """ - def convert_snippet_contents(content): " If the snippet contains snipmate style substitutions, convert them to ultisnips style " - content = re.sub("`\s*Filename\(", "`!p snip.rv = Filename(fn, ", content) - content = re.sub("`(?!!)([^`]+`)", "`!v \g<1>", content) + content = re.sub("`([^`]+`)", "`!v \g<1>", content) return content def convert_snippet_file(source): @@ -92,7 +80,4 @@ if __name__ == '__main__': target = open(target, "w") snippets = convert_snippets(source) - global_code = global_code_as_required(snippets) - if global_code: - print >> target, "global !p\n%s\nendglobal\n" % global_code print >> target, snippets