go gen improvements (#524)
Remove the "gen" directory and move directives_generate.go out of it. Add a build ignore tag so it isn't build by default. Cleanup the go gen invocations so there are not seen as package docs. Simplify the code a bit and don't run go gen twice.
This commit is contained in:
parent
a5f3cb5fe5
commit
98c86f3f9f
7 changed files with 140 additions and 145 deletions
2
Makefile
2
Makefile
|
@ -50,7 +50,7 @@ clean:
|
||||||
|
|
||||||
.PHONY: gen
|
.PHONY: gen
|
||||||
gen:
|
gen:
|
||||||
go generate ./core/...
|
go generate coredns.go
|
||||||
|
|
||||||
.PHONY: distclean
|
.PHONY: distclean
|
||||||
distclean: clean
|
distclean: clean
|
||||||
|
|
|
@ -1,7 +1,4 @@
|
||||||
// Package core registers the server and all plugins we support.
|
// Package core registers the server and all plugins we support.
|
||||||
|
|
||||||
// Additional middleware packages
|
|
||||||
//go:generate go run ../gen/directives_generate.go ../middleware.cfg
|
|
||||||
package core
|
package core
|
||||||
|
|
||||||
import (
|
import (
|
||||||
|
|
|
@ -1,4 +1,3 @@
|
||||||
//go:generate go run ../../gen/directives_generate.go ../../middleware.cfg
|
|
||||||
package dnsserver
|
package dnsserver
|
||||||
|
|
||||||
import (
|
import (
|
||||||
|
|
|
@ -1,7 +1,6 @@
|
||||||
// generated by directives_generate.go; DO NOT EDIT
|
// generated by directives_generate.go; DO NOT EDIT
|
||||||
package dnsserver
|
package dnsserver
|
||||||
|
|
||||||
|
|
||||||
// Directives are registered in the order they should be
|
// Directives are registered in the order they should be
|
||||||
// executed.
|
// executed.
|
||||||
//
|
//
|
||||||
|
@ -11,27 +10,27 @@ package dnsserver
|
||||||
// care what middleware above them are doing.
|
// care what middleware above them are doing.
|
||||||
|
|
||||||
var directives = []string{
|
var directives = []string{
|
||||||
"root",
|
"root",
|
||||||
"bind",
|
"bind",
|
||||||
"trace",
|
"trace",
|
||||||
"health",
|
"health",
|
||||||
"pprof",
|
"pprof",
|
||||||
"prometheus",
|
"prometheus",
|
||||||
"errors",
|
"errors",
|
||||||
"log",
|
"log",
|
||||||
"chaos",
|
"chaos",
|
||||||
"cache",
|
"cache",
|
||||||
"rewrite",
|
"rewrite",
|
||||||
"loadbalance",
|
"loadbalance",
|
||||||
"dnssec",
|
"dnssec",
|
||||||
"file",
|
"file",
|
||||||
"auto",
|
"auto",
|
||||||
"secondary",
|
"secondary",
|
||||||
"etcd",
|
"etcd",
|
||||||
"kubernetes",
|
"kubernetes",
|
||||||
"reverse",
|
"reverse",
|
||||||
"proxy",
|
"proxy",
|
||||||
"httpprox",
|
"httpprox",
|
||||||
"whoami",
|
"whoami",
|
||||||
"erratic",
|
"erratic",
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,5 +1,7 @@
|
||||||
package main
|
package main
|
||||||
|
|
||||||
|
//go:generate go run directives_generate.go
|
||||||
|
|
||||||
import "github.com/miekg/coredns/coremain"
|
import "github.com/miekg/coredns/coremain"
|
||||||
|
|
||||||
func main() {
|
func main() {
|
||||||
|
|
114
directives_generate.go
Normal file
114
directives_generate.go
Normal file
|
@ -0,0 +1,114 @@
|
||||||
|
//+build ignore
|
||||||
|
|
||||||
|
package main
|
||||||
|
|
||||||
|
import (
|
||||||
|
"bufio"
|
||||||
|
"go/format"
|
||||||
|
"io/ioutil"
|
||||||
|
"log"
|
||||||
|
"os"
|
||||||
|
"sort"
|
||||||
|
"strconv"
|
||||||
|
"strings"
|
||||||
|
)
|
||||||
|
|
||||||
|
func main() {
|
||||||
|
mi := make(map[string]string, 0)
|
||||||
|
md := make(map[int]string, 0)
|
||||||
|
|
||||||
|
file, err := os.Open(middlewareFile)
|
||||||
|
fatalIfErr(err)
|
||||||
|
|
||||||
|
defer file.Close()
|
||||||
|
|
||||||
|
scanner := bufio.NewScanner(file)
|
||||||
|
for scanner.Scan() {
|
||||||
|
line := scanner.Text()
|
||||||
|
if !strings.HasPrefix(line, `//`) && !strings.HasPrefix(line, "#") {
|
||||||
|
items := strings.Split(line, ":")
|
||||||
|
if len(items) == 3 {
|
||||||
|
if priority, err := strconv.Atoi(items[0]); err == nil {
|
||||||
|
md[priority] = items[1]
|
||||||
|
}
|
||||||
|
|
||||||
|
if items[2] != "" {
|
||||||
|
if strings.Contains(items[2], "/") {
|
||||||
|
mi[items[1]] = items[2]
|
||||||
|
} else {
|
||||||
|
mi[items[1]] = middlewarePath + items[2]
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
genImports("core/zmiddleware.go", "core", mi)
|
||||||
|
genDirectives("core/dnsserver/zdirectives.go", "dnsserver", md)
|
||||||
|
}
|
||||||
|
|
||||||
|
func genImports(file, pack string, mi map[string]string) {
|
||||||
|
outs := header + "package " + pack + "\n\n" + "import ("
|
||||||
|
|
||||||
|
if len(mi) > 0 {
|
||||||
|
outs += "\n"
|
||||||
|
}
|
||||||
|
|
||||||
|
for _, v := range mi {
|
||||||
|
outs += `_ "` + v + `\` + "\n"
|
||||||
|
}
|
||||||
|
outs += ")\n"
|
||||||
|
|
||||||
|
res, err := format.Source([]byte(outs))
|
||||||
|
fatalIfErr(err)
|
||||||
|
|
||||||
|
err = ioutil.WriteFile(file, res, 0644)
|
||||||
|
fatalIfErr(err)
|
||||||
|
}
|
||||||
|
|
||||||
|
func genDirectives(file, pack string, md map[int]string) {
|
||||||
|
|
||||||
|
outs := header + "package " + pack + "\n\n"
|
||||||
|
outs += `
|
||||||
|
// Directives are registered in the order they should be
|
||||||
|
// executed.
|
||||||
|
//
|
||||||
|
// Ordering is VERY important. Every middleware will
|
||||||
|
// feel the effects of all other middleware below
|
||||||
|
// (after) them during a request, but they must not
|
||||||
|
// care what middleware above them are doing.
|
||||||
|
|
||||||
|
var directives = []string{
|
||||||
|
`
|
||||||
|
|
||||||
|
var orders []int
|
||||||
|
for k := range md {
|
||||||
|
orders = append(orders, k)
|
||||||
|
}
|
||||||
|
sort.Ints(orders)
|
||||||
|
|
||||||
|
for _, k := range orders {
|
||||||
|
outs += `"` + md[k] + `",` + "\n"
|
||||||
|
}
|
||||||
|
|
||||||
|
outs += "}\n"
|
||||||
|
|
||||||
|
res, err := format.Source([]byte(outs))
|
||||||
|
fatalIfErr(err)
|
||||||
|
|
||||||
|
err = ioutil.WriteFile(file, res, 0644)
|
||||||
|
fatalIfErr(err)
|
||||||
|
}
|
||||||
|
|
||||||
|
func fatalIfErr(err error) {
|
||||||
|
if err != nil {
|
||||||
|
log.Fatal(err)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
const (
|
||||||
|
middlewarePath = "github.com/miekg/coredns/middleware/"
|
||||||
|
middlewareFile = "middleware.cfg"
|
||||||
|
header = "// generated by directives_generate.go; DO NOT EDIT\n"
|
||||||
|
)
|
|
@ -1,116 +0,0 @@
|
||||||
package main
|
|
||||||
|
|
||||||
import (
|
|
||||||
"bufio"
|
|
||||||
"io/ioutil"
|
|
||||||
"os"
|
|
||||||
"sort"
|
|
||||||
"strconv"
|
|
||||||
"strings"
|
|
||||||
)
|
|
||||||
|
|
||||||
var middlewarePath = "github.com/miekg/coredns/middleware/"
|
|
||||||
var header = "// generated by directives_generate.go; DO NOT EDIT\n"
|
|
||||||
|
|
||||||
func main() {
|
|
||||||
mwFile := os.Args[1]
|
|
||||||
|
|
||||||
mi := make(map[string]string, 0)
|
|
||||||
md := make(map[int]string, 0)
|
|
||||||
|
|
||||||
if file, err := os.Open(mwFile); err == nil {
|
|
||||||
defer file.Close()
|
|
||||||
|
|
||||||
scanner := bufio.NewScanner(file)
|
|
||||||
for scanner.Scan() {
|
|
||||||
line := scanner.Text()
|
|
||||||
if !strings.HasPrefix(line, `//`) && !strings.HasPrefix(line, "#") {
|
|
||||||
items := strings.Split(line, ":")
|
|
||||||
if len(items) == 3 {
|
|
||||||
if priority, err := strconv.Atoi(items[0]); err == nil {
|
|
||||||
md[priority] = items[1]
|
|
||||||
}
|
|
||||||
|
|
||||||
if items[2] != "" {
|
|
||||||
if strings.Contains(items[2], "/") {
|
|
||||||
mi[items[1]] = items[2]
|
|
||||||
} else {
|
|
||||||
mi[items[1]] = middlewarePath + items[2]
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
var orders []int
|
|
||||||
for k := range md {
|
|
||||||
orders = append(orders, k)
|
|
||||||
}
|
|
||||||
sort.Ints(orders)
|
|
||||||
|
|
||||||
if os.Getenv("GOPACKAGE") == "core" {
|
|
||||||
genImports("zmiddleware.go", mi)
|
|
||||||
}
|
|
||||||
if os.Getenv("GOPACKAGE") == "dnsserver" {
|
|
||||||
genDirectives("zdirectives.go", md)
|
|
||||||
}
|
|
||||||
|
|
||||||
} else {
|
|
||||||
os.Exit(1)
|
|
||||||
}
|
|
||||||
os.Exit(0)
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
func genImports(file string, mi map[string]string) {
|
|
||||||
outs := header + "package " + os.Getenv("GOPACKAGE") + "\n\n" + "import ("
|
|
||||||
|
|
||||||
if len(mi) > 0 {
|
|
||||||
outs += "\n"
|
|
||||||
}
|
|
||||||
|
|
||||||
for _, v := range mi {
|
|
||||||
outs += " _ \"" + v + "\"\n"
|
|
||||||
}
|
|
||||||
outs += ")\n"
|
|
||||||
|
|
||||||
err := ioutil.WriteFile(file, []byte(outs), 0644)
|
|
||||||
if err != nil {
|
|
||||||
os.Exit(1)
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
func genDirectives(file string, md map[int]string) {
|
|
||||||
|
|
||||||
outs := header + "package " + os.Getenv("GOPACKAGE") + "\n\n"
|
|
||||||
outs += `
|
|
||||||
// Directives are registered in the order they should be
|
|
||||||
// executed.
|
|
||||||
//
|
|
||||||
// Ordering is VERY important. Every middleware will
|
|
||||||
// feel the effects of all other middleware below
|
|
||||||
// (after) them during a request, but they must not
|
|
||||||
// care what middleware above them are doing.
|
|
||||||
|
|
||||||
var directives = []string{
|
|
||||||
`
|
|
||||||
|
|
||||||
var orders []int
|
|
||||||
for k := range md {
|
|
||||||
orders = append(orders, k)
|
|
||||||
}
|
|
||||||
sort.Ints(orders)
|
|
||||||
|
|
||||||
for _, k := range orders {
|
|
||||||
outs += " \"" + md[k] + "\",\n"
|
|
||||||
}
|
|
||||||
|
|
||||||
outs += "}\n"
|
|
||||||
|
|
||||||
err := ioutil.WriteFile(file, []byte(outs), 0644)
|
|
||||||
if err != nil {
|
|
||||||
os.Exit(1)
|
|
||||||
}
|
|
||||||
}
|
|
Loading…
Add table
Reference in a new issue