1
0
Fork 0
mirror of synced 2025-01-07 22:12:14 -05:00
ultimate-vim/sources_non_forked/vim-snippets/snippets/c.snippets

235 lines
3.6 KiB
Text
Raw Normal View History

## Main
# main
2012-08-16 23:41:25 -04:00
snippet main
int main(int argc, const char *argv[])
{
${0}
2012-08-16 23:41:25 -04:00
return 0;
}
# main(void)
2012-08-16 23:41:25 -04:00
snippet mainn
int main(void)
{
${0}
2012-08-16 23:41:25 -04:00
return 0;
}
##
2013-07-17 19:06:05 -04:00
## Preprocessor
2012-08-16 23:41:25 -04:00
# #include <...>
snippet inc
#include <${1:stdio}.h>
2012-08-16 23:41:25 -04:00
# #include "..."
snippet Inc
#include "${1:`vim_snippets#Filename("$1.h")`}"
# ifndef...define...endif
snippet ndef
2012-08-16 23:41:25 -04:00
#ifndef $1
#define ${1:SYMBOL} ${2:value}
2015-12-08 08:20:04 -05:00
#endif /* ifndef $1 */
# define
2012-08-16 23:41:25 -04:00
snippet def
#define
# ifdef...endif
2012-08-16 23:41:25 -04:00
snippet ifdef
#ifdef ${1:FOO}
${2:#define }
#endif
# if
2012-08-16 23:41:25 -04:00
snippet #if
#if ${1:FOO}
${0}
2012-08-16 23:41:25 -04:00
#endif
# header include guard
2012-08-16 23:41:25 -04:00
snippet once
2013-07-17 19:06:05 -04:00
#ifndef ${1:`toupper(vim_snippets#Filename('$1_H', 'UNTITLED_H'))`}
2012-08-16 23:41:25 -04:00
#define $1
${0}
2012-08-16 23:41:25 -04:00
#endif /* end of include guard: $1 */
##
## Control Statements
# if
2012-08-16 23:41:25 -04:00
snippet if
2015-07-13 06:22:46 -04:00
if (${1:true}) {
${0}
}
snippet ife
if (${1:true}) {
2013-07-17 19:06:05 -04:00
${2}
2015-07-13 06:22:46 -04:00
} else {
${0}
}
# else
2012-08-16 23:41:25 -04:00
snippet el
else {
2015-07-13 06:22:46 -04:00
${0}
}
# else if
snippet elif
2015-07-13 06:22:46 -04:00
else if (${1:true}) {
${0}
}
2013-07-17 19:06:05 -04:00
# ifi
snippet ifi
2015-07-13 06:22:46 -04:00
if (${1:true}) ${0};
# ternary
2012-08-16 23:41:25 -04:00
snippet t
${1:/* condition */} ? ${2:a} : ${3:b}
# switch
snippet switch
switch (${1:/* variable */}) {
case ${2:/* variable case */}:
${3}
${4:break;}${5}
default:
${6}
}
# switch without default
snippet switchndef
switch (${1:/* variable */}) {
case ${2:/* variable case */}:
${3}
${4:break;}${5}
}
# case
snippet case
case ${1:/* variable case */}:
${2}
${3:break;}
2015-12-08 08:20:04 -05:00
snippet ret
return ${0};
##
## Loops
# for
2012-08-16 23:41:25 -04:00
snippet for
2016-11-09 12:22:55 -05:00
for (int ${2:i} = 0; $2 < ${1:count}; $2${3:++}) {
2013-07-17 19:06:05 -04:00
${4}
}
# for (custom)
2012-08-16 23:41:25 -04:00
snippet forr
2016-11-09 12:22:55 -05:00
for (int ${1:i} = ${2:0}; ${3:$1 < 10}; $1${4:++}) {
2013-07-17 19:06:05 -04:00
${5}
}
# while
snippet wh
while (${1:/* condition */}) {
2013-07-17 19:06:05 -04:00
${2}
}
# do... while
snippet do
do {
2013-07-17 19:06:05 -04:00
${2}
} while (${1:/* condition */});
##
## Functions
# function definition
2012-08-16 23:41:25 -04:00
snippet fun
${1:void} ${2:function_name}(${3})
{
2013-07-17 19:06:05 -04:00
${4}
}
# function declaration
2012-08-16 23:41:25 -04:00
snippet fund
${1:void} ${2:function_name}(${3});
##
## Types
# typedef
2012-08-16 23:41:25 -04:00
snippet td
typedef ${1:int} ${2:MyCustomType};
# struct
2012-08-16 23:41:25 -04:00
snippet st
2013-07-17 19:06:05 -04:00
struct ${1:`vim_snippets#Filename('$1_t', 'name')`} {
2012-08-16 23:41:25 -04:00
${2:/* data */}
}${3: /* optional variable list */};
# typedef struct
2012-08-16 23:41:25 -04:00
snippet tds
typedef struct ${2:_$1 }{
${3:/* data */}
} ${1:`vim_snippets#Filename('$1_t', 'name')`};
2015-12-08 08:20:04 -05:00
snippet enum
enum ${1:name} { ${0} };
# typedef enum
2012-08-16 23:41:25 -04:00
snippet tde
typedef enum {
${1:/* data */}
} ${2:foo};
##
## Input/Output
2012-08-16 23:41:25 -04:00
# printf
snippet pr
printf("${1:%s}\n"${2});
2012-08-16 23:41:25 -04:00
# fprintf (again, this isn't as nice as TextMate's version, but it works)
snippet fpr
fprintf(${1:stderr}, "${2:%s}\n"${3});
2016-11-09 12:22:55 -05:00
snippet prd
printf("${1:} = %d\n", $1);
snippet prf
printf("${1:} = %f\n", $1);
snippet prx
printf("${1:} = %${2}\n", $1);
# getopt
snippet getopt
int choice;
while (1)
{
static struct option long_options[] =
{
/* Use flags like so:
{"verbose", no_argument, &verbose_flag, 'V'}*/
/* Argument styles: no_argument, required_argument, optional_argument */
{"version", no_argument, 0, 'v'},
{"help", no_argument, 0, 'h'},
${1}
{0,0,0,0}
};
int option_index = 0;
/* Argument parameters:
no_argument: " "
required_argument: ":"
optional_argument: "::" */
choice = getopt_long( argc, argv, "vh",
long_options, &option_index);
if (choice == -1)
break;
switch( choice )
{
case 'v':
${2}
break;
case 'h':
${3}
break;
case '?':
/* getopt_long will have already printed an error */
break;
default:
/* Not sure how to get here... */
return EXIT_FAILURE;
}
}
/* Deal with non-option arguments here */
if ( optind < argc )
{
while ( optind < argc )
{
${0}
}
}
##
## Miscellaneous
2012-08-16 23:41:25 -04:00
# This is kind of convenient
snippet .
[${1}]