aboutsummaryrefslogtreecommitdiff
path: root/plugin_generate.go
blob: fe8fef75ddf5e79ab624a610931c2ac6662b61d0 (plain) (blame)
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
//+build ignore

package main

import (
	"bytes"
	"errors"
	"go/ast"
	"go/parser"
	"go/printer"
	"go/token"
	"io/ioutil"
	"log"
	"strconv"
)

func AddImportToFile(file, imprt string) ([]byte, error) {
	fset := token.NewFileSet()
	f, err := parser.ParseFile(fset, file, nil, parser.ParseComments)
	if err != nil {
		return nil, err
	}

	for _, s := range f.Imports {
		iSpec := &ast.ImportSpec{Path: &ast.BasicLit{Value: s.Path.Value}}
		if iSpec.Path.Value == strconv.Quote(imprt) {
			return nil, errors.New("coredns import already found")
		}
	}

	for i := 0; i < len(f.Decls); i++ {
		d := f.Decls[i]

		switch d.(type) {
		case *ast.FuncDecl:
			// No action
		case *ast.GenDecl:
			dd := d.(*ast.GenDecl)

			// IMPORT Declarations
			if dd.Tok == token.IMPORT {
				// Add the new import
				iSpec := &ast.ImportSpec{Name: &ast.Ident{Name: "_"}, Path: &ast.BasicLit{Value: strconv.Quote(imprt)}}
				dd.Specs = append(dd.Specs, iSpec)
				break
			}
		}
	}

	ast.SortImports(fset, f)

	out, err := GenerateFile(fset, f)
	return out, err
}

func GenerateFile(fset *token.FileSet, file *ast.File) ([]byte, error) {
	var output []byte
	buffer := bytes.NewBuffer(output)
	if err := printer.Fprint(buffer, fset, file); err != nil {
		return nil, err
	}

	return buffer.Bytes(), nil
}

const (
	coredns = "github.com/miekg/coredns/core"
	// If everything is OK and we are sitting in CoreDNS' dir, this is where run.go should be.
	caddyrun = "../../mholt/caddy/caddy/caddymain/run.go"
)

func main() {
	out, err := AddImportToFile(caddyrun, coredns)
	if err != nil {
		log.Printf("failed to add import: %s", err)
		return
	}
	if err := ioutil.WriteFile(caddyrun, out, 0644); err != nil {
		log.Fatalf("failed to write go file: %s", err)
	}
}