git-lfs/commands/command_logs.go

110 lines
2.0 KiB
Go
Raw Normal View History

package commands
2013-12-05 22:36:57 +00:00
import (
"errors"
"io/ioutil"
2013-12-05 22:36:57 +00:00
"os"
"path/filepath"
2015-05-13 19:43:41 +00:00
"github.com/github/git-lfs/config"
"github.com/github/git-lfs/errutil"
"github.com/spf13/cobra"
2013-12-05 22:36:57 +00:00
)
2014-06-26 20:44:30 +00:00
var (
logsCmd = &cobra.Command{
2015-09-17 22:08:28 +00:00
Use: "logs",
Run: logsCommand,
2014-06-26 20:44:30 +00:00
}
2013-12-05 22:36:57 +00:00
2014-06-26 21:40:44 +00:00
logsLastCmd = &cobra.Command{
2015-09-17 22:08:28 +00:00
Use: "last",
Run: logsLastCommand,
2013-12-05 22:36:57 +00:00
}
2014-06-26 21:40:44 +00:00
logsShowCmd = &cobra.Command{
2015-09-17 22:08:28 +00:00
Use: "show",
Run: logsShowCommand,
2013-12-05 22:36:57 +00:00
}
2014-06-26 21:40:44 +00:00
logsClearCmd = &cobra.Command{
2015-09-17 22:08:28 +00:00
Use: "clear",
Run: logsClearCommand,
}
2014-06-26 21:40:44 +00:00
logsBoomtownCmd = &cobra.Command{
2015-09-17 22:08:28 +00:00
Use: "boomtown",
Run: logsBoomtownCommand,
}
2014-06-26 21:40:44 +00:00
)
2014-06-26 21:40:44 +00:00
func logsCommand(cmd *cobra.Command, args []string) {
for _, path := range sortedLogs() {
Print(path)
}
}
2014-06-26 21:40:44 +00:00
func logsLastCommand(cmd *cobra.Command, args []string) {
logs := sortedLogs()
if len(logs) < 1 {
2014-06-05 21:35:15 +00:00
Print("No logs to show")
return
}
2014-06-26 21:40:44 +00:00
logsShowCommand(cmd, logs[len(logs)-1:])
}
2014-06-26 21:40:44 +00:00
func logsShowCommand(cmd *cobra.Command, args []string) {
if len(args) == 0 {
Print("Supply a log name.")
return
}
name := args[0]
by, err := ioutil.ReadFile(filepath.Join(config.LocalLogDir, name))
if err != nil {
Exit("Error reading log: %s", name)
}
Debug("Reading log: %s", name)
os.Stdout.Write(by)
2013-12-05 22:36:57 +00:00
}
2014-06-26 21:40:44 +00:00
func logsClearCommand(cmd *cobra.Command, args []string) {
err := os.RemoveAll(config.LocalLogDir)
2013-12-05 22:36:57 +00:00
if err != nil {
Panic(err, "Error clearing %s", config.LocalLogDir)
2013-12-05 22:36:57 +00:00
}
Print("Cleared %s", config.LocalLogDir)
2013-12-05 22:36:57 +00:00
}
2014-06-26 21:40:44 +00:00
func logsBoomtownCommand(cmd *cobra.Command, args []string) {
Debug("Debug message")
err := errutil.Errorf(errors.New("Inner error message!"), "Error!")
2014-06-05 18:48:23 +00:00
Panic(err, "Welcome to Boomtown")
Debug("Never seen")
2013-12-05 22:36:57 +00:00
}
func sortedLogs() []string {
fileinfos, err := ioutil.ReadDir(config.LocalLogDir)
if err != nil {
return []string{}
}
2015-06-19 20:46:27 +00:00
names := make([]string, 0, len(fileinfos))
for _, info := range fileinfos {
2015-06-05 16:39:55 +00:00
if info.IsDir() {
continue
}
2015-06-19 20:46:27 +00:00
names = append(names, info.Name())
}
2015-06-19 20:46:27 +00:00
return names
}
2013-12-05 22:36:57 +00:00
func init() {
2014-06-26 21:40:44 +00:00
logsCmd.AddCommand(logsLastCmd, logsShowCmd, logsClearCmd, logsBoomtownCmd)
2014-06-26 20:44:30 +00:00
RootCmd.AddCommand(logsCmd)
2013-12-05 22:36:57 +00:00
}