X-Git-Url: https://git.rmz.io/dotfiles.git/blobdiff_plain/72653b2c0e0ee1b2c2a4126a2582efd6dc52d523..refs/heads/cadscan:/vim/ultisnips/cpp.snippets diff --git a/vim/ultisnips/cpp.snippets b/vim/ultisnips/cpp.snippets index a1b2578..f105362 100644 --- a/vim/ultisnips/cpp.snippets +++ b/vim/ultisnips/cpp.snippets @@ -1,7 +1,15 @@ # replace snippets of parent ft priority 1 -snippet cl "class .. (class)" +snippet inc "#include <>" b +#include <${1:iostream}> +endsnippet + +snippet Inc "#include \'\'" b +#include "${1:`!p snip.rv = snip.basename+".h"`}" +endsnippet + +snippet cl "class .. (class)" b class ${1:`!p snip.rv = snip.basename or "name"`} { public: @@ -47,29 +55,55 @@ endsnippet # # 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}, SIGNAL(${2:signal()}), - ${3:this}, SLOT(${4:slot()})); +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 w "Define a new QWidget" b +auto ${1:widget} = new ${2:QWidget}; +$1->setObjectName("${3:$1}"); ${0} endsnippet snippet widget "Qt Widget Class" b -class ${1:WidgetClass} : public QWidget +class ${1:`!p snip.rv = snip.basename or "WidgetClass"`} : public QWidget { Q_OBJECT public: explicit $1(${2}QWidget *parent = 0); - ~$1(); + ~$1() = default; + $0 public slots: - ${3} signals: - ${4} private: - ${5} -}; +}; // class${1/.+/ $0/m} +endsnippet + +# http://stackoverflow.com/a/9864472 +snippet alias "Function alias" b +template +auto ${1:alias}(Args&&... args) + -> decltype($2(std::forward(args)...)) +{ + return ${2:function}(std::forward(args)...); +} endsnippet