summaryrefslogtreecommitdiff
path: root/notes.go
diff options
context:
space:
mode:
authorJeff Carr <[email protected]>2023-12-31 02:49:26 -0600
committerJeff Carr <[email protected]>2023-12-31 02:49:26 -0600
commitb0b8b762ab98355d39750ebee5ef9f9feaa3c0ba (patch)
tree4a008ab4cf3bad03db9c60327104bc3b6da7f2c3 /notes.go
parent2a6ac8ccab17c7749cf12c951fccf42aa26da6cb (diff)
use go-arg package. start migrating more code over
Signed-off-by: Jeff Carr <[email protected]>
Diffstat (limited to 'notes.go')
-rw-r--r--notes.go80
1 files changed, 80 insertions, 0 deletions
diff --git a/notes.go b/notes.go
new file mode 100644
index 0000000..6b422f6
--- /dev/null
+++ b/notes.go
@@ -0,0 +1,80 @@
+package log
+
+/*
+var argv struct {
+ Foo string
+ Bar bool
+ User string `arg:"env:USER"`
+ Demo bool `help:"run a demo"`
+}
+*/
+
+/*
+var f1 *os.File
+var f2 *os.File
+var err error
+*/
+
+/* from gocron:
+
+// DefaultLogger is used by Cron if none is specified.
+var DefaultLogger Logger = PrintfLogger(log.New(os.Stdout, "cron: ", log.LstdFlags))
+
+// DiscardLogger can be used by callers to discard all log messages.
+var DiscardLogger Logger = PrintfLogger(log.New(ioutil.Discard, "", 0))
+
+// Logger is the interface used in this package for logging, so that any backend
+// can be plugged in. It is a subset of the github.com/go-logr/logr interface.
+type Logger interface {
+ // Info logs routine messages about cron's operation.
+ Info(msg string, keysAndValues ...interface{})
+ // Error logs an error condition.
+ Error(err error, msg string, keysAndValues ...interface{})
+}
+
+*/
+
+// fmt.Println(argv.Foo, args.Bar, args.User)
+/*
+ // from: https://github.com/robfig/cron/blob/master/logger.go
+ log.Println()
+ log.Println("STDOUT is now at /tmp/guilogfile")
+ log.Println("STDOUT is now at /tmp/guilogfile")
+ log.Println()
+ f1, err = os.OpenFile(outfile, os.O_RDWR | os.O_CREATE | os.O_APPEND, 0666)
+ if err != nil {
+ log.Fatalf("error opening file: %v", err)
+ }
+ // hmm. is there a trick here or must this be in main()
+ // defer f.Close()
+
+ log.SetOutput(f1)
+ log.Println("This is a test log entry")
+*/
+
+/*
+func captureSTDOUT() {
+ f2, _ = os.OpenFile("/tmp/my.log", os.O_APPEND|os.O_CREATE|os.O_WRONLY, 0664)
+ multiWriter := io.MultiWriter(os.Stderr, f2)
+ rd, wr, err := os.Pipe()
+ if err != nil {
+ os.Exit(1)
+ }
+
+ // overwrite os.Stdout
+ os.Stderr = wr
+
+ go func() {
+ scanner := bufio.NewScanner(rd)
+ for scanner.Scan() {
+ stdoutLine := scanner.Text()
+ multiWriter.Write([]byte(stdoutLine + "\n"))
+ }
+ }()
+
+ fmt.Println("foobar")
+
+ // hacky sleep to ensure the go routine can write before program exits
+ time.Sleep(time.Second)
+}
+*/