X-Git-Url: https://git.rmz.io/dotfiles.git/blobdiff_plain/53ec838a524643a830dba9fc81c21c1627f6b2ae..928005ffdaa1508c6f15bf386a29e02fa44b1136:/vim/ultisnips/cpp.snippets diff --git a/vim/ultisnips/cpp.snippets b/vim/ultisnips/cpp.snippets index a2a4180..4c79d78 100644 --- a/vim/ultisnips/cpp.snippets +++ b/vim/ultisnips/cpp.snippets @@ -1,6 +1,9 @@ # 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 @@ -21,9 +24,17 @@ private: }; // class${1/.+/ $0/m} endsnippet +snippet rule5 "Default constructors/destructors/operaters" b +${1:classname}() = default; +~$1() = default; +$1(const $1 &) = default; +$1($1 &&) = default; +$1 &operator=(const $1 &) = default; +$1 &operator=($1 &&) = default; +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 @@ -42,16 +53,28 @@ for (${4:int} ${2:i} = 0; $2 < ${1:count}; ${3:++$2}) } 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} #elif defined(__APPLE__) ${2} -#elif defined(WIN32) +#elif defined(_WIN32) ${3} #endif endsnippet +snippet pprint "Pretty print expression" b +#define PPRINT(x) std::cout << #x " = " << (x) << '\n'; +PPRINT(${VISUAL}${0}) +endsnippet + # # Qt # @@ -107,3 +130,18 @@ auto ${1:alias}(Args&&... args) return ${2:function}(std::forward(args)...); } endsnippet + +# https://stackoverflow.com/a/14803335 +snippet bind_memfun +template +std::function ${1:object_bind}(Ret (T::* fun)(Args...), T &t) +{ + return [=](Args... args) { return (t.*fun)(args...); }; +} +endsnippet + +snippet once "#pragma once" b +#pragma once + +${0} +endsnippet