-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathmain.go
89 lines (70 loc) · 1.72 KB
/
main.go
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
package main
import (
"flag"
"os"
"strconv"
"github.com/adrg/xdg"
"github.com/rs/zerolog"
"github.com/rs/zerolog/log"
"github.com/mattouille/papyri/database"
)
// integration points with goreleaser
var (
version = "dev"
commit = "none"
date = "unknown"
builtBy = "unknown"
)
func main() {
log.Debug().Strs("args", os.Args).Msg("Arguments passed")
// Close the default connections
defer database.DefaultConnection.Close()
err := database.DefaultConnection.Initialize()
if err != nil {
println("Error:", err.Error())
os.Exit(1)
}
cfg, err := database.DefaultConnection.Config()
if err != nil {
println("Error:", err.Error())
os.Exit(1)
}
log.Logger.Info().Interface("config", cfg)
// Create application with options
err = RunGUI()
if err != nil {
println("Error:", err)
}
}
func init() {
// sort out flags
debug := flag.Bool("debug", false, "sets log level to debug")
flag.Parse()
// creates pretty print text logging
zerolog.CallerMarshalFunc = func(file string, line int) string {
short := file
for i := len(file) - 1; i > 0; i-- {
if file[i] == '/' {
short = file[i+1:]
break
}
}
file = short
return file + ":" + strconv.Itoa(line)
}
// Set two log modes
zerolog.SetGlobalLevel(zerolog.InfoLevel)
if *debug {
zerolog.SetGlobalLevel(zerolog.DebugLevel)
log.Debug().Str("method", "flag").Msg("Log level set to debug")
}
// print the line that triggered the log
log.Logger = log.With().Caller().Logger()
// write to stderr
log.Logger = log.Output(zerolog.ConsoleWriter{Out: os.Stderr})
// setup the database
dbDir := xdg.DataHome
db, _ := database.New(dbDir + "/" + database.DefaultName)
database.DefaultConnection = db
log.Info().Msg("Starting application")
}