// Code generated by go.wit.com/apps/autogenpb DO NOT EDIT. // This file was autogenerated with autogenpb v0.5.3-11-g737c5b7 2025.09.16_2337 // go install go.wit.com/apps/autogenpb@latest // // define which structs (messages) you want to use in the .proto file // Then sort.pb.go and marshal.pb.go files are autogenerated // // autogenpb uses it and has an example .proto file with instructions // package gitpb import ( "time" "github.com/google/uuid" "go.wit.com/gui" "go.wit.com/lib/protobuf/guipb" "go.wit.com/log" "google.golang.org/protobuf/proto" anypb "google.golang.org/protobuf/types/known/anypb" timestamppb "google.golang.org/protobuf/types/known/timestamppb" "google.golang.org/protobuf/types/known/wrapperspb" ) // START GUI func (x *GitTags) NewTable(title string) *GitTagsTable { t := new(GitTagsTable) t.x = x pb := new(guipb.Table) pb.Title = title t.pb = pb return t } // force the application to choose the type of data. this allows the GUI plugin to be smarter func (t *GitTagsTable) AddStringFunc(title string, f func(*GitTag) string) *GitTagAnyFunc { t.pb.Order = append(t.pb.Order, title) sf := new(GitTagAnyFunc) sf.title = title sf.f = func(x *GitTag) any { return f(x) } sf.attr = new(guipb.ColAttr) sf.attr.Width = int32(sf.Width) sf.attr.Type = guipb.ColAttr_STRING t.anyFuncs = append(t.anyFuncs, sf) return sf } // force the application to choose the type of data. this allows the GUI plugin to be smarter func (t *GitTagsTable) AddButtonFunc(title string, f func(*GitTag) string) *GitTagAnyFunc { t.pb.Order = append(t.pb.Order, title) sf := new(GitTagAnyFunc) sf.title = title sf.f = func(x *GitTag) any { return f(x) } sf.attr = new(guipb.ColAttr) sf.attr.Width = int32(sf.Width) sf.attr.Type = guipb.ColAttr_STRING sf.attr.Click = true t.anyFuncs = append(t.anyFuncs, sf) return sf } // force the application to choose the type of data. this allows the GUI plugin to be smarter func (t *GitTagsTable) AddIntFunc(title string, f func(*GitTag) int) *GitTagAnyFunc { t.pb.Order = append(t.pb.Order, title) sf := new(GitTagAnyFunc) sf.title = title sf.f = func(x *GitTag) any { return f(x) } sf.attr = new(guipb.ColAttr) sf.attr.Width = int32(sf.Width) sf.attr.Type = guipb.ColAttr_INT t.anyFuncs = append(t.anyFuncs, sf) return sf } // force the application to choose the type of data. this allows the GUI plugin to be smarter func (t *GitTagsTable) AddTimeFunc(title string, f func(*GitTag) time.Time) *GitTagAnyFunc { t.pb.Order = append(t.pb.Order, title) sf := new(GitTagAnyFunc) sf.title = title sf.f = func(x *GitTag) any { return f(x) } sf.attr = new(guipb.ColAttr) sf.attr.Width = int32(sf.Width) sf.attr.Type = guipb.ColAttr_TIME // t.timeFuncs = append(t.timeFuncs, sf) t.anyFuncs = append(t.anyFuncs, sf) return sf } func (sf *GitTagAnyFunc) SetTitle(title string) { sf.title = title } func (mt *GitTagsTable) SetParent(p *gui.Node) { mt.parent = p } func (mt *GitTagsTable) ShowTable() { // log.Info("ShowTable() SENDING TO GUI") mt.MakeTable() mt.parent.ShowTable(mt.pb) } type GitTagAnyFunc struct { title string f func(*GitTag) any Custom func(*GitTag) Width int attr *guipb.ColAttr } type GitTagsTable struct { pb *guipb.Table parent *gui.Node x *GitTags hostnames []string anyFuncs []*GitTagAnyFunc CustomFunc func(*GitTag) } func (mt *GitTagsTable) doAnyFuncNew(sf *GitTagAnyFunc) bool { r := new(guipb.AnyCol) r.Header = new(guipb.Widget) r.Header.Name = sf.title r.Attr = proto.Clone(sf.attr).(*guipb.ColAttr) for m := range mt.x.IterAll() { t := sf.f(m) switch r.Attr.Type { case guipb.ColAttr_STRING: // anyProto, err := anypb.New(tsProto) stringValue := wrapperspb.String(t.(string)) anyProto, err := anypb.New(stringValue) _ = err // do something with err someday (?) r.Vals = append(r.Vals, anyProto) // return col.Vals[row] true case guipb.ColAttr_INT: var finalInt int finalInt = t.(int) intVal := wrapperspb.Int32(int32(finalInt)) anyProto, _ := anypb.New(intVal) r.Vals = append(r.Vals, anyProto) case guipb.ColAttr_DURATION: case guipb.ColAttr_TIME: var goTime time.Time goTime = t.(time.Time) tsProto := timestamppb.New(goTime) anyProto, err := anypb.New(tsProto) _ = err // do something with err someday (?) r.Vals = append(r.Vals, anyProto) default: log.Info("cell unhandled type", r.Attr.Type) } // cellTime := r.Vals[row] // s := shell.FormatDuration(time.Since(cellTime.AsTime())) } mt.pb.AnyCols = append(mt.pb.AnyCols, r) return true } func (mt *GitTagsTable) MakeTable() { for _, sf := range mt.anyFuncs { mt.doAnyFuncNew(sf) } } func (t *GitTagsTable) AddRefname() *GitTagAnyFunc { sf := t.AddStringFunc("Refname", func(m *GitTag) string { return m.Refname }) return sf } func (t *GitTagsTable) AddHash() *GitTagAnyFunc { sf := t.AddStringFunc("Hash", func(m *GitTag) string { return m.Hash }) return sf } func (t *GitTagsTable) AddSubject() *GitTagAnyFunc { sf := t.AddStringFunc("Subject", func(m *GitTag) string { return m.Subject }) return sf } func (mt *GitTagsTable) NewUuid() { mt.pb.Uuid = uuid.New().String() } // START TABLE UPDATE (doesn't work yet) func (mt *GitTagsTable) dumpStringFunc(name string) { for i, r := range mt.pb.StringCols { // log.Info("could use", i, r.Header.Name, "for name =", name) if r.Header.Name == name { log.Info("dump Strings row", i, r.Header.Name, r.Vals) break } } } func (mt *GitTagsTable) Delete() { if mt == nil { log.Info("mt == nil table already deleted") return } // log.Info("table Delete here") mt.parent.DeleteTable(mt.pb) } func (mt *GitTagsTable) gitTagsCustom(w *guipb.Widget) { row := mt.x.GitTags[w.Location.Y-1] // log.Info("got to gitTagsCustom() with", w.Location.X, w.Location.Y-1) for i, sf := range mt.anyFuncs { if i == int(w.Location.X) { if sf.Custom != nil { log.Info("doing Custom() func for button") sf.Custom(row) return } } } mt.CustomFunc(row) } func (mt *GitTagsTable) Custom(f func(*GitTag)) { mt.pb.RegisterCustom(mt.gitTagsCustom) mt.CustomFunc = f } func (mt *GitTagsTable) GetUuid() string { return mt.pb.Uuid } // END TABLE UPDATE // END GUI