This repository has been archived by the owner on Apr 19, 2018. It is now read-only.
-
Notifications
You must be signed in to change notification settings - Fork 24
/
Copy pathgen.go
90 lines (76 loc) · 2.05 KB
/
gen.go
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
package main
import (
"bytes"
"flag"
"fmt"
"io"
"os"
"github.com/drone/sqlgen/parse"
"github.com/drone/sqlgen/schema"
)
var (
input = flag.String("file", "", "input file name; required")
output = flag.String("o", "", "output file name; required")
pkgName = flag.String("pkg", "main", "output package name; required")
typeName = flag.String("type", "", "type to generate; required")
database = flag.String("db", "sqlite", "sql dialect; required")
genSchema = flag.Bool("schema", true, "generate sql schema and queries")
genFuncs = flag.Bool("funcs", true, "generate sql helper functions")
extraFuncs = flag.Bool("extras", true, "generate extra sql helper functions")
)
func main() {
flag.Parse()
// parses the syntax tree into something a bit
// easier to work with.
tree, err := parse.Parse(*input, *typeName)
if err != nil {
fmt.Fprintf(os.Stderr, "%v\n", err)
os.Exit(1)
}
// if the code is generated in a different folder
// that the struct we need to import the struct
if tree.Pkg != *pkgName && *pkgName != "main" {
// TODO
}
// load the Tree into a schema Object
table := schema.Load(tree)
dialect := schema.New(schema.Dialects[*database])
var buf bytes.Buffer
if *genFuncs {
writePackage(&buf, *pkgName)
writeImports(&buf, tree, "database/sql")
writeRowFunc(&buf, tree)
writeRowsFunc(&buf, tree)
writeSliceFunc(&buf, tree)
if *extraFuncs {
writeSelectRow(&buf, tree)
writeSelectRows(&buf, tree)
writeInsertFunc(&buf, tree)
writeUpdateFunc(&buf, tree)
}
} else {
writePackage(&buf, *pkgName)
}
// write the sql functions
if *genSchema {
writeSchema(&buf, dialect, table)
}
// formats the generated file using gofmt
pretty, err := format(&buf)
if err != nil {
fmt.Fprintf(os.Stderr, "%v\n", err)
return
}
// create output source for file. defaults to
// stdout but may be file.
var out io.WriteCloser = os.Stdout
if *output != "" {
out, err = os.Create(*output)
if err != nil {
fmt.Fprintf(os.Stderr, "%v\n", err)
return
}
defer out.Close()
}
io.Copy(out, pretty)
}