summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--auto.marshal.pb.go93
-rw-r--r--auto.pb.go374
-rw-r--r--auto.sort.pb.go191
-rw-r--r--go.mod21
-rw-r--r--go.sum38
5 files changed, 717 insertions, 0 deletions
diff --git a/auto.marshal.pb.go b/auto.marshal.pb.go
new file mode 100644
index 0000000..3a3d8ca
--- /dev/null
+++ b/auto.marshal.pb.go
@@ -0,0 +1,93 @@
+// Code generated by go.wit.com/apps/autogenpb DO NOT EDIT.
+// This file was autogenerated with autogenpb v0.5.14 2025-09-28_00:11:07_UTC
+// 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 prep
+
+import (
+ "google.golang.org/protobuf/encoding/protojson"
+ "google.golang.org/protobuf/encoding/prototext"
+ "google.golang.org/protobuf/proto"
+)
+
+// human readable JSON
+func (v *Autos) FormatJSON() string {
+ return protojson.Format(v)
+}
+
+// marshal json
+func (v *Autos) MarshalJSON() ([]byte, error) {
+ return protojson.Marshal(v)
+}
+
+// unmarshal json
+func (v *Autos) UnmarshalJSON(data []byte) error {
+ return protojson.Unmarshal(data, v)
+}
+
+// apparently this isn't stable, but it's awesomely better
+// https://protobuf.dev/reference/go/faq/#unstable-text
+// it's brilliant for config files!
+func (v *Autos) FormatTEXT() string {
+ v.fixUuid()
+ return prototext.Format(v)
+}
+
+// unmarshalTEXT. This reads the .text config file back in after the user edits it
+func (v *Autos) UnmarshalTEXT(data []byte) error {
+ return prototext.Unmarshal(data, v)
+}
+
+// marshal to wire. This is called winning.
+func (v *Autos) Marshal() ([]byte, error) {
+ v.fixUuid()
+ return proto.Marshal(v)
+}
+
+// unmarshal from wire. You have won.
+func (v *Autos) Unmarshal(data []byte) error {
+ return proto.Unmarshal(data, v)
+}
+
+// human readable JSON
+func (v *Auto) FormatJSON() string {
+ return protojson.Format(v)
+}
+
+// marshal json
+func (v *Auto) MarshalJSON() ([]byte, error) {
+ return protojson.Marshal(v)
+}
+
+// unmarshal json
+func (v *Auto) UnmarshalJSON(data []byte) error {
+ return protojson.Unmarshal(data, v)
+}
+
+// apparently this isn't stable, but it's awesomely better
+// https://protobuf.dev/reference/go/faq/#unstable-text
+// it's brilliant for config files!
+func (v *Auto) FormatTEXT() string {
+ return prototext.Format(v)
+}
+
+// unmarshalTEXT. This reads the .text config file back in after the user edits it
+func (v *Auto) UnmarshalTEXT(data []byte) error {
+ return prototext.Unmarshal(data, v)
+}
+
+// marshal to wire. This is called winning.
+func (v *Auto) Marshal() ([]byte, error) {
+ return proto.Marshal(v)
+}
+
+// unmarshal from wire. You have won.
+func (v *Auto) Unmarshal(data []byte) error {
+ return proto.Unmarshal(data, v)
+}
diff --git a/auto.pb.go b/auto.pb.go
new file mode 100644
index 0000000..438235b
--- /dev/null
+++ b/auto.pb.go
@@ -0,0 +1,374 @@
+// Code modified by go.wit.com/apps/autogenpb DO NOT EDIT.
+//
+// user defined Mutex locks were auto added
+//
+// autogenpb version & build time: v0.5.14 2025-09-28_00:11:07_UTC
+// autogenpb auto generates Sort(), Unique() and Marshal() functions
+// go install go.wit.com/apps/autogenpb@latest
+
+// Copyright 2025 WIT.COM Inc Licensed GPL 3.0
+
+// Code generated by protoc-gen-go. DO NOT EDIT.
+// versions:
+// protoc-gen-go v1.33.0
+// protoc v3.21.12
+// source: auto.proto
+
+package prep // autogenpb changed the package name
+
+import (
+ reflect "reflect"
+ sync "sync"
+
+ protoreflect "google.golang.org/protobuf/reflect/protoreflect"
+ protoimpl "google.golang.org/protobuf/runtime/protoimpl"
+ durationpb "google.golang.org/protobuf/types/known/durationpb"
+ timestamppb "google.golang.org/protobuf/types/known/timestamppb"
+)
+
+const (
+ // Verify that this generated code is sufficiently up-to-date.
+ _ = protoimpl.EnforceVersion(20 - protoimpl.MinVersion)
+ // Verify that runtime/protoimpl is sufficiently up-to-date.
+ _ = protoimpl.EnforceVersion(protoimpl.MaxVersion - 20)
+)
+
+type Auto struct {
+ // sync.RWMutex // skipped. protobuf file has `autogenpb:nomutex`
+
+ state protoimpl.MessageState
+ sizeCache protoimpl.SizeCache
+ unknownFields protoimpl.UnknownFields
+
+ Ctime *timestamppb.Timestamp `protobuf:"bytes,1,opt,name=ctime,proto3" json:"ctime,omitempty"` // when the user tried this autocomplete
+ Duration *durationpb.Duration `protobuf:"bytes,2,opt,name=duration,proto3" json:"duration,omitempty"` // time since the last autocomplete
+ Argname string `protobuf:"bytes,3,opt,name=argname,proto3" json:"argname,omitempty"` // what the shell thinks the name of the executable is
+ Arg0 string `protobuf:"bytes,4,opt,name=arg0,proto3" json:"arg0,omitempty"` // what os.Exec() has as os.Argv[0] // not interesting
+ Arg1 string `protobuf:"bytes,5,opt,name=arg1,proto3" json:"arg1,omitempty"` // should always be "--auto-complete" // not interesting
+ Arg3 string `protobuf:"bytes,6,opt,name=arg3,proto3" json:"arg3,omitempty"` // usually argv3 == argv0
+ Argv []string `protobuf:"bytes,7,rep,name=argv,proto3" json:"argv,omitempty"` // use this to store whatever you want while the whole POST happens
+ Cmd string `protobuf:"bytes,8,opt,name=cmd,proto3" json:"cmd,omitempty"` // the cmd being processed. For "git pull <tab>", cmd would be "pull"
+ Partial string `protobuf:"bytes,9,opt,name=partial,proto3" json:"partial,omitempty"` // set to the partial string trying to be matched
+ IsAuto bool `protobuf:"varint,10,opt,name=isAuto,proto3" json:"isAuto,omitempty"` // is true if '--auto-complete' is set
+ SetupAuto bool `protobuf:"varint,11,opt,name=setupAuto,proto3" json:"setupAuto,omitempty"` // is true if '--bash' is set // setup bash autocomplete here
+ Debug bool `protobuf:"varint,12,opt,name=debug,proto3" json:"debug,omitempty"` // print debugging info if true
+ Newline bool `protobuf:"varint,13,opt,name=newline,proto3" json:"newline,omitempty"` // was a newline was sent to STDERR?
+ Last string `protobuf:"bytes,14,opt,name=last,proto3" json:"last,omitempty"` // the last arg
+}
+
+func (x *Auto) Reset() {
+ *x = Auto{}
+ if protoimpl.UnsafeEnabled {
+ mi := &file_auto_proto_msgTypes[0]
+ ms := protoimpl.X.MessageStateOf(protoimpl.Pointer(x))
+ ms.StoreMessageInfo(mi)
+ }
+}
+
+func (x *Auto) String() string {
+ return protoimpl.X.MessageStringOf(x)
+}
+
+func (*Auto) ProtoMessage() {}
+
+func (x *Auto) ProtoReflect() protoreflect.Message {
+ mi := &file_auto_proto_msgTypes[0]
+ if protoimpl.UnsafeEnabled && x != nil {
+ ms := protoimpl.X.MessageStateOf(protoimpl.Pointer(x))
+ if ms.LoadMessageInfo() == nil {
+ ms.StoreMessageInfo(mi)
+ }
+ return ms
+ }
+ return mi.MessageOf(x)
+}
+
+// Deprecated: Use Auto.ProtoReflect.Descriptor instead.
+func (*Auto) Descriptor() ([]byte, []int) {
+ return file_auto_proto_rawDescGZIP(), []int{0}
+}
+
+func (x *Auto) GetCtime() *timestamppb.Timestamp {
+ if x != nil {
+ return x.Ctime
+ }
+ return nil
+}
+
+func (x *Auto) GetDuration() *durationpb.Duration {
+ if x != nil {
+ return x.Duration
+ }
+ return nil
+}
+
+func (x *Auto) GetArgname() string {
+ if x != nil {
+ return x.Argname
+ }
+ return ""
+}
+
+func (x *Auto) GetArg0() string {
+ if x != nil {
+ return x.Arg0
+ }
+ return ""
+}
+
+func (x *Auto) GetArg1() string {
+ if x != nil {
+ return x.Arg1
+ }
+ return ""
+}
+
+func (x *Auto) GetArg3() string {
+ if x != nil {
+ return x.Arg3
+ }
+ return ""
+}
+
+func (x *Auto) GetArgv() []string {
+ if x != nil {
+ return x.Argv
+ }
+ return nil
+}
+
+func (x *Auto) GetCmd() string {
+ if x != nil {
+ return x.Cmd
+ }
+ return ""
+}
+
+func (x *Auto) GetPartial() string {
+ if x != nil {
+ return x.Partial
+ }
+ return ""
+}
+
+func (x *Auto) GetIsAuto() bool {
+ if x != nil {
+ return x.IsAuto
+ }
+ return false
+}
+
+func (x *Auto) GetSetupAuto() bool {
+ if x != nil {
+ return x.SetupAuto
+ }
+ return false
+}
+
+func (x *Auto) GetDebug() bool {
+ if x != nil {
+ return x.Debug
+ }
+ return false
+}
+
+func (x *Auto) GetNewline() bool {
+ if x != nil {
+ return x.Newline
+ }
+ return false
+}
+
+func (x *Auto) GetLast() string {
+ if x != nil {
+ return x.Last
+ }
+ return ""
+}
+
+type Autos struct {
+ // sync.RWMutex // skipped. protobuf file has `autogenpb:nomutex`
+
+ state protoimpl.MessageState
+ sizeCache protoimpl.SizeCache
+ unknownFields protoimpl.UnknownFields
+
+ Uuid string `protobuf:"bytes,1,opt,name=uuid,proto3" json:"uuid,omitempty"` // `autogenpb:uuid:94210ebf-a534-4b33-aadd-2f5e1f56ae38`
+ Version string `protobuf:"bytes,2,opt,name=version,proto3" json:"version,omitempty"` // `autogenpb:version:v0.0.1`
+ Autos []*Auto `protobuf:"bytes,3,rep,name=autos,proto3" json:"autos,omitempty"` // THIS MUST BE HttpRequest and then HttpRequests
+}
+
+func (x *Autos) Reset() {
+ *x = Autos{}
+ if protoimpl.UnsafeEnabled {
+ mi := &file_auto_proto_msgTypes[1]
+ ms := protoimpl.X.MessageStateOf(protoimpl.Pointer(x))
+ ms.StoreMessageInfo(mi)
+ }
+}
+
+func (x *Autos) String() string {
+ return protoimpl.X.MessageStringOf(x)
+}
+
+func (*Autos) ProtoMessage() {}
+
+func (x *Autos) ProtoReflect() protoreflect.Message {
+ mi := &file_auto_proto_msgTypes[1]
+ if protoimpl.UnsafeEnabled && x != nil {
+ ms := protoimpl.X.MessageStateOf(protoimpl.Pointer(x))
+ if ms.LoadMessageInfo() == nil {
+ ms.StoreMessageInfo(mi)
+ }
+ return ms
+ }
+ return mi.MessageOf(x)
+}
+
+// Deprecated: Use Autos.ProtoReflect.Descriptor instead.
+func (*Autos) Descriptor() ([]byte, []int) {
+ return file_auto_proto_rawDescGZIP(), []int{1}
+}
+
+func (x *Autos) GetUuid() string {
+ if x != nil {
+ return x.Uuid
+ }
+ return ""
+}
+
+func (x *Autos) GetVersion() string {
+ if x != nil {
+ return x.Version
+ }
+ return ""
+}
+
+func (x *Autos) GetAutos() []*Auto {
+ if x != nil {
+ return x.Autos
+ }
+ return nil
+}
+
+var File_auto_proto protoreflect.FileDescriptor
+
+var file_auto_proto_rawDesc = []byte{
+ 0x0a, 0x0a, 0x61, 0x75, 0x74, 0x6f, 0x2e, 0x70, 0x72, 0x6f, 0x74, 0x6f, 0x12, 0x06, 0x68, 0x74,
+ 0x74, 0x70, 0x70, 0x62, 0x1a, 0x1f, 0x67, 0x6f, 0x6f, 0x67, 0x6c, 0x65, 0x2f, 0x70, 0x72, 0x6f,
+ 0x74, 0x6f, 0x62, 0x75, 0x66, 0x2f, 0x74, 0x69, 0x6d, 0x65, 0x73, 0x74, 0x61, 0x6d, 0x70, 0x2e,
+ 0x70, 0x72, 0x6f, 0x74, 0x6f, 0x1a, 0x1e, 0x67, 0x6f, 0x6f, 0x67, 0x6c, 0x65, 0x2f, 0x70, 0x72,
+ 0x6f, 0x74, 0x6f, 0x62, 0x75, 0x66, 0x2f, 0x64, 0x75, 0x72, 0x61, 0x74, 0x69, 0x6f, 0x6e, 0x2e,
+ 0x70, 0x72, 0x6f, 0x74, 0x6f, 0x22, 0xff, 0x02, 0x0a, 0x04, 0x41, 0x75, 0x74, 0x6f, 0x12, 0x30,
+ 0x0a, 0x05, 0x63, 0x74, 0x69, 0x6d, 0x65, 0x18, 0x01, 0x20, 0x01, 0x28, 0x0b, 0x32, 0x1a, 0x2e,
+ 0x67, 0x6f, 0x6f, 0x67, 0x6c, 0x65, 0x2e, 0x70, 0x72, 0x6f, 0x74, 0x6f, 0x62, 0x75, 0x66, 0x2e,
+ 0x54, 0x69, 0x6d, 0x65, 0x73, 0x74, 0x61, 0x6d, 0x70, 0x52, 0x05, 0x63, 0x74, 0x69, 0x6d, 0x65,
+ 0x12, 0x35, 0x0a, 0x08, 0x64, 0x75, 0x72, 0x61, 0x74, 0x69, 0x6f, 0x6e, 0x18, 0x02, 0x20, 0x01,
+ 0x28, 0x0b, 0x32, 0x19, 0x2e, 0x67, 0x6f, 0x6f, 0x67, 0x6c, 0x65, 0x2e, 0x70, 0x72, 0x6f, 0x74,
+ 0x6f, 0x62, 0x75, 0x66, 0x2e, 0x44, 0x75, 0x72, 0x61, 0x74, 0x69, 0x6f, 0x6e, 0x52, 0x08, 0x64,
+ 0x75, 0x72, 0x61, 0x74, 0x69, 0x6f, 0x6e, 0x12, 0x18, 0x0a, 0x07, 0x61, 0x72, 0x67, 0x6e, 0x61,
+ 0x6d, 0x65, 0x18, 0x03, 0x20, 0x01, 0x28, 0x09, 0x52, 0x07, 0x61, 0x72, 0x67, 0x6e, 0x61, 0x6d,
+ 0x65, 0x12, 0x12, 0x0a, 0x04, 0x61, 0x72, 0x67, 0x30, 0x18, 0x04, 0x20, 0x01, 0x28, 0x09, 0x52,
+ 0x04, 0x61, 0x72, 0x67, 0x30, 0x12, 0x12, 0x0a, 0x04, 0x61, 0x72, 0x67, 0x31, 0x18, 0x05, 0x20,
+ 0x01, 0x28, 0x09, 0x52, 0x04, 0x61, 0x72, 0x67, 0x31, 0x12, 0x12, 0x0a, 0x04, 0x61, 0x72, 0x67,
+ 0x33, 0x18, 0x06, 0x20, 0x01, 0x28, 0x09, 0x52, 0x04, 0x61, 0x72, 0x67, 0x33, 0x12, 0x12, 0x0a,
+ 0x04, 0x61, 0x72, 0x67, 0x76, 0x18, 0x07, 0x20, 0x03, 0x28, 0x09, 0x52, 0x04, 0x61, 0x72, 0x67,
+ 0x76, 0x12, 0x10, 0x0a, 0x03, 0x63, 0x6d, 0x64, 0x18, 0x08, 0x20, 0x01, 0x28, 0x09, 0x52, 0x03,
+ 0x63, 0x6d, 0x64, 0x12, 0x18, 0x0a, 0x07, 0x70, 0x61, 0x72, 0x74, 0x69, 0x61, 0x6c, 0x18, 0x09,
+ 0x20, 0x01, 0x28, 0x09, 0x52, 0x07, 0x70, 0x61, 0x72, 0x74, 0x69, 0x61, 0x6c, 0x12, 0x16, 0x0a,
+ 0x06, 0x69, 0x73, 0x41, 0x75, 0x74, 0x6f, 0x18, 0x0a, 0x20, 0x01, 0x28, 0x08, 0x52, 0x06, 0x69,
+ 0x73, 0x41, 0x75, 0x74, 0x6f, 0x12, 0x1c, 0x0a, 0x09, 0x73, 0x65, 0x74, 0x75, 0x70, 0x41, 0x75,
+ 0x74, 0x6f, 0x18, 0x0b, 0x20, 0x01, 0x28, 0x08, 0x52, 0x09, 0x73, 0x65, 0x74, 0x75, 0x70, 0x41,
+ 0x75, 0x74, 0x6f, 0x12, 0x14, 0x0a, 0x05, 0x64, 0x65, 0x62, 0x75, 0x67, 0x18, 0x0c, 0x20, 0x01,
+ 0x28, 0x08, 0x52, 0x05, 0x64, 0x65, 0x62, 0x75, 0x67, 0x12, 0x18, 0x0a, 0x07, 0x6e, 0x65, 0x77,
+ 0x6c, 0x69, 0x6e, 0x65, 0x18, 0x0d, 0x20, 0x01, 0x28, 0x08, 0x52, 0x07, 0x6e, 0x65, 0x77, 0x6c,
+ 0x69, 0x6e, 0x65, 0x12, 0x12, 0x0a, 0x04, 0x6c, 0x61, 0x73, 0x74, 0x18, 0x0e, 0x20, 0x01, 0x28,
+ 0x09, 0x52, 0x04, 0x6c, 0x61, 0x73, 0x74, 0x22, 0x59, 0x0a, 0x05, 0x41, 0x75, 0x74, 0x6f, 0x73,
+ 0x12, 0x12, 0x0a, 0x04, 0x75, 0x75, 0x69, 0x64, 0x18, 0x01, 0x20, 0x01, 0x28, 0x09, 0x52, 0x04,
+ 0x75, 0x75, 0x69, 0x64, 0x12, 0x18, 0x0a, 0x07, 0x76, 0x65, 0x72, 0x73, 0x69, 0x6f, 0x6e, 0x18,
+ 0x02, 0x20, 0x01, 0x28, 0x09, 0x52, 0x07, 0x76, 0x65, 0x72, 0x73, 0x69, 0x6f, 0x6e, 0x12, 0x22,
+ 0x0a, 0x05, 0x61, 0x75, 0x74, 0x6f, 0x73, 0x18, 0x03, 0x20, 0x03, 0x28, 0x0b, 0x32, 0x0c, 0x2e,
+ 0x68, 0x74, 0x74, 0x70, 0x70, 0x62, 0x2e, 0x41, 0x75, 0x74, 0x6f, 0x52, 0x05, 0x61, 0x75, 0x74,
+ 0x6f, 0x73, 0x62, 0x06, 0x70, 0x72, 0x6f, 0x74, 0x6f, 0x33,
+}
+
+var (
+ file_auto_proto_rawDescOnce sync.Once
+ file_auto_proto_rawDescData = file_auto_proto_rawDesc
+)
+
+func file_auto_proto_rawDescGZIP() []byte {
+ file_auto_proto_rawDescOnce.Do(func() {
+ file_auto_proto_rawDescData = protoimpl.X.CompressGZIP(file_auto_proto_rawDescData)
+ })
+ return file_auto_proto_rawDescData
+}
+
+var file_auto_proto_msgTypes = make([]protoimpl.MessageInfo, 2)
+var file_auto_proto_goTypes = []interface{}{
+ (*Auto)(nil), // 0: httppb.Auto
+ (*Autos)(nil), // 1: httppb.Autos
+ (*timestamppb.Timestamp)(nil), // 2: google.protobuf.Timestamp
+ (*durationpb.Duration)(nil), // 3: google.protobuf.Duration
+}
+var file_auto_proto_depIdxs = []int32{
+ 2, // 0: httppb.Auto.ctime:type_name -> google.protobuf.Timestamp
+ 3, // 1: httppb.Auto.duration:type_name -> google.protobuf.Duration
+ 0, // 2: httppb.Autos.autos:type_name -> httppb.Auto
+ 3, // [3:3] is the sub-list for method output_type
+ 3, // [3:3] is the sub-list for method input_type
+ 3, // [3:3] is the sub-list for extension type_name
+ 3, // [3:3] is the sub-list for extension extendee
+ 0, // [0:3] is the sub-list for field type_name
+}
+
+func init() { file_auto_proto_init() }
+func file_auto_proto_init() {
+ if File_auto_proto != nil {
+ return
+ }
+ if !protoimpl.UnsafeEnabled {
+ file_auto_proto_msgTypes[0].Exporter = func(v interface{}, i int) interface{} {
+ switch v := v.(*Auto); i {
+ case 0:
+ return &v.state
+ case 1:
+ return &v.sizeCache
+ case 2:
+ return &v.unknownFields
+ default:
+ return nil
+ }
+ }
+ file_auto_proto_msgTypes[1].Exporter = func(v interface{}, i int) interface{} {
+ switch v := v.(*Autos); i {
+ case 0:
+ return &v.state
+ case 1:
+ return &v.sizeCache
+ case 2:
+ return &v.unknownFields
+ default:
+ return nil
+ }
+ }
+ }
+ type x struct{}
+ out := protoimpl.TypeBuilder{
+ File: protoimpl.DescBuilder{
+ GoPackagePath: reflect.TypeOf(x{}).PkgPath(),
+ RawDescriptor: file_auto_proto_rawDesc,
+ NumEnums: 0,
+ NumMessages: 2,
+ NumExtensions: 0,
+ NumServices: 0,
+ },
+ GoTypes: file_auto_proto_goTypes,
+ DependencyIndexes: file_auto_proto_depIdxs,
+ MessageInfos: file_auto_proto_msgTypes,
+ }.Build()
+ File_auto_proto = out.File
+ file_auto_proto_rawDesc = nil
+ file_auto_proto_goTypes = nil
+ file_auto_proto_depIdxs = nil
+}
diff --git a/auto.sort.pb.go b/auto.sort.pb.go
new file mode 100644
index 0000000..bf0c4b4
--- /dev/null
+++ b/auto.sort.pb.go
@@ -0,0 +1,191 @@
+// Code generated by go.wit.com/apps/autogenpb DO NOT EDIT.
+// This file was autogenerated with autogenpb v0.5.14 2025-09-28_00:11:07_UTC
+// 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 prep
+
+import (
+ "fmt"
+ "iter"
+ "sync"
+
+ "google.golang.org/protobuf/proto"
+)
+
+// a simple global lock
+var autoMu sync.RWMutex
+
+func (x *Autos) fixUuid() {
+ if x == nil {
+ return
+ }
+ if x.Uuid == "94210ebf-a534-4b33-aadd-2f5e1f56ae38" {
+ return
+ }
+ x.Uuid = "94210ebf-a534-4b33-aadd-2f5e1f56ae38"
+ x.Version = "v0.0.1 go.wit.com/lib/gui/prep"
+}
+
+func NewAutos() *Autos {
+ x := new(Autos)
+ x.Uuid = "94210ebf-a534-4b33-aadd-2f5e1f56ae38"
+ x.Version = "v0.0.1 go.wit.com/lib/gui/prep"
+ return x
+}
+
+// START SORT
+
+// DEFINE THE Autos SCANNER.
+// itializes a new scanner.
+func newAutosScanner(things []*Autos) *AutosScanner {
+ return &AutosScanner{things: things}
+}
+
+type AutosScanner struct {
+ sync.Mutex
+
+ things []*Autos
+ index int
+}
+
+func (it *AutosScanner) Scan() bool {
+ if it.index >= len(it.things) {
+ return false
+ }
+ it.Lock()
+ it.index++
+ it.Unlock()
+ return true
+}
+
+// Next() returns the next thing in the array
+func (it *AutosScanner) Next() *Autos {
+ if it.things[it.index-1] == nil {
+ fmt.Println("Next() error in AutosScanner", it.index)
+ }
+ return it.things[it.index-1]
+}
+
+// END DEFINE THE SCANNER
+
+// DEFINE THE Auto SCANNER.
+// itializes a new scanner.
+func newAutoScanner(things []*Auto) *AutoScanner {
+ return &AutoScanner{things: things}
+}
+
+type AutoScanner struct {
+ sync.Mutex
+
+ things []*Auto
+ index int
+}
+
+func (it *AutoScanner) Scan() bool {
+ if it.index >= len(it.things) {
+ return false
+ }
+ it.Lock()
+ it.index++
+ it.Unlock()
+ return true
+}
+
+// Next() returns the next thing in the array
+func (it *AutoScanner) Next() *Auto {
+ if it.things[it.index-1] == nil {
+ fmt.Println("Next() error in AutoScanner", it.index)
+ }
+ return it.things[it.index-1]
+}
+
+// END DEFINE THE SCANNER
+
+// safely returns a slice of pointers to the FRUIT protobufs
+func (x *Autos) allAutos() []*Auto {
+ autoMu.RLock()
+ defer autoMu.RUnlock()
+
+ // Create a new slice to hold pointers to each FRUIT
+ var tmp []*Auto
+ tmp = make([]*Auto, len(x.Autos))
+ for i, p := range x.Autos {
+ tmp[i] = p // Copy pointers for safe iteration
+ }
+
+ return tmp
+}
+
+// safely returns a slice of pointers to the Auto protobufs
+func (x *Autos) selectAllAutos() []*Auto {
+ autoMu.RLock()
+ defer autoMu.RUnlock()
+
+ // Create a new slice to hold pointers to each Auto
+ var tmp []*Auto
+ tmp = make([]*Auto, len(x.Autos))
+ for i, p := range x.Autos {
+ tmp[i] = p // Copy pointers for safe iteration
+ }
+
+ return tmp
+}
+
+// END SORT
+
+func (x *Autos) Len() int {
+ autoMu.RLock()
+ defer autoMu.RUnlock()
+
+ return len(x.Autos)
+}
+
+// a Append() shortcut (that does Clone() with a mutex) notsure if it really works
+func (x *Autos) Append(y *Auto) *Auto {
+ autoMu.Lock()
+ defer autoMu.Unlock()
+
+ z := proto.Clone(y).(*Auto)
+ x.Autos = append(x.Autos, z)
+
+ return z
+}
+
+func (x *Autos) All() *AutoScanner {
+ AutoPointers := x.selectAllAutos()
+
+ scanner := newAutoScanner(AutoPointers)
+ return scanner
+}
+
+// Iterate 'for x := range' syntax using the awesome golang 1.24 'iter'
+func (x *Autos) IterAll() iter.Seq[*Auto] {
+ items := x.selectAllAutos()
+ // log.Println("Made All() Iter.Seq[] with length", len(items))
+ return func(yield func(*Auto) bool) {
+ for _, v := range items {
+ if !yield(v) {
+ return
+ }
+ }
+ }
+}
+func (x *Autos) Delete(y *Auto) bool {
+ autoMu.Lock()
+ defer autoMu.Unlock()
+
+ for i, _ := range x.Autos {
+ if x.Autos[i] == y {
+ x.Autos[i] = x.Autos[len(x.Autos)-1]
+ x.Autos = x.Autos[:len(x.Autos)-1]
+ return true
+ }
+ }
+ return false
+}
diff --git a/go.mod b/go.mod
new file mode 100644
index 0000000..4e03b8e
--- /dev/null
+++ b/go.mod
@@ -0,0 +1,21 @@
+module go.wit.com/lib/gui/prep
+
+go 1.24.1
+
+require (
+ go.wit.com/dev/alexflint/arg v1.6.4
+ go.wit.com/gui v0.25.4
+ go.wit.com/lib/fhelp v0.0.24
+ go.wit.com/lib/gui/shell v0.22.33
+ go.wit.com/log v0.25.1
+ google.golang.org/protobuf v1.36.9
+)
+
+require (
+ github.com/alexflint/go-scalar v1.2.0 // indirect
+ github.com/go-cmd/cmd v1.4.3 // indirect
+ github.com/google/uuid v1.6.0 // indirect
+ go.wit.com/lib/protobuf/guipb v0.0.17 // indirect
+ go.wit.com/widget v1.1.30 // indirect
+ golang.org/x/text v0.29.0 // indirect
+)
diff --git a/go.sum b/go.sum
new file mode 100644
index 0000000..e833f77
--- /dev/null
+++ b/go.sum
@@ -0,0 +1,38 @@
+github.com/alexflint/go-scalar v1.2.0 h1:WR7JPKkeNpnYIOfHRa7ivM21aWAdHD0gEWHCx+WQBRw=
+github.com/alexflint/go-scalar v1.2.0/go.mod h1:LoFvNMqS1CPrMVltza4LvnGKhaSpc3oyLEBUZVhhS2o=
+github.com/davecgh/go-spew v1.1.1 h1:vj9j/u1bqnvCEfJOwUhtlOARqs3+rkHYY13jYWTU97c=
+github.com/davecgh/go-spew v1.1.1/go.mod h1:J7Y8YcW2NihsgmVo/mv3lAwl/skON4iLHjSsI+c5H38=
+github.com/go-cmd/cmd v1.4.3 h1:6y3G+3UqPerXvPcXvj+5QNPHT02BUw7p6PsqRxLNA7Y=
+github.com/go-cmd/cmd v1.4.3/go.mod h1:u3hxg/ry+D5kwh8WvUkHLAMe2zQCaXd00t35WfQaOFk=
+github.com/go-test/deep v1.1.0 h1:WOcxcdHcvdgThNXjw0t76K42FXTU7HpNQWHpA2HHNlg=
+github.com/go-test/deep v1.1.0/go.mod h1:5C2ZWiW0ErCdrYzpqxLbTX7MG14M9iiw8DgHncVwcsE=
+github.com/google/go-cmp v0.5.5 h1:Khx7svrCpmxxtHBq5j2mp/xVjsi8hQMfNLvJFAlrGgU=
+github.com/google/go-cmp v0.5.5/go.mod h1:v8dTdLbMG2kIc/vJvl+f65V22dbkXbowE6jgT/gNBxE=
+github.com/google/uuid v1.6.0 h1:NIvaJDMOsjHA8n1jAhLSgzrAzy1Hgr+hNrb57e+94F0=
+github.com/google/uuid v1.6.0/go.mod h1:TIyPZe4MgqvfeYDBFedMoGGpEw/LqOeaOT+nhxU+yHo=
+github.com/pmezard/go-difflib v1.0.0 h1:4DBwDE0NGyQoBHbLQYPwSUPoCMWR5BEzIk/f1lZbAQM=
+github.com/pmezard/go-difflib v1.0.0/go.mod h1:iKH77koFhYxTK1pcRnkKkqfTogsbg7gZNVY4sRDYZ/4=
+github.com/stretchr/testify v1.11.1 h1:7s2iGBzp5EwR7/aIZr8ao5+dra3wiQyKjjFuvgVKu7U=
+github.com/stretchr/testify v1.11.1/go.mod h1:wZwfW3scLgRK+23gO65QZefKpKQRnfz6sD981Nm4B6U=
+go.wit.com/dev/alexflint/arg v1.6.4 h1:DE5LUzanP6by4xkrV1sIqkvgfWxcqz0evwVPZoUE/Q0=
+go.wit.com/dev/alexflint/arg v1.6.4/go.mod h1:RKOrAnxFl+856vbfvMEYcdd4qgBq2ZEO8atUcINendY=
+go.wit.com/gui v0.25.4 h1:JpeU9qKVKpVAZv0mbpBqcm9zrS9wuo0bfKJa5K9/udg=
+go.wit.com/gui v0.25.4/go.mod h1:yOhOaGk2496Lrq7qvNwU0T2uKSnwxYgD1hHUuLIZ1BQ=
+go.wit.com/lib/fhelp v0.0.24 h1:4UhVLRKE7TBCPeCKeihBQ8ReM78VELyDXkYt5w5yyKs=
+go.wit.com/lib/fhelp v0.0.24/go.mod h1:8lRn3kJUuxkhief0JjbxL/ydw06ZJx/HLw7eMx9Xx9Y=
+go.wit.com/lib/gui/shell v0.22.33 h1:3MvWBQU4rOHK4Ac5MkQ62ndW7WhCBpu9F3AVeUF7YgQ=
+go.wit.com/lib/gui/shell v0.22.33/go.mod h1:aRDwKXKXkZaO4y/0KPe1lhKQCXpyi8hXgUEOrHhzpAI=
+go.wit.com/lib/protobuf/guipb v0.0.17 h1:CIszLmWl21EjvcyaQ46HPTma6nJdRuOdErn0rRP1Zo4=
+go.wit.com/lib/protobuf/guipb v0.0.17/go.mod h1:9AzFoNKnE0161IOTfdul6SX5+GPAFNW7RPKWohenmcQ=
+go.wit.com/log v0.25.1 h1:74WVf9NSN6z5jc2oSbA1ehxdZ7V/NBXTk5t0jIoaTMg=
+go.wit.com/log v0.25.1/go.mod h1:XE4lTfAibWgwBJksIk7u3IEJ8xcBvNhnlewYAQGj2Ew=
+go.wit.com/widget v1.1.30 h1:O/dIG7QtDrZkR5P6f8JAMyevBiMXSun9vL6F0KFAWV8=
+go.wit.com/widget v1.1.30/go.mod h1:wj7TpAr2gk7Poa+v8XQkH1aidnTdgAa/a8GxrMtcztw=
+golang.org/x/text v0.29.0 h1:1neNs90w9YzJ9BocxfsQNHKuAT4pkghyXc4nhZ6sJvk=
+golang.org/x/text v0.29.0/go.mod h1:7MhJOA9CD2qZyOKYazxdYMF85OwPdEr9jTtBpO7ydH4=
+golang.org/x/xerrors v0.0.0-20191204190536-9bdfabe68543 h1:E7g+9GITq07hpfrRu66IVDexMakfv52eLZ2CXBWiKr4=
+golang.org/x/xerrors v0.0.0-20191204190536-9bdfabe68543/go.mod h1:I/5z698sn9Ka8TeJc9MKroUUfqBBauWjQqLJ2OPfmY0=
+google.golang.org/protobuf v1.36.9 h1:w2gp2mA27hUeUzj9Ex9FBjsBm40zfaDtEWow293U7Iw=
+google.golang.org/protobuf v1.36.9/go.mod h1:fuxRtAxBytpl4zzqUh6/eyUujkJdNiuEkXntxiD/uRU=
+gopkg.in/yaml.v3 v3.0.1 h1:fxVm/GzAzEWqLHuvctI91KS9hhNmmWOoWu0XTYJS7CA=
+gopkg.in/yaml.v3 v3.0.1/go.mod h1:K4uyk7z7BCEPqu6E+C64Yfv1cQ7kz7rIZviUmN+EgEM=