
TL; DR: Codegenerator.
Stellen Sie sich vor, Sie entwickeln eine Bibliothek, die verschiedene Speichertreiber unterstützt: Postgresql, Scylla, JSON und einige andere.
Jeder dieser Treiber hat externe Abhängigkeiten von anderen Bibliotheken. Postgresql - database / sql, github.com/lib/pq. Scylla - github.com/scylladb/gocql oder Standard github.com/gocql/gocql. JSON - github.com/mailru/easyjson oder github.com/json-iterator/go oder encoding / json.
.
, : Postgres , , .
, .
, . : sql.go, cql.go, json.go.
, .
pkger .
pkger —
files := make([]string, 0)
if *cql {
files = append(files, pkger.Include("/cql.go"))
}
if *json {
files = append(files, pkger.Include("/json.go"))
}
if *sql {
files = append(files, pkger.Include("/sql.go"))
}
pkger -o < >
, .
go generate
//go:generate pkger -o < >
, .
— Go, .
for i := range files {
_, filename := filepath.Split(files[i])
in, err := pkger.Open(files[i])
if err != nil {
panic(err)
}
src := []byte(fmt.Sprintf(genStr, strings.Join(os.Args[1:], " ")))
reader := bufio.NewReader(in)
for {
line, err := reader.ReadBytes('\n')
if strings.HasPrefix(string(line), "package ") {
line = []byte(fmt.Sprintf("package %s\n", *pkgName))
}
src = append(src, line...)
if err == io.EOF {
break
}
if err != nil {
panic(err)
}
}
if err := ioutil.WriteFile(filename, src, 0644); err != nil {
panic(err)
}
in.Close()
}
“cmd/< >”. , .
go get github.com/< >/< >/< >
Und dann läuft der Codegenerator in seinem Projekt
< > -sql
Wenn Sie Ihre Bibliothek aktualisieren müssen, aktualisiert der Benutzer den Codegenerator
go get -u github.com/< >/< >/< >
Und dann beginnt die Generation von neuem.
Ein Beispiel für einen bestimmten Ansatz zur Verwendung von Abhängigkeiten i CrekerIn der Nan- Bibliothek implementiert : Sie können mit der Bibliothek sowohl im üblichen Modus durch Import als auch in der Codegenerierungsversion arbeiten.