gitpb/gitTag.gui.pb.go

258 lines
6.2 KiB
Go

// 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