forked from Elara6331/itd
		
	Reorganize itctl structure
This commit is contained in:
		| @@ -1,24 +0,0 @@ | ||||
| /* | ||||
|  *	itd uses bluetooth low energy to communicate with InfiniTime devices | ||||
|  *	Copyright (C) 2021 Arsen Musayelyan | ||||
|  * | ||||
|  *	This program is free software: you can redistribute it and/or modify | ||||
|  *	it under the terms of the GNU General Public License as published by | ||||
|  *	the Free Software Foundation, either version 3 of the License, or | ||||
|  *	(at your option) any later version. | ||||
|  * | ||||
|  *	This program is distributed in the hope that it will be useful, | ||||
|  *	but WITHOUT ANY WARRANTY; without even the implied warranty of | ||||
|  *	MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the | ||||
|  *	GNU General Public License for more details. | ||||
|  * | ||||
|  *	You should have received a copy of the GNU General Public License | ||||
|  *	along with this program.  If not, see <http://www.gnu.org/licenses/>. | ||||
|  */ | ||||
|  | ||||
| package cmd | ||||
|  | ||||
| type DFUProgress struct { | ||||
| 	Received int64 `mapstructure:"recvd"` | ||||
| 	Total    int64 `mapstructure:"total"` | ||||
| } | ||||
| @@ -16,10 +16,11 @@ | ||||
|  *	along with this program.  If not, see <http://www.gnu.org/licenses/>. | ||||
|  */ | ||||
| 
 | ||||
| package cmd | ||||
| package firmware | ||||
| 
 | ||||
| import ( | ||||
| 	"github.com/spf13/cobra" | ||||
| 	"go.arsenm.dev/itd/cmd/itctl/root" | ||||
| ) | ||||
| 
 | ||||
| // firmwareCmd represents the firmware command | ||||
| @@ -30,5 +31,5 @@ var firmwareCmd = &cobra.Command{ | ||||
| } | ||||
| 
 | ||||
| func init() { | ||||
| 	rootCmd.AddCommand(firmwareCmd) | ||||
| 	root.RootCmd.AddCommand(firmwareCmd) | ||||
| } | ||||
| @@ -16,7 +16,7 @@ | ||||
|  *	along with this program.  If not, see <http://www.gnu.org/licenses/>. | ||||
|  */ | ||||
| 
 | ||||
| package cmd | ||||
| package firmware | ||||
| 
 | ||||
