X-Git-Url: https://git.rmz.io/dotfiles.git/blobdiff_plain/d7d49311e213282c381e9187fd0fbc2d477fc047..ba7858552e48c97bbdd128a3f751e827e88d2ce1:/vim/ultisnips/cpp.snippets diff --git a/vim/ultisnips/cpp.snippets b/vim/ultisnips/cpp.snippets index 666c965..5529a1a 100644 --- a/vim/ultisnips/cpp.snippets +++ b/vim/ultisnips/cpp.snippets @@ -24,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 @@ -45,12 +53,19 @@ 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 @@ -93,8 +108,8 @@ class ${1:`!p snip.rv = snip.basename or "WidgetClass"`} : public QWidget Q_OBJECT public: - explicit $1(${2}QWidget *parent = 0); - ~$1() = default; + explicit $1(${2}QWidget *parent = nullptr); + virtual ~$1() = default; $0 public slots: @@ -116,6 +131,15 @@ auto ${1:alias}(Args&&... 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