1
0
mirror of https://github.com/beego/bee.git synced 2025-10-25 06:52:18 +00:00

Merge branch 'develop' into fix-load-config

This commit is contained in:
Faissal Elamraoui
2017-03-16 21:35:44 +00:00
committed by GitHub
4 changed files with 65 additions and 5 deletions

View File

@@ -27,6 +27,7 @@ import (
_ "github.com/beego/bee/cmd/commands/new"
_ "github.com/beego/bee/cmd/commands/pack"
_ "github.com/beego/bee/cmd/commands/run"
_ "github.com/beego/bee/cmd/commands/scripts"
_ "github.com/beego/bee/cmd/commands/version"
"github.com/beego/bee/utils"
)

View File

@@ -0,0 +1,44 @@
package scripts
import (
"os/exec"
"os"
"runtime"
"strings"
"github.com/beego/bee/cmd/commands"
"github.com/beego/bee/cmd/commands/version"
"github.com/beego/bee/config"
"github.com/beego/bee/logger"
)
func init() {
for commandName, command := range config.Conf.Scripts {
CmdNew := &commands.Command{
UsageLine: commandName,
Short: command,
PreRun: func(cmd *commands.Command, args []string) { version.ShowShortVersionBanner() },
Run: RunScript,
}
commands.AvailableCommands = append(commands.AvailableCommands, CmdNew)
}
}
func RunScript(cmd *commands.Command, args []string) int {
var c *exec.Cmd
switch runtime.GOOS {
case "darwin", "linux":
c = exec.Command("sh", "-c", cmd.Short+" "+strings.Join(args, " "))
case "windows": //TODO
}
c.Stdout = os.Stdout
c.Stderr = os.Stderr
err := c.Run()
if err != nil {
beeLogger.Log.Error(err.Error())
}
return 0
}

View File

@@ -37,6 +37,7 @@ var Conf = struct {
Database database
EnableReload bool `json:"enable_reload" yaml:"enable_reload"`
EnableNotification bool `json:"enable_notification" yaml:"enable_notification"`
Scripts map[string]string `json:"scripts" yaml:"scripts"`
}{
GoInstall: true,
DirStruct: dirStruct{
@@ -52,6 +53,7 @@ var Conf = struct {
Driver: "mysql",
},
EnableNotification: true,
Scripts: map[string]string{},
}
// gopm support

View File

@@ -1,3 +1,16 @@
// Copyright 2017 bee authors
//
// Licensed under the Apache License, Version 2.0 (the "License"): you may
// not use this file except in compliance with the License. You may obtain
// a copy of the License at
//
// http://www.apache.org/licenses/LICENSE-2.0
//
// Unless required by applicable law or agreed to in writing, software
// distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
// WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
// License for the specific language governing permissions and limitations
// under the License.
package utils
import (
@@ -21,9 +34,9 @@ func Notify(text, title string) {
case "darwin":
osxNotify(text, title)
case "linux":
windowsNotify(text, title)
case "windows":
linuxNotify(text, title)
case "windows":
windowsNotify(text, title)
}
}
@@ -45,7 +58,7 @@ func windowsNotify(text, title string) {
}
func linuxNotify(text, title string) {
exec.Command("notify-send", "-i", "", title, text)
exec.Command("notify-send", "-i", "", title, text).Run()
}
func existTerminalNotifier() bool {