annotate zs.go @ 5:e0ee0721d34f draft

added tests for eval command runner
author zaitsev.serge
date Fri, 05 Dec 2014 18:21:42 +0000
parents 05fc24caac37
children cb66f5b86616
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
0
45a9e1fac18e initial commit
zaitsev.serge
parents:
diff changeset
1 package main
45a9e1fac18e initial commit
zaitsev.serge
parents:
diff changeset
2
45a9e1fac18e initial commit
zaitsev.serge
parents:
diff changeset
3 import (
45a9e1fac18e initial commit
zaitsev.serge
parents:
diff changeset
4 "bytes"
45a9e1fac18e initial commit
zaitsev.serge
parents:
diff changeset
5 "fmt"
45a9e1fac18e initial commit
zaitsev.serge
parents:
diff changeset
6 "io"
45a9e1fac18e initial commit
zaitsev.serge
parents:
diff changeset
7 "io/ioutil"
45a9e1fac18e initial commit
zaitsev.serge
parents:
diff changeset
8 "log"
45a9e1fac18e initial commit
zaitsev.serge
parents:
diff changeset
9 "os"
45a9e1fac18e initial commit
zaitsev.serge
parents:
diff changeset
10 "os/exec"
45a9e1fac18e initial commit
zaitsev.serge
parents:
diff changeset
11 "path"
45a9e1fac18e initial commit
zaitsev.serge
parents:
diff changeset
12 "path/filepath"
45a9e1fac18e initial commit
zaitsev.serge
parents:
diff changeset
13 "strings"
45a9e1fac18e initial commit
zaitsev.serge
parents:
diff changeset
14 "time"
45a9e1fac18e initial commit
zaitsev.serge
parents:
diff changeset
15
45a9e1fac18e initial commit
zaitsev.serge
parents:
diff changeset
16 "github.com/russross/blackfriday"
45a9e1fac18e initial commit
zaitsev.serge
parents:
diff changeset
17 )
45a9e1fac18e initial commit
zaitsev.serge
parents:
diff changeset
18
45a9e1fac18e initial commit
zaitsev.serge
parents:
diff changeset
19 const (
45a9e1fac18e initial commit
zaitsev.serge
parents:
diff changeset
20 ZSDIR = ".zs"
45a9e1fac18e initial commit
zaitsev.serge
parents:
diff changeset
21 PUBDIR = ".pub"
45a9e1fac18e initial commit
zaitsev.serge
parents:
diff changeset
22 )
45a9e1fac18e initial commit
zaitsev.serge
parents:
diff changeset
23
3
53dea9841cd9 moved eval func type to the top, added some error logs
zaitsev.serge
parents: 2
diff changeset
24 type EvalFn func(args []string, vars map[string]string) (string, error)
53dea9841cd9 moved eval func type to the top, added some error logs
zaitsev.serge
parents: 2
diff changeset
25
0
45a9e1fac18e initial commit
zaitsev.serge
parents:
diff changeset
26 func split2(s, delim string) (string, string) {
45a9e1fac18e initial commit
zaitsev.serge
parents:
diff changeset
27 parts := strings.SplitN(s, delim, 2)
45a9e1fac18e initial commit
zaitsev.serge
parents:
diff changeset
28 if len(parts) == 2 {
45a9e1fac18e initial commit
zaitsev.serge
parents:
diff changeset
29 return parts[0], parts[1]
45a9e1fac18e initial commit
zaitsev.serge
parents:
diff changeset
30 } else {
45a9e1fac18e initial commit
zaitsev.serge
parents:
diff changeset
31 return parts[0], ""
45a9e1fac18e initial commit
zaitsev.serge
parents:
diff changeset
32 }
45a9e1fac18e initial commit
zaitsev.serge
parents:
diff changeset
33 }
45a9e1fac18e initial commit
zaitsev.serge
parents:
diff changeset
34
45a9e1fac18e initial commit
zaitsev.serge
parents:
diff changeset
35 func md(s string) (map[string]string, string) {
45a9e1fac18e initial commit
zaitsev.serge
parents:
diff changeset
36 v := map[string]string{}
2
fd79b3a90bef fixed empty header in markdown
zaitsev.serge
parents: 0
diff changeset
37 if strings.Index(s, "\n\n") == -1 {
fd79b3a90bef fixed empty header in markdown
zaitsev.serge
parents: 0
diff changeset
38 return map[string]string{}, s
fd79b3a90bef fixed empty header in markdown
zaitsev.serge
parents: 0
diff changeset
39 }
0
45a9e1fac18e initial commit
zaitsev.serge
parents:
diff changeset
40 header, body := split2(s, "\n\n")
45a9e1fac18e initial commit
zaitsev.serge
parents:
diff changeset
41 for _, line := range strings.Split(header, "\n") {
45a9e1fac18e initial commit
zaitsev.serge
parents:
diff changeset
42 key, value := split2(line, ":")
45a9e1fac18e initial commit
zaitsev.serge
parents:
diff changeset
43 v[strings.ToLower(strings.TrimSpace(key))] = strings.TrimSpace(value)
45a9e1fac18e initial commit
zaitsev.serge
parents:
diff changeset
44 }
45a9e1fac18e initial commit
zaitsev.serge
parents:
diff changeset
45 return v, body
45a9e1fac18e initial commit
zaitsev.serge
parents:
diff changeset
46 }
45a9e1fac18e initial commit
zaitsev.serge
parents:
diff changeset
47
45a9e1fac18e initial commit
zaitsev.serge
parents:
diff changeset
48 func render(s string, vars map[string]string, eval EvalFn) (string, error) {
4
05fc24caac37 render uses strings, not bytes; added helpers for env and run
zaitsev.serge
parents: 3
diff changeset
49 delim_open := "{{"
05fc24caac37 render uses strings, not bytes; added helpers for env and run
zaitsev.serge
parents: 3
diff changeset
50 delim_close := "}}"
0
45a9e1fac18e initial commit
zaitsev.serge
parents:
diff changeset
51
45a9e1fac18e initial commit
zaitsev.serge
parents:
diff changeset
52 out := bytes.NewBuffer(nil)
45a9e1fac18e initial commit
zaitsev.serge
parents:
diff changeset
53 for {
4
05fc24caac37 render uses strings, not bytes; added helpers for env and run
zaitsev.serge
parents: 3
diff changeset
54 if from := strings.Index(s, delim_open); from == -1 {
05fc24caac37 render uses strings, not bytes; added helpers for env and run
zaitsev.serge
parents: 3
diff changeset
55 out.WriteString(s)
0
45a9e1fac18e initial commit
zaitsev.serge
parents:
diff changeset
56 return out.String(), nil
45a9e1fac18e initial commit
zaitsev.serge
parents:
diff changeset
57 } else {
4
05fc24caac37 render uses strings, not bytes; added helpers for env and run
zaitsev.serge
parents: 3
diff changeset
58 if to := strings.Index(s, delim_close); to == -1 {
0
45a9e1fac18e initial commit
zaitsev.serge
parents:
diff changeset
59 return "", fmt.Errorf("Close delim not found")
45a9e1fac18e initial commit
zaitsev.serge
parents:
diff changeset
60 } else {
4
05fc24caac37 render uses strings, not bytes; added helpers for env and run
zaitsev.serge
parents: 3
diff changeset
61 out.WriteString(s[:from])
05fc24caac37 render uses strings, not bytes; added helpers for env and run
zaitsev.serge
parents: 3
diff changeset
62 cmd := s[from+len(delim_open) : to]
05fc24caac37 render uses strings, not bytes; added helpers for env and run
zaitsev.serge
parents: 3
diff changeset
63 s = s[to+len(delim_close):]
05fc24caac37 render uses strings, not bytes; added helpers for env and run
zaitsev.serge
parents: 3
diff changeset
64 m := strings.Fields(cmd)
0
45a9e1fac18e initial commit
zaitsev.serge
parents:
diff changeset
65 if len(m) == 1 {
45a9e1fac18e initial commit
zaitsev.serge
parents:
diff changeset
66 if v, ok := vars[m[0]]; ok {
4
05fc24caac37 render uses strings, not bytes; added helpers for env and run
zaitsev.serge
parents: 3
diff changeset
67 out.WriteString(v)
0
45a9e1fac18e initial commit
zaitsev.serge
parents:
diff changeset
68 continue
45a9e1fac18e initial commit
zaitsev.serge
parents:
diff changeset
69 }
45a9e1fac18e initial commit
zaitsev.serge
parents:
diff changeset
70 }
45a9e1fac18e initial commit
zaitsev.serge
parents:
diff changeset
71 if res, err := eval(m, vars); err == nil {
4
05fc24caac37 render uses strings, not bytes; added helpers for env and run
zaitsev.serge
parents: 3
diff changeset
72 out.WriteString(res)
0
45a9e1fac18e initial commit
zaitsev.serge
parents:
diff changeset
73 } else {
45a9e1fac18e initial commit
zaitsev.serge
parents:
diff changeset
74 log.Println(err) // silent
45a9e1fac18e initial commit
zaitsev.serge
parents:
diff changeset
75 }
45a9e1fac18e initial commit
zaitsev.serge
parents:
diff changeset
76 }
45a9e1fac18e initial commit
zaitsev.serge
parents:
diff changeset
77 }
45a9e1fac18e initial commit
zaitsev.serge
parents:
diff changeset
78 }
45a9e1fac18e initial commit
zaitsev.serge
parents:
diff changeset
79 }
45a9e1fac18e initial commit
zaitsev.serge
parents:
diff changeset
80
4
05fc24caac37 render uses strings, not bytes; added helpers for env and run
zaitsev.serge
parents: 3
diff changeset
81 func env(vars map[string]string) []string {
0
45a9e1fac18e initial commit
zaitsev.serge
parents:
diff changeset
82 env := []string{"ZS=" + os.Args[0]}
4
05fc24caac37 render uses strings, not bytes; added helpers for env and run
zaitsev.serge
parents: 3
diff changeset
83 env = append(env, os.Environ()...)
0
45a9e1fac18e initial commit
zaitsev.serge
parents:
diff changeset
84 for k, v := range vars {
45a9e1fac18e initial commit
zaitsev.serge
parents:
diff changeset
85 env = append(env, "ZS_"+strings.ToUpper(k)+"="+v)
45a9e1fac18e initial commit
zaitsev.serge
parents:
diff changeset
86 }
4
05fc24caac37 render uses strings, not bytes; added helpers for env and run
zaitsev.serge
parents: 3
diff changeset
87 return env
05fc24caac37 render uses strings, not bytes; added helpers for env and run
zaitsev.serge
parents: 3
diff changeset
88 }
05fc24caac37 render uses strings, not bytes; added helpers for env and run
zaitsev.serge
parents: 3
diff changeset
89
05fc24caac37 render uses strings, not bytes; added helpers for env and run
zaitsev.serge
parents: 3
diff changeset
90 func run(cmd string, args []string, vars map[string]string, output io.Writer) error {
05fc24caac37 render uses strings, not bytes; added helpers for env and run
zaitsev.serge
parents: 3
diff changeset
91 var errbuf bytes.Buffer
05fc24caac37 render uses strings, not bytes; added helpers for env and run
zaitsev.serge
parents: 3
diff changeset
92 c := exec.Command(cmd, args...)
05fc24caac37 render uses strings, not bytes; added helpers for env and run
zaitsev.serge
parents: 3
diff changeset
93 c.Env = env(vars)
05fc24caac37 render uses strings, not bytes; added helpers for env and run
zaitsev.serge
parents: 3
diff changeset
94 c.Stdout = output
0
45a9e1fac18e initial commit
zaitsev.serge
parents:
diff changeset
95 c.Stderr = &errbuf
4
05fc24caac37 render uses strings, not bytes; added helpers for env and run
zaitsev.serge
parents: 3
diff changeset
96
05fc24caac37 render uses strings, not bytes; added helpers for env and run
zaitsev.serge
parents: 3
diff changeset
97 err := c.Run()
05fc24caac37 render uses strings, not bytes; added helpers for env and run
zaitsev.serge
parents: 3
diff changeset
98
05fc24caac37 render uses strings, not bytes; added helpers for env and run
zaitsev.serge
parents: 3
diff changeset
99 if errbuf.Len() > 0 {
05fc24caac37 render uses strings, not bytes; added helpers for env and run
zaitsev.serge
parents: 3
diff changeset
100 log.Println(errbuf.String())
05fc24caac37 render uses strings, not bytes; added helpers for env and run
zaitsev.serge
parents: 3
diff changeset
101 }
05fc24caac37 render uses strings, not bytes; added helpers for env and run
zaitsev.serge
parents: 3
diff changeset
102
05fc24caac37 render uses strings, not bytes; added helpers for env and run
zaitsev.serge
parents: 3
diff changeset
103 if err != nil {
05fc24caac37 render uses strings, not bytes; added helpers for env and run
zaitsev.serge
parents: 3
diff changeset
104 return err
05fc24caac37 render uses strings, not bytes; added helpers for env and run
zaitsev.serge
parents: 3
diff changeset
105 }
05fc24caac37 render uses strings, not bytes; added helpers for env and run
zaitsev.serge
parents: 3
diff changeset
106 return nil
05fc24caac37 render uses strings, not bytes; added helpers for env and run
zaitsev.serge
parents: 3
diff changeset
107 }
05fc24caac37 render uses strings, not bytes; added helpers for env and run
zaitsev.serge
parents: 3
diff changeset
108
05fc24caac37 render uses strings, not bytes; added helpers for env and run
zaitsev.serge
parents: 3
diff changeset
109 func eval(cmd []string, vars map[string]string) (string, error) {
05fc24caac37 render uses strings, not bytes; added helpers for env and run
zaitsev.serge
parents: 3
diff changeset
110 outbuf := bytes.NewBuffer(nil)
05fc24caac37 render uses strings, not bytes; added helpers for env and run
zaitsev.serge
parents: 3
diff changeset
111 err := run(path.Join(ZSDIR, cmd[0]), cmd[1:], vars, outbuf)
05fc24caac37 render uses strings, not bytes; added helpers for env and run
zaitsev.serge
parents: 3
diff changeset
112 if err != nil {
5
e0ee0721d34f added tests for eval command runner
zaitsev.serge
parents: 4
diff changeset
113 if _, ok := err.(*exec.ExitError); ok {
e0ee0721d34f added tests for eval command runner
zaitsev.serge
parents: 4
diff changeset
114 return "", err
e0ee0721d34f added tests for eval command runner
zaitsev.serge
parents: 4
diff changeset
115 }
4
05fc24caac37 render uses strings, not bytes; added helpers for env and run
zaitsev.serge
parents: 3
diff changeset
116 outbuf = bytes.NewBuffer(nil)
05fc24caac37 render uses strings, not bytes; added helpers for env and run
zaitsev.serge
parents: 3
diff changeset
117 err := run(cmd[0], cmd[1:], vars, outbuf)
5
e0ee0721d34f added tests for eval command runner
zaitsev.serge
parents: 4
diff changeset
118 // Return exit errors, but ignore if the command was not found
e0ee0721d34f added tests for eval command runner
zaitsev.serge
parents: 4
diff changeset
119 if _, ok := err.(*exec.ExitError); ok {
0
45a9e1fac18e initial commit
zaitsev.serge
parents:
diff changeset
120 return "", err
45a9e1fac18e initial commit
zaitsev.serge
parents:
diff changeset
121 }
45a9e1fac18e initial commit
zaitsev.serge
parents:
diff changeset
122 }
45a9e1fac18e initial commit
zaitsev.serge
parents:
diff changeset
123 return outbuf.String(), nil
45a9e1fac18e initial commit
zaitsev.serge
parents:
diff changeset
124 }
45a9e1fac18e initial commit
zaitsev.serge
parents:
diff changeset
125
45a9e1fac18e initial commit
zaitsev.serge
parents:
diff changeset
126 func buildMarkdown(path string) error {
45a9e1fac18e initial commit
zaitsev.serge
parents:
diff changeset
127 b, err := ioutil.ReadFile(path)
45a9e1fac18e initial commit
zaitsev.serge
parents:
diff changeset
128 if err != nil {
45a9e1fac18e initial commit
zaitsev.serge
parents:
diff changeset
129 return err
45a9e1fac18e initial commit
zaitsev.serge
parents:
diff changeset
130 }
45a9e1fac18e initial commit
zaitsev.serge
parents:
diff changeset
131 v, body := md(string(b))
45a9e1fac18e initial commit
zaitsev.serge
parents:
diff changeset
132 defaultVars(v, path)
45a9e1fac18e initial commit
zaitsev.serge
parents:
diff changeset
133 content, err := render(body, v, eval)
45a9e1fac18e initial commit
zaitsev.serge
parents:
diff changeset
134 if err != nil {
45a9e1fac18e initial commit
zaitsev.serge
parents:
diff changeset
135 return err
45a9e1fac18e initial commit
zaitsev.serge
parents:
diff changeset
136 }
45a9e1fac18e initial commit
zaitsev.serge
parents:
diff changeset
137 v["content"] = string(blackfriday.MarkdownBasic([]byte(content)))
45a9e1fac18e initial commit
zaitsev.serge
parents:
diff changeset
138 b, err = ioutil.ReadFile(filepath.Join(ZSDIR, v["layout"]))
45a9e1fac18e initial commit
zaitsev.serge
parents:
diff changeset
139 if err != nil {
45a9e1fac18e initial commit
zaitsev.serge
parents:
diff changeset
140 return err
45a9e1fac18e initial commit
zaitsev.serge
parents:
diff changeset
141 }
45a9e1fac18e initial commit
zaitsev.serge
parents:
diff changeset
142 content, err = render(string(b), v, eval)
45a9e1fac18e initial commit
zaitsev.serge
parents:
diff changeset
143 if err != nil {
45a9e1fac18e initial commit
zaitsev.serge
parents:
diff changeset
144 return err
45a9e1fac18e initial commit
zaitsev.serge
parents:
diff changeset
145 }
45a9e1fac18e initial commit
zaitsev.serge
parents:
diff changeset
146 err = ioutil.WriteFile(v["output"], []byte(content), 0666)
45a9e1fac18e initial commit
zaitsev.serge
parents:
diff changeset
147 if err != nil {
45a9e1fac18e initial commit
zaitsev.serge
parents:
diff changeset
148 return err
45a9e1fac18e initial commit
zaitsev.serge
parents:
diff changeset
149 }
45a9e1fac18e initial commit
zaitsev.serge
parents:
diff changeset
150 return nil
45a9e1fac18e initial commit
zaitsev.serge
parents:
diff changeset
151 }
45a9e1fac18e initial commit
zaitsev.serge
parents:
diff changeset
152
45a9e1fac18e initial commit
zaitsev.serge
parents:
diff changeset
153 func defaultVars(vars map[string]string, path string) {
45a9e1fac18e initial commit
zaitsev.serge
parents:
diff changeset
154 if _, ok := vars["file"]; !ok {
45a9e1fac18e initial commit
zaitsev.serge
parents:
diff changeset
155 vars["file"] = path
45a9e1fac18e initial commit
zaitsev.serge
parents:
diff changeset
156 }
45a9e1fac18e initial commit
zaitsev.serge
parents:
diff changeset
157 if _, ok := vars["url"]; !ok {
45a9e1fac18e initial commit
zaitsev.serge
parents:
diff changeset
158 vars["url"] = path[:len(path)-len(filepath.Ext(path))] + ".html"
45a9e1fac18e initial commit
zaitsev.serge
parents:
diff changeset
159 if strings.HasPrefix(vars["url"], "./") {
45a9e1fac18e initial commit
zaitsev.serge
parents:
diff changeset
160 vars["url"] = vars["url"][2:]
45a9e1fac18e initial commit
zaitsev.serge
parents:
diff changeset
161 }
45a9e1fac18e initial commit
zaitsev.serge
parents:
diff changeset
162 }
45a9e1fac18e initial commit
zaitsev.serge
parents:
diff changeset
163 if _, ok := vars["outdir"]; !ok {
45a9e1fac18e initial commit
zaitsev.serge
parents:
diff changeset
164 vars["outdir"] = PUBDIR
45a9e1fac18e initial commit
zaitsev.serge
parents:
diff changeset
165 }
45a9e1fac18e initial commit
zaitsev.serge
parents:
diff changeset
166 if _, ok := vars["output"]; !ok {
45a9e1fac18e initial commit
zaitsev.serge
parents:
diff changeset
167 vars["output"] = filepath.Join(PUBDIR, vars["url"])
45a9e1fac18e initial commit
zaitsev.serge
parents:
diff changeset
168 }
45a9e1fac18e initial commit
zaitsev.serge
parents:
diff changeset
169 if _, ok := vars["layout"]; !ok {
45a9e1fac18e initial commit
zaitsev.serge
parents:
diff changeset
170 vars["layout"] = "index.html"
45a9e1fac18e initial commit
zaitsev.serge
parents:
diff changeset
171 }
45a9e1fac18e initial commit
zaitsev.serge
parents:
diff changeset
172 }
45a9e1fac18e initial commit
zaitsev.serge
parents:
diff changeset
173
45a9e1fac18e initial commit
zaitsev.serge
parents:
diff changeset
174 func copyFile(path string) error {
45a9e1fac18e initial commit
zaitsev.serge
parents:
diff changeset
175 if in, err := os.Open(path); err != nil {
45a9e1fac18e initial commit
zaitsev.serge
parents:
diff changeset
176 return err
45a9e1fac18e initial commit
zaitsev.serge
parents:
diff changeset
177 } else {
45a9e1fac18e initial commit
zaitsev.serge
parents:
diff changeset
178 defer in.Close()
45a9e1fac18e initial commit
zaitsev.serge
parents:
diff changeset
179 if stat, err := in.Stat(); err != nil {
45a9e1fac18e initial commit
zaitsev.serge
parents:
diff changeset
180 return err
45a9e1fac18e initial commit
zaitsev.serge
parents:
diff changeset
181 } else {
45a9e1fac18e initial commit
zaitsev.serge
parents:
diff changeset
182 // Directory?
45a9e1fac18e initial commit
zaitsev.serge
parents:
diff changeset
183 if stat.Mode().IsDir() {
45a9e1fac18e initial commit
zaitsev.serge
parents:
diff changeset
184 os.Mkdir(filepath.Join(PUBDIR, path), 0755)
45a9e1fac18e initial commit
zaitsev.serge
parents:
diff changeset
185 return nil
45a9e1fac18e initial commit
zaitsev.serge
parents:
diff changeset
186 }
45a9e1fac18e initial commit
zaitsev.serge
parents:
diff changeset
187 if !stat.Mode().IsRegular() {
45a9e1fac18e initial commit
zaitsev.serge
parents:
diff changeset
188 return nil
45a9e1fac18e initial commit
zaitsev.serge
parents:
diff changeset
189 }
45a9e1fac18e initial commit
zaitsev.serge
parents:
diff changeset
190 }
45a9e1fac18e initial commit
zaitsev.serge
parents:
diff changeset
191 if out, err := os.Create(filepath.Join(PUBDIR, path)); err != nil {
45a9e1fac18e initial commit
zaitsev.serge
parents:
diff changeset
192 return err
45a9e1fac18e initial commit
zaitsev.serge
parents:
diff changeset
193 } else {
45a9e1fac18e initial commit
zaitsev.serge
parents:
diff changeset
194 defer out.Close()
45a9e1fac18e initial commit
zaitsev.serge
parents:
diff changeset
195 _, err = io.Copy(out, in)
45a9e1fac18e initial commit
zaitsev.serge
parents:
diff changeset
196 return err
45a9e1fac18e initial commit
zaitsev.serge
parents:
diff changeset
197 }
45a9e1fac18e initial commit
zaitsev.serge
parents:
diff changeset
198 }
45a9e1fac18e initial commit
zaitsev.serge
parents:
diff changeset
199 }
45a9e1fac18e initial commit
zaitsev.serge
parents:
diff changeset
200
45a9e1fac18e initial commit
zaitsev.serge
parents:
diff changeset
201 func buildAll(once bool) {
45a9e1fac18e initial commit
zaitsev.serge
parents:
diff changeset
202 lastModified := time.Unix(0, 0)
45a9e1fac18e initial commit
zaitsev.serge
parents:
diff changeset
203 for {
45a9e1fac18e initial commit
zaitsev.serge
parents:
diff changeset
204 os.Mkdir(PUBDIR, 0755)
45a9e1fac18e initial commit
zaitsev.serge
parents:
diff changeset
205 err := filepath.Walk(".", func(path string, info os.FileInfo, err error) error {
45a9e1fac18e initial commit
zaitsev.serge
parents:
diff changeset
206 // ignore hidden files and directories
45a9e1fac18e initial commit
zaitsev.serge
parents:
diff changeset
207 if filepath.Base(path)[0] == '.' || strings.HasPrefix(path, ".") {
45a9e1fac18e initial commit
zaitsev.serge
parents:
diff changeset
208 return nil
45a9e1fac18e initial commit
zaitsev.serge
parents:
diff changeset
209 }
45a9e1fac18e initial commit
zaitsev.serge
parents:
diff changeset
210
45a9e1fac18e initial commit
zaitsev.serge
parents:
diff changeset
211 if info.ModTime().After(lastModified) {
45a9e1fac18e initial commit
zaitsev.serge
parents:
diff changeset
212 ext := filepath.Ext(path)
45a9e1fac18e initial commit
zaitsev.serge
parents:
diff changeset
213 if ext == ".md" || ext == "mkd" {
45a9e1fac18e initial commit
zaitsev.serge
parents:
diff changeset
214 log.Println("mkd: ", path)
45a9e1fac18e initial commit
zaitsev.serge
parents:
diff changeset
215 return buildMarkdown(path)
45a9e1fac18e initial commit
zaitsev.serge
parents:
diff changeset
216 } else {
45a9e1fac18e initial commit
zaitsev.serge
parents:
diff changeset
217 log.Println("raw: ", path)
45a9e1fac18e initial commit
zaitsev.serge
parents:
diff changeset
218 return copyFile(path)
45a9e1fac18e initial commit
zaitsev.serge
parents:
diff changeset
219 }
45a9e1fac18e initial commit
zaitsev.serge
parents:
diff changeset
220 }
45a9e1fac18e initial commit
zaitsev.serge
parents:
diff changeset
221 return nil
45a9e1fac18e initial commit
zaitsev.serge
parents:
diff changeset
222 })
45a9e1fac18e initial commit
zaitsev.serge
parents:
diff changeset
223 if err != nil {
45a9e1fac18e initial commit
zaitsev.serge
parents:
diff changeset
224 log.Println("ERROR:", err)
45a9e1fac18e initial commit
zaitsev.serge
parents:
diff changeset
225 }
45a9e1fac18e initial commit
zaitsev.serge
parents:
diff changeset
226 lastModified = time.Now()
45a9e1fac18e initial commit
zaitsev.serge
parents:
diff changeset
227 if once {
45a9e1fac18e initial commit
zaitsev.serge
parents:
diff changeset
228 break
45a9e1fac18e initial commit
zaitsev.serge
parents:
diff changeset
229 }
45a9e1fac18e initial commit
zaitsev.serge
parents:
diff changeset
230 time.Sleep(1 * time.Second)
45a9e1fac18e initial commit
zaitsev.serge
parents:
diff changeset
231 }
45a9e1fac18e initial commit
zaitsev.serge
parents:
diff changeset
232 }
45a9e1fac18e initial commit
zaitsev.serge
parents:
diff changeset
233
45a9e1fac18e initial commit
zaitsev.serge
parents:
diff changeset
234 func main() {
45a9e1fac18e initial commit
zaitsev.serge
parents:
diff changeset
235 if len(os.Args) == 1 {
45a9e1fac18e initial commit
zaitsev.serge
parents:
diff changeset
236 fmt.Println(os.Args[0], "<command> [args]")
45a9e1fac18e initial commit
zaitsev.serge
parents:
diff changeset
237 return
45a9e1fac18e initial commit
zaitsev.serge
parents:
diff changeset
238 }
45a9e1fac18e initial commit
zaitsev.serge
parents:
diff changeset
239 cmd := os.Args[1]
45a9e1fac18e initial commit
zaitsev.serge
parents:
diff changeset
240 args := os.Args[2:]
45a9e1fac18e initial commit
zaitsev.serge
parents:
diff changeset
241 switch cmd {
45a9e1fac18e initial commit
zaitsev.serge
parents:
diff changeset
242 case "build":
45a9e1fac18e initial commit
zaitsev.serge
parents:
diff changeset
243 buildAll(true)
45a9e1fac18e initial commit
zaitsev.serge
parents:
diff changeset
244 case "watch":
45a9e1fac18e initial commit
zaitsev.serge
parents:
diff changeset
245 buildAll(false) // pass duration
45a9e1fac18e initial commit
zaitsev.serge
parents:
diff changeset
246 case "var":
45a9e1fac18e initial commit
zaitsev.serge
parents:
diff changeset
247 if len(args) == 0 {
3
53dea9841cd9 moved eval func type to the top, added some error logs
zaitsev.serge
parents: 2
diff changeset
248 log.Println("ERROR: filename expected")
0
45a9e1fac18e initial commit
zaitsev.serge
parents:
diff changeset
249 return
45a9e1fac18e initial commit
zaitsev.serge
parents:
diff changeset
250 }
45a9e1fac18e initial commit
zaitsev.serge
parents:
diff changeset
251 if b, err := ioutil.ReadFile(args[0]); err == nil {
45a9e1fac18e initial commit
zaitsev.serge
parents:
diff changeset
252 vars, _ := md(string(b))
45a9e1fac18e initial commit
zaitsev.serge
parents:
diff changeset
253 defaultVars(vars, args[0])
45a9e1fac18e initial commit
zaitsev.serge
parents:
diff changeset
254 if len(args) > 1 {
45a9e1fac18e initial commit
zaitsev.serge
parents:
diff changeset
255 for _, a := range args[1:] {
45a9e1fac18e initial commit
zaitsev.serge
parents:
diff changeset
256 fmt.Println(vars[a])
45a9e1fac18e initial commit
zaitsev.serge
parents:
diff changeset
257 }
45a9e1fac18e initial commit
zaitsev.serge
parents:
diff changeset
258 } else {
45a9e1fac18e initial commit
zaitsev.serge
parents:
diff changeset
259 for k, v := range vars {
45a9e1fac18e initial commit
zaitsev.serge
parents:
diff changeset
260 fmt.Println(k + ":" + v)
45a9e1fac18e initial commit
zaitsev.serge
parents:
diff changeset
261 }
45a9e1fac18e initial commit
zaitsev.serge
parents:
diff changeset
262 }
45a9e1fac18e initial commit
zaitsev.serge
parents:
diff changeset
263 } else {
3
53dea9841cd9 moved eval func type to the top, added some error logs
zaitsev.serge
parents: 2
diff changeset
264 log.Println(err)
0
45a9e1fac18e initial commit
zaitsev.serge
parents:
diff changeset
265 }
45a9e1fac18e initial commit
zaitsev.serge
parents:
diff changeset
266 default:
4
05fc24caac37 render uses strings, not bytes; added helpers for env and run
zaitsev.serge
parents: 3
diff changeset
267 err := run(path.Join(ZSDIR, cmd), args, map[string]string{}, os.Stdout)
05fc24caac37 render uses strings, not bytes; added helpers for env and run
zaitsev.serge
parents: 3
diff changeset
268 if err != nil {
0
45a9e1fac18e initial commit
zaitsev.serge
parents:
diff changeset
269 log.Println(err)
45a9e1fac18e initial commit
zaitsev.serge
parents:
diff changeset
270 }
45a9e1fac18e initial commit
zaitsev.serge
parents:
diff changeset
271 }
45a9e1fac18e initial commit
zaitsev.serge
parents:
diff changeset
272 }