ingo is a simple Go library helping you to persist flags in a ini-like config file.
-h
output.:
and =
and not start with #
as these
runes are used as separators and comment prefix in the config filego get -u github.com/schachmat/ingo
Just setup your flags with defaults like you are used to do. Instead of
flag.Parse()
you have to call ingo.Parse(APPLICATION_NAME)
and check if an
error is returned. Thats all.
package main
import (
"flag"
"fmt"
"log"
"github.com/schachmat/ingo"
)
func main() {
num := flag.Int("num", 3, "`NUMBER` of times to\n \tdo a barrel roll")
location := flag.String("location", "space", "`WHERE` to do the barrel roll")
flag.StringVar(location, "l", "space", "`WHERE` to do the barrel roll (shorthand)")
if err := ingo.Parse("keep_rollin"); err != nil {
log.Fatal(err)
}
fmt.Println(*num, *location)
}
The (one newline, four spaces, one tab) separator will ensure that multi-line
usage strings will be laid out correctly in the config file and in the -h
help message. The code will create the following config file .keep_rollinrc
(or any other location if specified in the environment variable
KEEP_ROLLINRC
):
# WHERE to do the barrel roll
location=space
# NUMBER of times to
# do a barrel roll
num=3
If you change num to 5 in the config file, it will be persistent on all future runs:
# WHERE to do the barrel roll
location=space
# NUMBER of times to
# do a barrel roll
num=5
If you add a new flag style
to your programm, it will be added to the config
file on the first run using the default value from the flag:
# WHERE to do the barrel roll
location=space
# NUMBER of times to
# do a barrel roll
num=5
# HOW to do the barrel roll
style=epic
If you remove both location flags from your programm, the config entry will be rewritten to this:
# NUMBER of times to
# do a barrel roll
num=5
# HOW to do the barrel roll
style=epic
# The following options are probably deprecated and not used currently!
location=space
Also when such old flags are found, a warning like the following is printed to
stderr when running ingo.Parse
:
!!!!!!!!!!
! WARNING: keep_rollin was probably updated,
! Check and update .keep_rollinrc as necessary
! and remove the last "deprecated" paragraph to disable this message!
!!!!!!!!!!
All config files will have a header like the following explaining the syntax:
# keep_rollin configuration
#
# This config has https://github.com/schachmat/ingo syntax.
# Empty lines or lines starting with # will be ignored.
# All other lines must look like "KEY=VALUE" (without the quotes).
# The VALUE must not be enclosed in quotes as well!
Copyright (c) 2016-2017, [email protected]
Permission to use, copy, modify, and/or distribute this software for any purpose with or without fee is hereby granted, provided that the above copyright notice and this permission notice appear in all copies.
THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.