]> git.rmz.io Git - dotfiles.git/blobdiff - vim/ultisnips/cpp.snippets
Other changes at cadscan (with the ones I want to keep stripped)
[dotfiles.git] / vim / ultisnips / cpp.snippets
index 769f986c297671789e02b1d84e2f5d820db50b1f..f1053621d489d200cf4a4b64674b1133077e9d0a 100644 (file)
@@ -1,18 +1,15 @@
-priority -50
+# replace snippets of parent ft
+priority 1
 
-extends c
-
-# We want to overwrite everything in parent ft.
-priority -49
+snippet inc "#include <>" b
+#include <${1:iostream}>
+endsnippet
 
-###########################################################################
-#                            TextMate Snippets                            #
-###########################################################################
-snippet beginend "$1.begin(), $1.end() (beginend)"
-${1:v}${1/^.*?(-)?(>)?$/(?2::(?1:>:.))/}begin(), $1${1/^.*?(-)?(>)?$/(?2::(?1:>:.))/}end()
+snippet Inc "#include \'\'" b
+#include "${1:`!p snip.rv = snip.basename+".h"`}"
 endsnippet
 
-snippet cl "class .. (class)"
+snippet cl "class .. (class)" b
 class ${1:`!p snip.rv = snip.basename or "name"`}
 {
 public:
@@ -28,30 +25,85 @@ snippet ns "namespace .. (namespace)"
 namespace${1/.+/ /m}${1:`!p snip.rv = snip.basename or "name"`}
 {
 ${VISUAL}${0}
-} // namespace${1/.+/ $0/m}
+}${1/.+/ \/\/ namespace $0/m}
+endsnippet
+
+snippet mfun "Member Function" b
+${4:void} ${1:`!p snip.rv = snip.basename or "name"`}::${2:memberFunction}(${3})
+{
+       ${0}
+}
 endsnippet
 
-snippet readfile "read file (readF)"
-std::vector<char> v;
-if (FILE *fp = fopen(${1:"filename"}, "r"))
+snippet for "for loop (for)"
+for (${4:int} ${2:i} = 0; $2 < ${1:count}; ${3:++$2})
 {
-       char buf[1024];
-       while(size_t len = fread(buf, 1, sizeof(buf), fp))
-               v.insert(v.end(), buf, buf + len);
-       fclose(fp);
+       ${VISUAL}${0}
 }
 endsnippet
 
-snippet map "std::map (map)"
-std::map<${1:key}, ${2:value}> map$0;
+snippet cplat "Cross platform pre processor split" b
+#if defined(__GNUC__) && defined(__unix__)
+${1}
+#elif defined(__APPLE__)
+${2}
+#elif defined(WIN32)
+${3}
+#endif
 endsnippet
 
-snippet vector "std::vector (v)"
-std::vector<${1:char}> v$0;
+#
+# Qt
+#
+global !p
+def align(base, a, pad=' '):
+       amount = abs(len(base) - len(a))
+       return amount * pad if len(base) < len(a) else ''
+endglobal
+
+snippet connect "Qt connect()" b
+connect(${1:this}, `!p snip.rv = align(t[1],t[3])`&${2:class::function},
+        ${3:this}, `!p snip.rv = align(t[3],t[1])`&${4:class::function});
+${0}
+endsnippet
+
+snippet connectl "Qt connect() lambda" b
+connect(${1:this}, &${2:class::function},
+        [=](${3:void}) { ${4} });
+${0}
 endsnippet
 
-snippet tp "template <typename ..> (template)"
-template <typename ${1:_InputIter}>
+snippet w "Define a new QWidget" b
+auto ${1:widget} = new ${2:QWidget};
+$1->setObjectName("${3:$1}");
+${0}
 endsnippet
 
-# vim:ft=snippets:
+snippet widget "Qt Widget Class" b
+class ${1:`!p snip.rv = snip.basename or "WidgetClass"`} : public QWidget
+{
+       Q_OBJECT
+
+public:
+       explicit $1(${2}QWidget *parent = 0);
+       ~$1() = default;
+
+       $0
+public slots:
+
+signals:
+
+private:
+
+}; // class${1/.+/ $0/m}
+endsnippet
+
+# http://stackoverflow.com/a/9864472
+snippet alias "Function alias" b
+template <typename... Args>
+auto ${1:alias}(Args&&... args)
+       -> decltype($2(std::forward<Args>(args)...))
+{
+       return ${2:function}(std::forward<Args>(args)...);
+}
+endsnippet