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
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
|
// Copyright 2017-2025 WIT.COM Inc. All rights reserved.
// Use of this source code is governed by the GPL 3.0
package main
// An app to submit patches for the 30 GO GUI repos
import (
"embed"
"go.wit.com/lib/ENV"
"go.wit.com/lib/protobuf/argvpb"
"go.wit.com/lib/protobuf/forgepb"
"go.wit.com/log"
)
// at build time, this can be used to store GUI plugins with matching GO deps
//
//go:embed resources/*
var resources embed.FS
func doInit() *forgepb.Forge {
// the current forge init process
forge, err := forgepb.Init()
me.forge = forge
if err == nil {
// do the new user check anyway. should exit right away with no error
s, err := doNewUser()
if err != nil {
// fail if new user check fails
me.argv.BadExit(s, err)
}
return forge
}
// Probably a new user
s, err := doNewUser()
if err != nil {
me.argv.BadExit(s, err)
}
me.argv.GoodExit("try running: 'forge rebuild forge' to test out that forge is working on your machine")
return forge
}
func doCoreChecks() {
me.forge.RescanRepos() // looks for new dirs, checks existing repos for changes
// if you are in "normal" mode, always run normal every time to catch accidental errors
// for example, if you accidentally changed branches from your user branch
if me.forge.IsModeNormal() {
// show what is still normal and what is not
if doNormalStatus() {
// log.Info("things are still normal")
} else {
log.Info("doNormalStatus() failed. things are not normal anymore")
}
} else {
if !me.forge.IsModeNormal() {
ENV.PrintTable()
}
if me.forge.IsModeDevel() {
dumpDebug()
}
}
}
func main() {
var s string
var err error
me = new(mainType)
me.argv = argvpb.Autocomplete(&argv) // adds shell auto complete to go-args
me.forge, err = forgepb.Init()
if err != nil {
log.Printf("forge failure on Init err=(%v)\n", err)
me.argv.BadExit("WTF", err)
}
if me.forge.IsModeUnknown() || me.forge.IsModeNewUser() {
doNewUser()
}
// put things to do every time forge runs here
doCoreChecks()
if me.argv.Cmd == "" {
// no command line arguments were given
// do the default behavior and exit
s, err := doDefaultBehavior()
if err != nil {
me.argv.BadExit(s, err)
}
me.argv.GoodExit(s)
}
log.Info("Starting forge with subcommand:", me.argv.Cmd)
s, err = doSubcommand()
// safe exits back to your shell (with timing and toolkit close)
if err != nil {
me.argv.BadExit(s, err)
}
me.argv.GoodExit(s)
}
|