| import ( | ||||
| 	"bufio" | ||||
| @@ -31,6 +31,12 @@ import ( | ||||
| 	"go.arsenm.dev/itd/internal/types" | ||||
| ) | ||||
| 
 | ||||
| type DFUProgress struct { | ||||
| 	Received int64 `mapstructure:"recvd"` | ||||
| 	Total    int64 `mapstructure:"total"` | ||||
| } | ||||
| 
 | ||||
| 
 | ||||
| // upgradeCmd represents the upgrade command | ||||
| var upgradeCmd = &cobra.Command{ | ||||
| 	Use:     "upgrade", | ||||
| @@ -16,7 +16,7 @@ | ||||
|  *	along with this program.  If not, see <http://www.gnu.org/licenses/>. | ||||
|  */ | ||||
| 
 | ||||
| package cmd | ||||
| package firmware | ||||
| 
 | ||||
| import ( | ||||
| 	"bufio" | ||||
| @@ -16,7 +16,7 @@ | ||||
|  *	along with this program.  If not, see <http://www.gnu.org/licenses/>. | ||||
|  */ | ||||
| 
 | ||||
| package cmd | ||||
| package get | ||||
| 
 | ||||
| import ( | ||||
| 	"bufio" | ||||
| @@ -16,7 +16,7 @@ | ||||
|  *	along with this program.  If not, see <http://www.gnu.org/licenses/>. | ||||
|  */ | ||||
| 
 | ||||
| package cmd | ||||
| package get | ||||
| 
 | ||||
| import ( | ||||
| 	"bufio" | ||||
| @@ -16,10 +16,11 @@ | ||||
|  *	along with this program.  If not, see <http://www.gnu.org/licenses/>. | ||||
|  */ | ||||
| 
 | ||||
| package cmd | ||||
| package get | ||||
| 
 | ||||
| import ( | ||||
| 	"github.com/spf13/cobra" | ||||
| 	"go.arsenm.dev/itd/cmd/itctl/root" | ||||
| ) | ||||
| 
 | ||||
| // getCmd represents the get command | ||||
| @@ -29,5 +30,5 @@ var getCmd = &cobra.Command{ | ||||
| } | ||||
| 
 | ||||
| func init() { | ||||
| 	rootCmd.AddCommand(getCmd) | ||||
| 	root.RootCmd.AddCommand(getCmd) | ||||
| } | ||||
| @@ -16,7 +16,7 @@ | ||||
|  *	along with this program.  If not, see <http://www.gnu.org/licenses/>. | ||||
|  */ | ||||
| 
 | ||||
| package cmd | ||||
| package get | ||||
| 
 | ||||
| import ( | ||||
| 	"bufio" | ||||
| @@ -16,7 +16,7 @@ | ||||
|  *	along with this program.  If not, see <http://www.gnu.org/licenses/>. | ||||
|  */ | ||||
| 
 | ||||
| package cmd | ||||
| package get | ||||
| 
 | ||||
| import ( | ||||
| 	"bufio" | ||||
| @@ -16,7 +16,7 @@ | ||||
|  *	along with this program.  If not, see <http://www.gnu.org/licenses/>. | ||||
|  */ | ||||
| 
 | ||||
| package cmd | ||||
| package get | ||||
| 
 | ||||
| import ( | ||||
| 	"bufio" | ||||
| @@ -19,9 +19,13 @@ | ||||
| package main | ||||
|  | ||||
| import ( | ||||
| 	"os" | ||||
| 	_ "go.arsenm.dev/itd/cmd/itctl/firmware" | ||||
| 	_ "go.arsenm.dev/itd/cmd/itctl/get" | ||||
| 	_ "go.arsenm.dev/itd/cmd/itctl/notify" | ||||
| 	"go.arsenm.dev/itd/cmd/itctl/root" | ||||
| 	_ "go.arsenm.dev/itd/cmd/itctl/set" | ||||
|  | ||||
| 	"go.arsenm.dev/itd/cmd/itctl/cmd" | ||||
| 	"os" | ||||
|  | ||||
| 	"github.com/rs/zerolog" | ||||
| 	"github.com/rs/zerolog/log" | ||||
| @@ -32,5 +36,5 @@ func init() { | ||||
| } | ||||
|  | ||||
| func main() { | ||||
| 	cmd.Execute() | ||||
| 	root.Execute() | ||||
| } | ||||
|   | ||||
| @@ -16,7 +16,7 @@ | ||||
|  *	along with this program.  If not, see <http://www.gnu.org/licenses/>. | ||||
|  */ | ||||
| 
 | ||||
| package cmd | ||||
| package notify | ||||
| 
 | ||||
| import ( | ||||
| 	"bufio" | ||||
| @@ -26,6 +26,7 @@ import ( | ||||
| 	"github.com/rs/zerolog/log" | ||||
| 	"github.com/spf13/cobra" | ||||
| 	"github.com/spf13/viper" | ||||
| 	"go.arsenm.dev/itd/cmd/itctl/root" | ||||
| 	"go.arsenm.dev/itd/internal/types" | ||||
| ) | ||||
| 
 | ||||
| @@ -79,5 +80,5 @@ var notifyCmd = &cobra.Command{ | ||||
| } | ||||
| 
 | ||||
| func init() { | ||||
| 	rootCmd.AddCommand(notifyCmd) | ||||
| 	root.RootCmd.AddCommand(notifyCmd) | ||||
| } | ||||
| @@ -16,7 +16,7 @@ | ||||
|  *	along with this program.  If not, see <http://www.gnu.org/licenses/>. | ||||
|  */ | ||||
| 
 | ||||
| package cmd | ||||
| package root | ||||
| 
 | ||||
| import ( | ||||
| 	"github.com/abiosoft/ishell" | ||||
| @@ -24,8 +24,8 @@ import ( | ||||
| 	"github.com/spf13/viper" | ||||
| ) | ||||
| 
 | ||||
| // rootCmd represents the base command when called without any subcommands | ||||
| var rootCmd = &cobra.Command{ | ||||
| // RootCmd represents the base command when called without any subcommands | ||||
| var RootCmd = &cobra.Command{ | ||||
| 	Use:   "itctl", | ||||
| 	Short: "Control the itd daemon for InfiniTime smartwatches", | ||||
| 	Run: func(cmd *cobra.Command, args []string) { | ||||
| @@ -61,16 +61,16 @@ var rootCmd = &cobra.Command{ | ||||
| // Execute adds all child commands to the root command and sets flags appropriately. | ||||
| // This is called by main.main(). It only needs to happen once to the rootCmd. | ||||
| func Execute() { | ||||
| 	rootCmd.CompletionOptions.DisableDefaultCmd = true | ||||
| 	cobra.CheckErr(rootCmd.Execute()) | ||||
| 	RootCmd.CompletionOptions.DisableDefaultCmd = true | ||||
| 	cobra.CheckErr(RootCmd.Execute()) | ||||
| } | ||||
| 
 | ||||
| func init() { | ||||
| 	// Register flag for socket path | ||||
| 	rootCmd.Flags().StringP("socket-path", "s", "", "Path to itd socket") | ||||
| 	RootCmd.Flags().StringP("socket-path", "s", "", "Path to itd socket") | ||||
| 
 | ||||
| 	// Bind flag and environment variable to viper key | ||||
| 	viper.BindPFlag("sockPath", rootCmd.Flags().Lookup("socket-path")) | ||||
| 	viper.BindPFlag("sockPath", RootCmd.Flags().Lookup("socket-path")) | ||||
| 	viper.BindEnv("sockPath", "ITCTL_SOCKET_PATH") | ||||
| 
 | ||||
| 	// Set default value for socket path | ||||
| @@ -16,10 +16,11 @@ | ||||
|  *	along with this program.  If not, see <http://www.gnu.org/licenses/>. | ||||
|  */ | ||||
| 
 | ||||
| package cmd | ||||
| package set | ||||
| 
 | ||||
| import ( | ||||
| 	"github.com/spf13/cobra" | ||||
| 	"go.arsenm.dev/itd/cmd/itctl/root" | ||||
| ) | ||||
| 
 | ||||
| // setCmd represents the set command | ||||
| @@ -29,5 +30,5 @@ var setCmd = &cobra.Command{ | ||||
| } | ||||
| 
 | ||||
| func init() { | ||||
| 	rootCmd.AddCommand(setCmd) | ||||
| 	root.RootCmd.AddCommand(setCmd) | ||||
| } | ||||
| @@ -16,7 +16,7 @@ | ||||
|  *	along with this program.  If not, see <http://www.gnu.org/licenses/>. | ||||
|  */ | ||||
| 
 | ||||
| package cmd | ||||
| package set | ||||
| 
 | ||||
| import ( | ||||
| 	"bufio" | ||||
		Reference in New Issue
	
	Block a user