repolist/scan.go

77 lines
1.4 KiB
Go
Raw Normal View History

2024-02-17 08:39:55 -06:00
package repolist
import (
"fmt"
2024-02-19 19:43:21 -06:00
"strconv"
2024-02-17 08:39:55 -06:00
"strings"
"go.wit.com/log"
)
2024-02-17 14:22:24 -06:00
func (r *RepoList) SetAutoScan(b bool) {
me.autoScan = b
}
2024-02-19 21:11:32 -06:00
func (r *RepoList) RegisterHideFunction(f func(*Repo)) {
2024-02-19 19:43:21 -06:00
me.hideFunction = f
}
2024-02-17 14:22:24 -06:00
func (r *RepoList) ScanRepositories() (int, string) {
2024-02-17 08:39:55 -06:00
var i int
2024-02-19 19:43:21 -06:00
var shown int
2024-02-18 15:09:35 -06:00
t := TimeFunction(func() {
2024-02-17 08:39:55 -06:00
for _, repo := range me.allrepos {
i += 1
2024-02-17 14:22:24 -06:00
repo.NewScan()
2024-02-19 19:43:21 -06:00
if me.hideFunction == nil {
// application didn't register a hide function
} else {
me.hideFunction(repo)
}
}
var hidden int
for _, repo := range me.allrepos {
if repo.Hidden() {
hidden += 1
} else {
shown += 1
}
2024-02-17 08:39:55 -06:00
}
})
s := fmt.Sprint(t)
2024-02-19 19:43:21 -06:00
tmp := strconv.Itoa(shown) + " repos shown"
log.Info("Setting shownCount to", tmp)
me.shownCount.SetText(tmp)
log.Info("Scanned", i, "repositories. todo: count/show changes in", s)
2024-02-17 08:39:55 -06:00
return i, s
}
2024-02-17 14:22:24 -06:00
func (r *Repo) NewScan() bool {
2024-02-17 15:48:56 -06:00
if r.Status == nil {
log.Warn("repo.Status = nil. not initialized for some reason")
2024-02-17 08:39:55 -06:00
return false
}
// run the repostatus update
2024-02-17 15:48:56 -06:00
r.Status.UpdateNew()
2024-02-17 08:39:55 -06:00
// print out whatever changes have happened
2024-02-17 15:48:56 -06:00
if c, ok := r.Status.Changed(); ok {
2024-02-17 08:39:55 -06:00
c := strings.TrimSpace(c)
for _, line := range strings.Split(c, "\n") {
2024-02-17 15:48:56 -06:00
log.Info(r.Status.Path(), line)
2024-02-17 08:39:55 -06:00
}
}
2024-02-18 17:56:25 -06:00
// hide or show repos based on the checkboxes
if me.autoHidePerfect {
if r.IsPerfect() {
2024-02-17 08:39:55 -06:00
r.Hide()
} else {
r.Show()
2024-02-17 08:39:55 -06:00
}
}
return true
2024-02-17 08:39:55 -06:00
}