diff options
Diffstat (limited to '')
-rw-r--r-- | pkg/datamaps/config.go | 29 | ||||
-rw-r--r-- | pkg/datamaps/db.go | 2 |
2 files changed, 6 insertions, 25 deletions
diff --git a/pkg/datamaps/config.go b/pkg/datamaps/config.go index 91718b5..e64f1fd 100644 --- a/pkg/datamaps/config.go +++ b/pkg/datamaps/config.go @@ -1,8 +1,6 @@ package datamaps import ( - "flag" - "fmt" "log" "os" "path/filepath" @@ -63,6 +61,7 @@ func defaultOptions() *Options { } } +// nextString get the next string in a slice func nextString(args []string, i *int, message string) string { if len(args) > *i+1 { *i++ @@ -91,34 +90,16 @@ func processOptions(opts *Options, allArgs []string) { opts.DMPath = nextString(restArgs, &i, "import path required") case "-n", "--name": opts.DMName = nextString(restArgs, &i, "datamap name required") + case "--overwrite": + opts.DMOverwrite = true + case "--initial": + opts.DMInitial = true } - } } func ParseOptions() *Options { opts := defaultOptions() processOptions(opts, os.Args[1:]) - - // setup command - setupCmd := flag.NewFlagSet("setup", flag.ExitOnError) - setupCmd.Usage = func() { fmt.Println("No, you fucking idiot!") } - - // datamap command and its flags - datamapCmd := flag.NewFlagSet("datamap", flag.ExitOnError) - _ = datamapCmd.String("import", opts.DMPath, "Path to datamap") - _ = datamapCmd.String("name", opts.DMName, "The name you want to give to the imported datamap.") - _ = datamapCmd.Bool("overwrite", opts.DMOverwrite, "Start fresh with this datamap (erases existing datamap data).") - _ = datamapCmd.Bool("initial", opts.DMInitial, "This option must be used where no datamap table yet exists.") - - // server command and its flags - _ = flag.NewFlagSet("server", flag.ExitOnError) - - if len(os.Args) < 2 { - fmt.Println("Expected 'datamap' or 'setup' subcommand") - os.Exit(1) - } - return opts - } diff --git a/pkg/datamaps/db.go b/pkg/datamaps/db.go index 46d07bc..0f6a930 100644 --- a/pkg/datamaps/db.go +++ b/pkg/datamaps/db.go @@ -53,7 +53,7 @@ func SetupDB(path string) (*sql.DB, error) { // TODO - how do we avoid passing in all these params!??! //DatamapToDB takes a slice of DatamapLine and writes it to a sqlite3 db file. //func DatafmapToDB(d_path string, data []DatamapLine, dm_name string, dm_path string) error { -func DatamapToDB(opts Options) error { +func DatamapToDB(opts *Options) error { fmt.Printf("Importing datamap file %s and naming it %s.\n", opts.DMPath, opts.DMName) // db, err := SetupDB("/home/lemon/.config/datamaps-go/datamaps.db") // if err != nil { |