Compare commits

..

No commits in common. "main" and "v0.1" have entirely different histories.
main ... v0.1

8 changed files with 24 additions and 154 deletions

View File

@ -14,8 +14,5 @@ LDFLAGS=-ldflags "-w -s -X cmd.Version=${VERSION} -X cmd.Build=${BUILD}"
breaktime: breaktime:
go build ${LDFLAGS} -o build/${BINARY} go build ${LDFLAGS} -o build/${BINARY}
install:
mv build/${BINARY} ${GOPATH}/bin
clean: clean:
rm build/* rm build/*

View File

@ -5,10 +5,7 @@ Copyright © 2023 Brian Buller <brian@bullercodeworks.com>
package cmd package cmd
import ( import (
"time"
"github.com/spf13/cobra" "github.com/spf13/cobra"
"github.com/spf13/viper"
) )
// breakCmd represents the break command // breakCmd represents the break command
@ -16,9 +13,10 @@ var breakCmd = &cobra.Command{
Use: "break", Use: "break",
Short: "Start a break", Short: "Start a break",
Run: func(cmd *cobra.Command, args []string) { Run: func(cmd *cobra.Command, args []string) {
viper.Set("lastbreak", time.Now())
viper.WriteConfig()
}, },
} }
func init() { rootCmd.AddCommand(breakCmd) } func init() {
rootCmd.AddCommand(breakCmd)
}

View File

@ -9,7 +9,6 @@ import (
"os" "os"
"os/exec" "os/exec"
"sort" "sort"
"strconv"
"strings" "strings"
"github.com/spf13/cobra" "github.com/spf13/cobra"
@ -23,7 +22,9 @@ var configCmd = &cobra.Command{
RunE: opConfig, RunE: opConfig,
} }
func init() { rootCmd.AddCommand(configCmd) } func init() {
rootCmd.AddCommand(configCmd)
}
func opConfig(cmd *cobra.Command, args []string) error { func opConfig(cmd *cobra.Command, args []string) error {
updConfig := make(map[string]string) updConfig := make(map[string]string)
@ -60,17 +61,6 @@ func opConfig(cmd *cobra.Command, args []string) error {
viper.WriteConfig() viper.WriteConfig()
} }
settings = append(settings, fmt.Sprintf("%s: %t", k, v)) settings = append(settings, fmt.Sprintf("%s: %t", k, v))
case float64:
if nv, ok := updConfig[k]; ok {
var err error
v, err = strconv.ParseFloat(nv, 64)
if err != nil {
return fmt.Errorf("Unable to parse float value")
}
viper.Set(k, v)
viper.WriteConfig()
}
settings = append(settings, fmt.Sprintf("%s: %f", k, v))
default: default:
if nv, ok := updConfig[k]; ok { if nv, ok := updConfig[k]; ok {
v = nv v = nv

View File

@ -1,5 +1,6 @@
/* /*
Copyright © 2023 Brian Buller <brian@bullercodeworks.com> Copyright © 2023 Brian Buller <brian@bullercodeworks.com>
*/ */
package cmd package cmd
@ -16,45 +17,17 @@ var i3Cmd = &cobra.Command{
Use: "i3", Use: "i3",
Short: "Print state to stdout in i3 bar format", Short: "Print state to stdout in i3 bar format",
Run: func(cmd *cobra.Command, args []string) { Run: func(cmd *cobra.Command, args []string) {
if len(args) == 1 {
switch args[0] {
case "toggle":
toggleCmd.Run(cmd, []string{"-s"})
case "click":
if viper.GetBool("active") {
breakCmd.Run(cmd, []string{"-s"})
} else {
startCmd.Run(cmd, []string{"-s"})
}
case "status":
if viper.GetBool("active") {
fmt.Print("{\"text\":\"\uf04c\",\"state\":\"Good\"}")
} else {
fmt.Print("{\"text\":\"\uf04b\"}")
}
return
}
}
if viper.GetBool("active") {
lastBreak := viper.GetTime("lastbreak") lastBreak := viper.GetTime("lastbreak")
pomo := viper.GetDuration("pomodoro") pomo := viper.GetDuration("pomodoro")
warnPct := viper.GetFloat64("warnpct") //0.75 warnPct := viper.GetFloat64("warnpct") //0.75
warn := int(pomo.Seconds() * warnPct) warn := pomo * time.Duration(warnPct)
elapsed := int(time.Since(lastBreak).Seconds()) elapsed := time.Since(lastBreak)
rem := time.Until(lastBreak.Add(pomo)).Round(time.Duration(time.Second)) if elapsed > pomo {
if elapsed > int(pomo.Seconds()) { fmt.Print("{\"icon\":\"tomato\",\"state\":\"Critical\", \"text\": \"BREAK!\"}")
state := "Critical"
if elapsed%2 == 1 {
state = "Warning"
}
fmt.Printf("{\"icon\":\"time\",\"state\":\"%s\", \"text\": \"BREAK!\"}", state)
} else if elapsed > warn { } else if elapsed > warn {
fmt.Printf("{\"icon\":\"time\",\"state\":\"Warning\", \"text\": \"%s\"}", rem) fmt.Printf("{\"icon\":\"tomato\",\"state\":\"Warning\", \"text\": \"%s\"}", elapsed)
} else { } else {
fmt.Printf("{\"icon\":\"time\",\"state\":\"Good\", \"text\": \"%s\"}", rem) fmt.Printf("{\"icon\":\"tomato\",\"state\":\"Good\", \"text\": \"%s\"}", elapsed)
}
} else {
fmt.Print("{\"icon\":\"time\", \"text\": \"Stopped\"}")
} }
}, },
} }

