--- /dev/null
+{
+ "single import": {
+ "prefix": "im",
+ "body": [
+ "import \"${1:package}\""
+ ],
+ "description": "import statement"
+ },
+ "multiple imports": {
+ "prefix": "ims",
+ "body": [
+ "import (",
+ "\t\"${1:package}\"",
+ ")"
+ ],
+ "description": "a import block"
+ },
+ "single constant": {
+ "prefix": "co",
+ "body": [
+ "const ${1:name} = ${2:value}"
+ ],
+ "description": "a constant"
+ },
+ "multiple constants": {
+ "prefix": "cos",
+ "body": [
+ "const (",
+ "\t${1:name} = ${2:value}",
+ ")"
+ ],
+ "description": "a constant block"
+ },
+ "type interface declaration": {
+ "prefix": "tyi",
+ "body": [
+ "type ${1:name} interface {",
+ "\t$0",
+ "}"
+ ],
+ "description": "a type interface"
+ },
+ "type struct declaration": {
+ "prefix": "tys",
+ "body": [
+ "type ${1:name} struct {",
+ "\t$0",
+ "}"
+ ],
+ "description": "a struct declaration"
+ },
+ "package main and main function": {
+ "prefix": "pkgm",
+ "body": [
+ "package main",
+ "",
+ "func main() {",
+ "\t$0",
+ "}"
+ ],
+ "description": "main package & function"
+ },
+ "function declaration": {
+ "prefix": "func",
+ "body": [
+ "func $1($2) $3 {",
+ "\t$0",
+ "}"
+ ],
+ "description": "function declaration"
+ },
+ "variable declaration": {
+ "prefix": "var",
+ "body": [
+ "var ${1:name} ${2:type}"
+ ],
+ "description": "a variable"
+ },
+ "switch statement": {
+ "prefix": "switch",
+ "body": [
+ "switch ${1:expression} {",
+ "case ${2:condition}:",
+ "\t$0",
+ "}"
+ ],
+ "description": "switch statement"
+ },
+ "select statement": {
+ "prefix": "sel",
+ "body": [
+ "select {",
+ "case ${1:condition}:",
+ "\t$0",
+ "}"
+ ],
+ "description": "select statement"
+ },
+ "case clause": {
+ "prefix": "cs",
+ "body": [
+ "case ${1:condition}:$0"
+ ],
+ "description": "case clause"
+ },
+ "for statement": {
+ "prefix": "for",
+ "body": [
+ "for ${1:i} := 0; $1 < ${2:count}; $1${3:++} {",
+ "\t$0",
+ "}"
+ ],
+ "description": "a for loop"
+ },
+ "for range statement": {
+ "prefix": "forr",
+ "body": [
+ "for ${1:_, }${2:var} := range ${3:var} {",
+ "\t$0",
+ "}"
+ ],
+ "description": "a for range loop"
+ },
+ "channel declaration": {
+ "prefix": "ch",
+ "body": [
+ "chan ${1:type}"
+ ],
+ "description": "a channel"
+ },
+ "map declaration": {
+ "prefix": "map",
+ "body": [
+ "map[${1:type}]${2:type}"
+ ],
+ "description": "a map"
+ },
+ "empty interface": {
+ "prefix": "in",
+ "body": [
+ "interface{}"
+ ],
+ "description": "empty interface"
+ },
+ "if statement": {
+ "prefix": "if",
+ "body": [
+ "if ${1:condition} {",
+ "\t$0",
+ "}"
+ ],
+ "description": "if statement"
+ },
+ "else branch": {
+ "prefix": "el",
+ "body": [
+ "else {",
+ "\t$0",
+ "}"
+ ],
+ "description": "else branch"
+ },
+ "if else statement": {
+ "prefix": "ie",
+ "body": [
+ "if ${1:condition} {",
+ "\t$2",
+ "} else {",
+ "\t$0",
+ "}"
+ ],
+ "description": "if else"
+ },
+ "if err != nil": {
+ "prefix": "iferr",
+ "body": [
+ "if err != nil {",
+ "\t${1:return ${2:nil, }${3:err}}",
+ "}"
+ ],
+ "description": "if err != nil"
+ },
+ "fmt.Println": {
+ "prefix": "fp",
+ "body": [
+ "fmt.Println(\"$1\")"
+ ],
+ "description": "fmt.Println()"
+ },
+ "fmt.Printf": {
+ "prefix": "ff",
+ "body": [
+ "fmt.Printf(\"$1\", ${2:var})"
+ ],
+ "description": "fmt.Printf()"
+ },
+ "log.Println": {
+ "prefix": "lp",
+ "body": [
+ "log.Println(\"$1\")"
+ ],
+ "description": "log.Println()"
+ },
+ "log.Printf": {
+ "prefix": "lf",
+ "body": [
+ "log.Printf(\"$1\", ${2:var})"
+ ],
+ "description": "log.Printf()"
+ },
+ "log variable content": {
+ "prefix": "lv",
+ "body": [
+ "log.Printf(\"${1:var}: %#+v\\\\n\", ${1:var})"
+ ],
+ "description": "log.Printf() with variable content"
+ },
+ "t.Log": {
+ "prefix": "tl",
+ "body": [
+ "t.Log(\"$1\")"
+ ],
+ "description": "t.Log()"
+ },
+ "t.Logf": {
+ "prefix": "tlf",
+ "body": [
+ "t.Logf(\"$1\", ${2:var})"
+ ],
+ "description": "t.Logf()"
+ },
+ "t.Logf variable content": {
+ "prefix": "tlv",
+ "body": [
+ "t.Logf(\"${1:var}: %#+v\\\\n\", ${1:var})"
+ ],
+ "description": "t.Logf() with variable content"
+ },
+ "make(...)": {
+ "prefix": "make",
+ "body": [
+ "make(${1:type}, ${2:0})"
+ ],
+ "description": "make statement"
+ },
+ "new(...)": {
+ "prefix": "new",
+ "body": [
+ "new(${1:type})"
+ ],
+ "description": "new statement"
+ },
+ "panic(...)": {
+ "prefix": "pn",
+ "body": [
+ "panic(\"$0\")"
+ ],
+ "description": "panic"
+ },
+ "http ResponseWriter *Request": {
+ "prefix": "wr",
+ "body": [
+ "${1:w} http.ResponseWriter, ${2:r} *http.Request"
+ ],
+ "description": "http Response"
+ },
+ "http.HandleFunc": {
+ "prefix": "hf",
+ "body": [
+ "${1:http}.HandleFunc(\"${2:/}\", ${3:handler})"
+ ],
+ "description": "http.HandleFunc()"
+ },
+ "http handler declaration": {
+ "prefix": "hand",
+ "body": [
+ "func $1(${2:w} http.ResponseWriter, ${3:r} *http.Request) {",
+ "\t$0",
+ "}"
+ ],
+ "description": "http handler declaration"
+ },
+ "http.Redirect": {
+ "prefix": "rd",
+ "body": [
+ "http.Redirect(${1:w}, ${2:r}, \"${3:/}\", ${4:http.StatusFound})"
+ ],
+ "description": "http.Redirect()"
+ },
+ "http.Error": {
+ "prefix": "herr",
+ "body": [
+ "http.Error(${1:w}, ${2:err}.Error(), ${3:http.StatusInternalServerError})"
+ ],
+ "description": "http.Error()"
+ },
+ "http.ListenAndServe": {
+ "prefix": "las",
+ "body": [
+ "http.ListenAndServe(\"${1::8080}\", ${2:nil})"
+ ],
+ "description": "http.ListenAndServe"
+ },
+ "http.Serve": {
+ "prefix": "sv",
+ "body": [
+ "http.Serve(\"${1::8080}\", ${2:nil})"
+ ],
+ "description": "http.Serve"
+ },
+ "goroutine anonymous function": {
+ "prefix": "go",
+ "body": [
+ "go func($1) {",
+ "\t$0",
+ "}($2)"
+ ],
+ "description": "anonymous goroutine declaration"
+ },
+ "goroutine function": {
+ "prefix": "gf",
+ "body": [
+ "go ${1:func}($0)"
+ ],
+ "description": "goroutine declaration"
+ },
+ "defer statement": {
+ "prefix": "df",
+ "body": [
+ "defer ${1:func}($0)"
+ ],
+ "description": "defer statement"
+ },
+ "test function": {
+ "prefix": "tf",
+ "body": [
+ "func Test$1(t *testing.T) {",
+ "\t$0",
+ "}"
+ ],
+ "description": "Test function"
+ },
+ "benchmark function": {
+ "prefix": "bf",
+ "body": [
+ "func Benchmark$1(b *testing.B) {",
+ "\tfor ${2:i} := 0; ${2:i} < b.N; ${2:i}++ {",
+ "\t\t$0",
+ "\t}",
+ "}"
+ ],
+ "description": "Benchmark function"
+ },
+ "example function": {
+ "prefix": "ef",
+ "body": [
+ "func Example$1() {",
+ "\t$2",
+ "\t//Output:",
+ "\t$3",
+ "}"
+ ],
+ "description": "Example function"
+ },
+ "table driven test": {
+ "prefix": "tdt",
+ "body": [
+ "func Test$1(t *testing.T) {",
+ "\ttestCases := []struct {",
+ "\t\tdesc\tstring",
+ "\t\t$2",
+ "\t}{",
+ "\t\t{",
+ "\t\t\tdesc: \"$3\",",
+ "\t\t\t$4",
+ "\t\t},",
+ "\t}",
+ "\tfor _, tC := range testCases {",
+ "\t\tt.Run(tC.desc, func(t *testing.T) {",
+ "\t\t\t$0",
+ "\t\t})",
+ "\t}",
+ "}"
+ ],
+ "description": "table driven test"
+ },
+ "init function": {
+ "prefix": "finit",
+ "body": [
+ "func init() {",
+ "\t$1",
+ "}"
+ ],
+ "description": "init function"
+ },
+ "main function": {
+ "prefix": "fmain",
+ "body": [
+ "func main() {",
+ "\t$1",
+ "}"
+ ],
+ "description": "main function"
+ },
+ "method declaration": {
+ "prefix": "meth",
+ "body": [
+ "func (${1:receiver} ${2:type}) ${3:method}($4) $5 {",
+ "\t$0",
+ "}"
+ ],
+ "description": "method declaration"
+ },
+ "hello world web app": {
+ "prefix": "helloweb",
+ "body": [
+ "package main",
+ "",
+ "import (",
+ "\t\"fmt\"",
+ "\t\"net/http\"",
+ "\t\"time\"",
+ ")",
+ "",
+ "func greet(w http.ResponseWriter, r *http.Request) {",
+ "\tfmt.Fprintf(w, \"Hello World! %s\", time.Now())",
+ "}",
+ "",
+ "func main() {",
+ "\thttp.HandleFunc(\"/\", greet)",
+ "\thttp.ListenAndServe(\":8080\", nil)",
+ "}"
+ ],
+ "description": "sample hello world webapp"
+ },
+ "sort implementation": {
+ "prefix": "sort",
+ "body": [
+ "type ${1:SortBy} []${2:Type}",
+ "",
+ "func (a $1) Len() int { return len(a) }",
+ "func (a $1) Swap(i, j int) { a[i], a[j] = a[j], a[i] }",
+ "func (a $1) Less(i, j int) bool { ${3:return a[i] < a[j]} }"
+ ],
+ "description": "a custom sort.Sort interface implementation, for a given slice type."
+ }
+}
\ No newline at end of file