]> git.rmz.io Git - dotfiles.git/blobdiff - vim/ultisnips/cpp.snippets
vim/ultisnips: add range-based for loop snippet
[dotfiles.git] / vim / ultisnips / cpp.snippets
index a2a418040c979159f90a5832f2be738f52404071..99cfa78ade44d2dcd8d78957de85a7662d69988f 100644 (file)
@@ -1,6 +1,9 @@
 # replace snippets of parent ft
 priority 1
 
 # replace snippets of parent ft
 priority 1
 
+# disable horrible one word snippets
+clearsnippets pri pro pub fr mu
+
 snippet inc "#include <>" b
 #include <${1:iostream}>
 endsnippet
 snippet inc "#include <>" b
 #include <${1:iostream}>
 endsnippet
@@ -22,8 +25,7 @@ private:
 endsnippet
 
 snippet ns "namespace .. (namespace)"
 endsnippet
 
 snippet ns "namespace .. (namespace)"
-namespace${1/.+/ /m}${1:`!p snip.rv = snip.basename or "name"`}
-{
+namespace${1/.+/ /m}${1:`!p snip.rv = snip.basename or "name"`} {
 ${VISUAL}${0}
 }${1/.+/ \/\/ namespace $0/m}
 endsnippet
 ${VISUAL}${0}
 }${1/.+/ \/\/ namespace $0/m}
 endsnippet
@@ -42,6 +44,13 @@ for (${4:int} ${2:i} = 0; $2 < ${1:count}; ${3:++$2})
 }
 endsnippet
 
 }
 endsnippet
 
+snippet fore "range-based for loop"
+for (auto ${1:n} : ${2:v})
+{
+       ${VISUAL}${0}
+}
+endsnippet
+
 snippet cplat "Cross platform pre processor split" b
 #if defined(__GNUC__) && defined(__unix__)
 ${1}
 snippet cplat "Cross platform pre processor split" b
 #if defined(__GNUC__) && defined(__unix__)
 ${1}
@@ -52,6 +61,11 @@ ${3}
 #endif
 endsnippet
 
 #endif
 endsnippet
 
+snippet pprint "Pretty print expression" b
+#define PPRINT(x) std::cout << #x " = " << (x) << '\n';
+PPRINT(${VISUAL}${0})
+endsnippet
+
 #
 # Qt
 #
 #
 # Qt
 #
@@ -107,3 +121,9 @@ auto ${1:alias}(Args&&... args)
        return ${2:function}(std::forward<Args>(args)...);
 }
 endsnippet
        return ${2:function}(std::forward<Args>(args)...);
 }
 endsnippet
+
+snippet once "#pragma once" b
+#pragma once
+
+${0}
+endsnippet