View File

@ -33,16 +33,15 @@ func Execute() {
} }
func init() { func init() {
viper.SetDefault("active", false)
viper.SetDefault("lastbreak", time.Now()) viper.SetDefault("lastbreak", time.Now())
p, _ := time.ParseDuration("25m") p, _ := time.ParseDuration("25m")
viper.SetDefault("pomodoro", p) viper.SetDefault("pomodoro", p)
p, _ = time.ParseDuration("5m")
viper.SetDefault("breaklength", p)
viper.SetDefault("warnpct", 0.75) viper.SetDefault("warnpct", 0.75)
cobra.OnInitialize(initConfig) cobra.OnInitialize(initConfig)
rootCmd.PersistentFlags().StringVar(&cfgFile, "config", "", "config file (default is $HOME/.breaktime.yaml)") rootCmd.PersistentFlags().StringVar(&cfgFile, "config", "", "config file (default is $HOME/.breaktime.yaml)")
rootCmd.Flags().BoolP("toggle", "t", false, "Help message for toggle")
} }
// initConfig reads in config file and ENV variables if set. // initConfig reads in config file and ENV variables if set.
@ -96,19 +95,11 @@ func initConfig() {
viper.AutomaticEnv() // read in environment variables that match viper.AutomaticEnv() // read in environment variables that match
// If a config file is found, read it in. // If a config file is found, read it in.
if err := viper.ReadInConfig(); err != nil { if err := viper.ReadInConfig(); err == nil {
fmt.Println("Error reading config") fmt.Fprintln(os.Stderr, "Using config file:", viper.ConfigFileUsed())
os.Exit(1)
} }
} }
func runRootCmd(cmd *cobra.Command, args []string) error { return nil } func runRootCmd(cmd *cobra.Command, args []string) error {
return nil
func hasArg(arg string, args []string) bool {
for i := range args {
if args[i] == arg {
return true
}
}
return false
} }

View File

@ -1,27 +0,0 @@
/*
Copyright © 2023 Brian Buller <brian@bullercodeworks.com>
*/
package cmd
import (
"fmt"
"github.com/spf13/cobra"
"github.com/spf13/viper"
)
// startCmd represents the start command
var startCmd = &cobra.Command{
Use: "start",
Short: "Start the timer",
Run: func(cmd *cobra.Command, args []string) {
viper.Set("active", true)
viper.WriteConfig()
if !hasArg("-s", args) {
fmt.Println("Timer Started.")
}
},
}
func init() { rootCmd.AddCommand(startCmd) }

View File

@ -1,27 +0,0 @@
/*
Copyright © 2023 Brian Buller <brian@bullercodeworks.com>
*/
package cmd
import (
"fmt"
"github.com/spf13/cobra"
"github.com/spf13/viper"
)
// stopCmd represents the stop command
var stopCmd = &cobra.Command{
Use: "stop",
Short: "Stop the timer",
Run: func(cmd *cobra.Command, args []string) {
viper.Set("active", false)
viper.WriteConfig()
if !hasArg("-s", args) {
fmt.Println("Timer Stopped.")
}
},
}
func init() { rootCmd.AddCommand(stopCmd) }

View File

@ -1,25 +0,0 @@
/*
Copyright © 2023 Brian Buller <brian@bullercodeworks.com>
*/
package cmd
import (
"github.com/spf13/cobra"
"github.com/spf13/viper"
)
// toggleCmd represents the toggle command
var toggleCmd = &cobra.Command{
Use: "toggle",
Short: "Toggle timer off/on",
Run: func(cmd *cobra.Command, args []string) {
if viper.GetBool("active") {
stopCmd.Run(cmd, args)
} else {
startCmd.Run(cmd, args)
}
},
}
func init() { rootCmd.AddCommand(toggleCmd) }