mirror of
https://github.com/beego/bee.git
synced 2024-11-21 23:50:54 +00:00
Merge pull request #17 from Unknwon/master
Update tpl file and code for create new Beego application
This commit is contained in:
commit
47c65fb1ef
@ -1,3 +1,4 @@
|
|||||||
|
// Bee is a tool for developling applications based on beego framework.
|
||||||
package main
|
package main
|
||||||
|
|
||||||
import (
|
import (
|
||||||
@ -56,8 +57,8 @@ func (c *Command) Runnable() bool {
|
|||||||
}
|
}
|
||||||
|
|
||||||
var commands = []*Command{
|
var commands = []*Command{
|
||||||
cmdCreate,
|
cmdNew,
|
||||||
cmdStart,
|
cmdRun,
|
||||||
cmdPack,
|
cmdPack,
|
||||||
cmdApiapp,
|
cmdApiapp,
|
||||||
//cmdReStart,
|
//cmdReStart,
|
9
bee.json
Normal file
9
bee.json
Normal file
@ -0,0 +1,9 @@
|
|||||||
|
{
|
||||||
|
"dir_structure":{
|
||||||
|
"controllers": "",
|
||||||
|
"models": ""
|
||||||
|
},
|
||||||
|
"files": [
|
||||||
|
"main.go"
|
||||||
|
]
|
||||||
|
}
|
165
createapp.go
165
createapp.go
@ -1,165 +0,0 @@
|
|||||||
package main
|
|
||||||
|
|
||||||
import (
|
|
||||||
"fmt"
|
|
||||||
"os"
|
|
||||||
path "path/filepath"
|
|
||||||
"strings"
|
|
||||||
)
|
|
||||||
|
|
||||||
var cmdCreate = &Command{
|
|
||||||
UsageLine: "create [appname]",
|
|
||||||
Short: "create an application base on beego framework",
|
|
||||||
Long: `
|
|
||||||
create an application base on beego framework
|
|
||||||
|
|
||||||
In the current path, will create a folder named [appname]
|
|
||||||
|
|
||||||
In the appname folder has the follow struct:
|
|
||||||
|
|
||||||
|- main.go
|
|
||||||
|- conf
|
|
||||||
|- app.conf
|
|
||||||
|- controllers
|
|
||||||
|- default.go
|
|
||||||
|- models
|
|
||||||
|- static
|
|
||||||
|- js
|
|
||||||
|- css
|
|
||||||
|- img
|
|
||||||
|- views
|
|
||||||
index.tpl
|
|
||||||
|
|
||||||
`,
|
|
||||||
}
|
|
||||||
|
|
||||||
func init() {
|
|
||||||
cmdCreate.Run = createapp
|
|
||||||
}
|
|
||||||
|
|
||||||
func createapp(cmd *Command, args []string) {
|
|
||||||
curpath, _ := os.Getwd()
|
|
||||||
if len(args) != 1 {
|
|
||||||
fmt.Println("error args")
|
|
||||||
os.Exit(2)
|
|
||||||
}
|
|
||||||
|
|
||||||
gopath := os.Getenv("GOPATH")
|
|
||||||
Debugf("gopath:%s", gopath)
|
|
||||||
if gopath == "" {
|
|
||||||
fmt.Println("you should set GOPATH in the env")
|
|
||||||
os.Exit(2)
|
|
||||||
}
|
|
||||||
haspath := false
|
|
||||||
appsrcpath := ""
|
|
||||||
|
|
||||||
wgopath := path.SplitList(gopath)
|
|
||||||
for _, wg := range wgopath {
|
|
||||||
wg = path.Join(wg, "src")
|
|
||||||
|
|
||||||
if path.HasPrefix(strings.ToLower(curpath), strings.ToLower(wg)) {
|
|
||||||
haspath = true
|
|
||||||
appsrcpath = wg
|
|
||||||
break
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
if !haspath {
|
|
||||||
fmt.Printf("can't create application outside of GOPATH `%s`\n", gopath)
|
|
||||||
fmt.Printf("you first should `cd $GOPATH%ssrc` then use create\n", string(path.Separator))
|
|
||||||
os.Exit(2)
|
|
||||||
}
|
|
||||||
|
|
||||||
apppath := path.Join(curpath, args[0])
|
|
||||||
|
|
||||||
if _, err := os.Stat(apppath); os.IsNotExist(err) == false {
|
|
||||||
fmt.Printf("path `%s` exists, can not create app without remove it\n", apppath)
|
|
||||||
os.Exit(2)
|
|
||||||
}
|
|
||||||
|
|
||||||
os.MkdirAll(apppath, 0755)
|
|
||||||
fmt.Println("create app folder:", apppath)
|
|
||||||
os.Mkdir(path.Join(apppath, "conf"), 0755)
|
|
||||||
fmt.Println("create conf:", path.Join(apppath, "conf"))
|
|
||||||
os.Mkdir(path.Join(apppath, "controllers"), 0755)
|
|
||||||
fmt.Println("create controllers:", path.Join(apppath, "controllers"))
|
|
||||||
os.Mkdir(path.Join(apppath, "models"), 0755)
|
|
||||||
fmt.Println("create models:", path.Join(apppath, "models"))
|
|
||||||
os.Mkdir(path.Join(apppath, "static"), 0755)
|
|
||||||
fmt.Println("create static:", path.Join(apppath, "static"))
|
|
||||||
os.Mkdir(path.Join(apppath, "static", "js"), 0755)
|
|
||||||
fmt.Println("create static js:", path.Join(apppath, "static", "js"))
|
|
||||||
os.Mkdir(path.Join(apppath, "static", "css"), 0755)
|
|
||||||
fmt.Println("create static css:", path.Join(apppath, "static", "css"))
|
|
||||||
os.Mkdir(path.Join(apppath, "static", "img"), 0755)
|
|
||||||
fmt.Println("create static img:", path.Join(apppath, "static", "img"))
|
|
||||||
fmt.Println("create views:", path.Join(apppath, "views"))
|
|
||||||
os.Mkdir(path.Join(apppath, "views"), 0755)
|
|
||||||
fmt.Println("create conf app.conf:", path.Join(apppath, "conf", "app.conf"))
|
|
||||||
writetofile(path.Join(apppath, "conf", "app.conf"), strings.Replace(appconf, "{{.Appname}}", args[0], -1))
|
|
||||||
|
|
||||||
fmt.Println("create controllers default.go:", path.Join(apppath, "controllers", "default.go"))
|
|
||||||
writetofile(path.Join(apppath, "controllers", "default.go"), controllers)
|
|
||||||
|
|
||||||
fmt.Println("create views index.tpl:", path.Join(apppath, "views", "index.tpl"))
|
|
||||||
writetofile(path.Join(apppath, "views", "index.tpl"), indextpl)
|
|
||||||
|
|
||||||
fmt.Println("create main.go:", path.Join(apppath, "main.go"))
|
|
||||||
writetofile(path.Join(apppath, "main.go"), strings.Replace(maingo, "{{.Appname}}", strings.Join(strings.Split(apppath[len(appsrcpath)+1:], string(path.Separator)), "/"), -1))
|
|
||||||
}
|
|
||||||
|
|
||||||
var appconf = `
|
|
||||||
appname = {{.Appname}}
|
|
||||||
httpport = 8080
|
|
||||||
runmode = dev
|
|
||||||
`
|
|
||||||
|
|
||||||
var maingo = `package main
|
|
||||||
|
|
||||||
import (
|
|
||||||
"{{.Appname}}/controllers"
|
|
||||||
"github.com/astaxie/beego"
|
|
||||||
)
|
|
||||||
|
|
||||||
func main() {
|
|
||||||
beego.Router("/", &controllers.MainController{})
|
|
||||||
beego.Run()
|
|
||||||
}
|
|
||||||
|
|
||||||
`
|
|
||||||
var controllers = `package controllers
|
|
||||||
|
|
||||||
import (
|
|
||||||
"github.com/astaxie/beego"
|
|
||||||
)
|
|
||||||
|
|
||||||
type MainController struct {
|
|
||||||
beego.Controller
|
|
||||||
}
|
|
||||||
|
|
||||||
func (this *MainController) Get() {
|
|
||||||
this.Data["Username"] = "astaxie"
|
|
||||||
this.Data["Email"] = "astaxie@gmail.com"
|
|
||||||
this.TplNames = "index.tpl"
|
|
||||||
}
|
|
||||||
`
|
|
||||||
|
|
||||||
var indextpl = `<!DOCTYPE html>
|
|
||||||
<html>
|
|
||||||
<head>
|
|
||||||
<title>beego welcome template</title>
|
|
||||||
</head>
|
|
||||||
<body>
|
|
||||||
<h1>Hello, world!{{.Username}},{{.Email}}</h1>
|
|
||||||
</body>
|
|
||||||
</html>
|
|
||||||
`
|
|
||||||
|
|
||||||
func writetofile(filename, content string) {
|
|
||||||
f, err := os.Create(filename)
|
|
||||||
if err != nil {
|
|
||||||
panic(err)
|
|
||||||
}
|
|
||||||
defer f.Close()
|
|
||||||
f.WriteString(content)
|
|
||||||
}
|
|
242
new.go
Normal file
242
new.go
Normal file
@ -0,0 +1,242 @@
|
|||||||
|
package main
|
||||||
|
|
||||||
|
import (
|
||||||
|
"fmt"
|
||||||
|
"os"
|
||||||
|
path "path/filepath"
|
||||||
|
"strings"
|
||||||
|
)
|
||||||
|
|
||||||
|
var cmdNew = &Command{
|
||||||
|
UsageLine: "new [appname]",
|
||||||
|
Short: "create an application base on beego framework",
|
||||||
|
Long: `
|
||||||
|
create an application base on beego framework,
|
||||||
|
|
||||||
|
which in the current path with folder named [appname].
|
||||||
|
|
||||||
|
The [appname] folder has following structure:
|
||||||
|
|
||||||
|
|- main.go
|
||||||
|
|- conf
|
||||||
|
|- app.conf
|
||||||
|
|- controllers
|
||||||
|
|- default.go
|
||||||
|
|- models
|
||||||
|
|- static
|
||||||
|
|- js
|
||||||
|
|- css
|
||||||
|
|- img
|
||||||
|
|- views
|
||||||
|
index.tpl
|
||||||
|
|
||||||
|
`,
|
||||||
|
}
|
||||||
|
|
||||||
|
func init() {
|
||||||
|
cmdNew.Run = createApp
|
||||||
|
}
|
||||||
|
|
||||||
|
func createApp(cmd *Command, args []string) {
|
||||||
|
curpath, _ := os.Getwd()
|
||||||
|
if len(args) != 1 {
|
||||||
|
fmt.Println("[ERRO] Argument [appname] is missing")
|
||||||
|
os.Exit(2)
|
||||||
|
}
|
||||||
|
|
||||||
|
gopath := os.Getenv("GOPATH")
|
||||||
|
Debugf("gopath:%s", gopath)
|
||||||
|
if gopath == "" {
|
||||||
|
fmt.Printf("[ERRO] $GOPATH not found\n")
|
||||||
|
fmt.Printf("[HINT] Set $GOPATH in your environment vairables\n")
|
||||||
|
os.Exit(2)
|
||||||
|
}
|
||||||
|
haspath := false
|
||||||
|
appsrcpath := ""
|
||||||
|
|
||||||
|
wgopath := path.SplitList(gopath)
|
||||||
|
for _, wg := range wgopath {
|
||||||
|
wg = path.Join(wg, "src")
|
||||||
|
|
||||||
|
if path.HasPrefix(strings.ToLower(curpath), strings.ToLower(wg)) {
|
||||||
|
haspath = true
|
||||||
|
appsrcpath = wg
|
||||||
|
break
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if !haspath {
|
||||||
|
fmt.Printf("[ERRO] Unable to create an application outside of $GOPATH(%s)\n", gopath)
|
||||||
|
fmt.Printf("[HINT] Change your work directory by `cd $GOPATH%ssrc`\n", string(path.Separator))
|
||||||
|
os.Exit(2)
|
||||||
|
}
|
||||||
|
|
||||||
|
apppath := path.Join(curpath, args[0])
|
||||||
|
|
||||||
|
if _, err := os.Stat(apppath); os.IsNotExist(err) == false {
|
||||||
|
fmt.Printf("[ERRO] Path(%s) has alreay existed\n", apppath)
|
||||||
|
os.Exit(2)
|
||||||
|
}
|
||||||
|
|
||||||
|
fmt.Println("[INFO] Creating application...")
|
||||||
|
|
||||||
|
os.MkdirAll(apppath, 0755)
|
||||||
|
fmt.Println(apppath + string(path.Separator))
|
||||||
|
os.Mkdir(path.Join(apppath, "conf"), 0755)
|
||||||
|
fmt.Println(path.Join(apppath, "conf") + string(path.Separator))
|
||||||
|
os.Mkdir(path.Join(apppath, "controllers"), 0755)
|
||||||
|
fmt.Println(path.Join(apppath, "controllers") + string(path.Separator))
|
||||||
|
os.Mkdir(path.Join(apppath, "models"), 0755)
|
||||||
|
fmt.Println(path.Join(apppath, "models") + string(path.Separator))
|
||||||
|
os.Mkdir(path.Join(apppath, "static"), 0755)
|
||||||
|
fmt.Println(path.Join(apppath, "static") + string(path.Separator))
|
||||||
|
os.Mkdir(path.Join(apppath, "static", "js"), 0755)
|
||||||
|
fmt.Println(path.Join(apppath, "static", "js") + string(path.Separator))
|
||||||
|
os.Mkdir(path.Join(apppath, "static", "css"), 0755)
|
||||||
|
fmt.Println(path.Join(apppath, "static", "css") + string(path.Separator))
|
||||||
|
os.Mkdir(path.Join(apppath, "static", "img"), 0755)
|
||||||
|
fmt.Println(path.Join(apppath, "static", "img") + string(path.Separator))
|
||||||
|
fmt.Println(path.Join(apppath, "views") + string(path.Separator))
|
||||||
|
os.Mkdir(path.Join(apppath, "views"), 0755)
|
||||||
|
fmt.Println(path.Join(apppath, "conf", "app.conf"))
|
||||||
|
writetofile(path.Join(apppath, "conf", "app.conf"), strings.Replace(appconf, "{{.Appname}}", args[0], -1))
|
||||||
|
|
||||||
|
fmt.Println(path.Join(apppath, "controllers", "default.go"))
|
||||||
|
writetofile(path.Join(apppath, "controllers", "default.go"), controllers)
|
||||||
|
|
||||||
|
fmt.Println(path.Join(apppath, "views", "index.tpl"))
|
||||||
|
writetofile(path.Join(apppath, "views", "index.tpl"), indextpl)
|
||||||
|
|
||||||
|
fmt.Println(path.Join(apppath, "main.go"))
|
||||||
|
writetofile(path.Join(apppath, "main.go"), strings.Replace(maingo, "{{.Appname}}", strings.Join(strings.Split(apppath[len(appsrcpath)+1:], string(path.Separator)), string(path.Separator)), -1))
|
||||||
|
|
||||||
|
fmt.Println("[SUCC] New application successfully created!")
|
||||||
|
}
|
||||||
|
|
||||||
|
var appconf = `appname = {{.Appname}}
|
||||||
|
httpport = 8080
|
||||||
|
runmode = dev
|
||||||
|
`
|
||||||
|
|
||||||
|
var maingo = `package main
|
||||||
|
|
||||||
|
import (
|
||||||
|
"{{.Appname}}/controllers"
|
||||||
|
"github.com/astaxie/beego"
|
||||||
|
)
|
||||||
|
|
||||||
|
func main() {
|
||||||
|
beego.Router("/", &controllers.MainController{})
|
||||||
|
beego.Run()
|
||||||
|
}
|
||||||
|
|
||||||
|
`
|
||||||
|
var controllers = `package controllers
|
||||||
|
|
||||||
|
import (
|
||||||
|
"github.com/astaxie/beego"
|
||||||
|
)
|
||||||
|
|
||||||
|
type MainController struct {
|
||||||
|
beego.Controller
|
||||||
|
}
|
||||||
|
|
||||||
|
func (this *MainController) Get() {
|
||||||
|
this.Data["Website"] = "beego.me"
|
||||||
|
this.Data["Email"] = "astaxie@gmail.com"
|
||||||
|
this.TplNames = "index.tpl"
|
||||||
|
}
|
||||||
|
`
|
||||||
|
|
||||||
|
var indextpl = `<!DOCTYPE html>
|
||||||
|
|
||||||
|
<html>
|
||||||
|
<head>
|
||||||
|
<title>Beego</title>
|
||||||
|
<meta http-equiv="Content-Type" content="text/html; charset=utf-8">
|
||||||
|
</head>
|
||||||
|
|
||||||
|
<style type="text/css">
|
||||||
|
body {
|
||||||
|
margin: 0px;
|
||||||
|
font-family: "Helvetica Neue",Helvetica,Arial,sans-serif;
|
||||||
|
font-size: 14px;
|
||||||
|
line-height: 20px;
|
||||||
|
color: rgb(51, 51, 51);
|
||||||
|
background-color: rgb(255, 255, 255);
|
||||||
|
}
|
||||||
|
|
||||||
|
.hero-unit {
|
||||||
|
padding: 60px;
|
||||||
|
margin-bottom: 30px;
|
||||||
|
border-radius: 6px 6px 6px 6px;
|
||||||
|
}
|
||||||
|
|
||||||
|
.container {
|
||||||
|
width: 940px;
|
||||||
|
margin-right: auto;
|
||||||
|
margin-left: auto;
|
||||||
|
}
|
||||||
|
|
||||||
|
.row {
|
||||||
|
margin-left: -20px;
|
||||||
|
}
|
||||||
|
|
||||||
|
h1 {
|
||||||
|
margin: 10px 0px;
|
||||||
|
font-family: inherit;
|
||||||
|
font-weight: bold;
|
||||||
|
text-rendering: optimizelegibility;
|
||||||
|
}
|
||||||
|
|
||||||
|
.hero-unit h1 {
|
||||||
|
margin-bottom: 0px;
|
||||||
|
font-size: 60px;
|
||||||
|
line-height: 1;
|
||||||
|
letter-spacing: -1px;
|
||||||
|
color: inherit;
|
||||||
|
}
|
||||||
|
|
||||||
|
.description {
|
||||||
|
padding-top: 5px;
|
||||||
|
padding-left: 5px;
|
||||||
|
font-size: 18px;
|
||||||
|
font-weight: 200;
|
||||||
|
line-height: 30px;
|
||||||
|
color: inherit;
|
||||||
|
}
|
||||||
|
|
||||||
|
p {
|
||||||
|
margin: 0px 0px 10px;
|
||||||
|
}
|
||||||
|
</style>
|
||||||
|
|
||||||
|
<body>
|
||||||
|
<header class="hero-unit" style="background-color:#A9F16C">
|
||||||
|
<div class="container">
|
||||||
|
<div class="row">
|
||||||
|
<div class="hero-text">
|
||||||
|
<h1>Welcome to Beego!</h1>
|
||||||
|
<p class="description">
|
||||||
|
Beego is a simple & powerful Go web framework which is inspired by tornado and sinatra.
|
||||||
|
<br />
|
||||||
|
Official website: <a href="http://{{.Website}}">{{.Website}}</a>
|
||||||
|
<br />
|
||||||
|
Contact me: {{.Email}}</a>
|
||||||
|
</p>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</header>
|
||||||
|
</body>
|
||||||
|
</html>
|
||||||
|
`
|
||||||
|
|
||||||
|
func writetofile(filename, content string) {
|
||||||
|
f, err := os.Create(filename)
|
||||||
|
if err != nil {
|
||||||
|
panic(err)
|
||||||
|
}
|
||||||
|
defer f.Close()
|
||||||
|
f.WriteString(content)
|
||||||
|
}
|
95
run.go
Normal file
95
run.go
Normal file
@ -0,0 +1,95 @@
|
|||||||
|
package main
|
||||||
|
|
||||||
|
import (
|
||||||
|
"encoding/json"
|
||||||
|
"fmt"
|
||||||
|
"os"
|
||||||
|
path "path/filepath"
|
||||||
|
"runtime"
|
||||||
|
)
|
||||||
|
|
||||||
|
var cmdRun = &Command{
|
||||||
|
UsageLine: "run [appname]",
|
||||||
|
Short: "run the app which can hot compile",
|
||||||
|
Long: `
|
||||||
|
start the appname throw exec.Command
|
||||||
|
|
||||||
|
then start a inotify watch for current dir
|
||||||
|
|
||||||
|
when the file has changed bee will auto go build and restart the app
|
||||||
|
|
||||||
|
file changed
|
||||||
|
|
|
||||||
|
check if it's go file
|
||||||
|
|
|
||||||
|
yes no
|
||||||
|
| |
|
||||||
|
go build do nothing
|
||||||
|
|
|
||||||
|
restart app
|
||||||
|
`,
|
||||||
|
}
|
||||||
|
|
||||||
|
func init() {
|
||||||
|
cmdRun.Run = runApp
|
||||||
|
}
|
||||||
|
|
||||||
|
var appname string
|
||||||
|
var conf struct {
|
||||||
|
DirStruct struct {
|
||||||
|
Controllers string
|
||||||
|
Models string
|
||||||
|
} `json:"dir_structure"`
|
||||||
|
Files []string
|
||||||
|
}
|
||||||
|
|
||||||
|
func runApp(cmd *Command, args []string) {
|
||||||
|
if len(args) != 1 {
|
||||||
|
fmt.Println("[ERRO] Argument [appname] is missing")
|
||||||
|
os.Exit(2)
|
||||||
|
}
|
||||||
|
crupath, _ := os.Getwd()
|
||||||
|
Debugf("current path:%s\n", crupath)
|
||||||
|
|
||||||
|
err := loadConfig()
|
||||||
|
if err != nil {
|
||||||
|
fmt.Println("[ERRO] Fail to parse bee.json:", err)
|
||||||
|
}
|
||||||
|
var paths []string
|
||||||
|
paths = append(paths,
|
||||||
|
path.Join(crupath, conf.DirStruct.Controllers),
|
||||||
|
path.Join(crupath, conf.DirStruct.Models))
|
||||||
|
paths = append(paths, conf.Files...)
|
||||||
|
|
||||||
|
NewWatcher(paths)
|
||||||
|
appname = args[0]
|
||||||
|
Autobuild()
|
||||||
|
for {
|
||||||
|
runtime.Gosched()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// loadConfig loads customized configuration.
|
||||||
|
func loadConfig() error {
|
||||||
|
f, err := os.Open("bee.json")
|
||||||
|
if err != nil {
|
||||||
|
// Use default.
|
||||||
|
return nil
|
||||||
|
}
|
||||||
|
defer f.Close()
|
||||||
|
|
||||||
|
d := json.NewDecoder(f)
|
||||||
|
err = d.Decode(&conf)
|
||||||
|
if err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
|
||||||
|
// Set variables.
|
||||||
|
if len(conf.DirStruct.Controllers) == 0 {
|
||||||
|
conf.DirStruct.Controllers = "controllers"
|
||||||
|
}
|
||||||
|
if len(conf.DirStruct.Models) == 0 {
|
||||||
|
conf.DirStruct.Models = "models"
|
||||||
|
}
|
||||||
|
return nil
|
||||||
|
}
|
54
start.go
54
start.go
@ -1,54 +0,0 @@
|
|||||||
package main
|
|
||||||
|
|
||||||
import (
|
|
||||||
"fmt"
|
|
||||||
"os"
|
|
||||||
path "path/filepath"
|
|
||||||
"runtime"
|
|
||||||
)
|
|
||||||
|
|
||||||
var cmdStart = &Command{
|
|
||||||
UsageLine: "start [appname]",
|
|
||||||
Short: "start the app which can hot compile",
|
|
||||||
Long: `
|
|
||||||
start the appname throw exec.Command
|
|
||||||
|
|
||||||
then start a inotify watch for current dir
|
|
||||||
|
|
||||||
when the file has changed bee will auto go build and restart the app
|
|
||||||
|
|
||||||
file changed
|
|
||||||
|
|
|
||||||
checked is go file
|
|
||||||
|
|
|
||||||
yes no
|
|
||||||
| |
|
|
||||||
go build do nothing
|
|
||||||
|
|
|
||||||
restart app
|
|
||||||
`,
|
|
||||||
}
|
|
||||||
|
|
||||||
func init() {
|
|
||||||
cmdStart.Run = startapp
|
|
||||||
}
|
|
||||||
|
|
||||||
var appname string
|
|
||||||
|
|
||||||
func startapp(cmd *Command, args []string) {
|
|
||||||
if len(args) != 1 {
|
|
||||||
fmt.Println("error args")
|
|
||||||
os.Exit(2)
|
|
||||||
}
|
|
||||||
crupath, _ := os.Getwd()
|
|
||||||
Debugf("current path:%s\n", crupath)
|
|
||||||
|
|
||||||
var paths []string
|
|
||||||
paths = append(paths, path.Join(crupath, "controllers"), path.Join(crupath, "models"))
|
|
||||||
NewWatcher(paths)
|
|
||||||
appname = args[0]
|
|
||||||
Autobuild()
|
|
||||||
for {
|
|
||||||
runtime.Gosched()
|
|
||||||
}
|
|
||||||
}
|
|
13
watch.go
13
watch.go
@ -45,7 +45,7 @@ func NewWatcher(paths []string) {
|
|||||||
eventTime[e.Name] = time.Now()
|
eventTime[e.Name] = time.Now()
|
||||||
|
|
||||||
if isbuild {
|
if isbuild {
|
||||||
fmt.Println(e)
|
fmt.Println("[EVEN]", e)
|
||||||
go Autobuild()
|
go Autobuild()
|
||||||
}
|
}
|
||||||
case err := <-watcher.Error:
|
case err := <-watcher.Error:
|
||||||
@ -53,6 +53,8 @@ func NewWatcher(paths []string) {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
}()
|
}()
|
||||||
|
|
||||||
|
fmt.Println("[INFO] Initializing watcher...")
|
||||||
for _, path := range paths {
|
for _, path := range paths {
|
||||||
fmt.Println(path)
|
fmt.Println(path)
|
||||||
err = watcher.Watch(path)
|
err = watcher.Watch(path)
|
||||||
@ -67,7 +69,7 @@ func Autobuild() {
|
|||||||
state.Lock()
|
state.Lock()
|
||||||
defer state.Unlock()
|
defer state.Unlock()
|
||||||
|
|
||||||
fmt.Println("start autobuild")
|
fmt.Println("[INFO] Start building...")
|
||||||
path, _ := os.Getwd()
|
path, _ := os.Getwd()
|
||||||
os.Chdir(path)
|
os.Chdir(path)
|
||||||
bcmd := exec.Command("go", "build")
|
bcmd := exec.Command("go", "build")
|
||||||
@ -76,10 +78,10 @@ func Autobuild() {
|
|||||||
err := bcmd.Run()
|
err := bcmd.Run()
|
||||||
|
|
||||||
if err != nil {
|
if err != nil {
|
||||||
fmt.Println("============== build failed ===================")
|
fmt.Println("[ERRO] ============== Build failed ===================")
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
fmt.Println("build success")
|
fmt.Println("[SUCC] Build was successful")
|
||||||
Restart(appname)
|
Restart(appname)
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -101,8 +103,7 @@ func Restart(appname string) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
func Start(appname string) {
|
func Start(appname string) {
|
||||||
fmt.Println("start", appname)
|
fmt.Println("[INFO] Restarting", appname)
|
||||||
|
|
||||||
if strings.Index(appname, "./") == -1 {
|
if strings.Index(appname, "./") == -1 {
|
||||||
appname = "./" + appname
|
appname = "./" + appname
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user