2024-11-29 15:19:04 -06:00
|
|
|
package main
|
|
|
|
|
|
|
|
import (
|
|
|
|
"fmt"
|
|
|
|
"io"
|
2024-11-29 15:27:56 -06:00
|
|
|
"os"
|
|
|
|
"strings"
|
2025-01-09 15:29:27 -06:00
|
|
|
|
|
|
|
"go.wit.com/log"
|
2024-11-29 15:19:04 -06:00
|
|
|
)
|
|
|
|
|
2025-01-09 05:20:00 -06:00
|
|
|
// passes in the protobuf file protobuf
|
|
|
|
func (pb *Files) makeSortfile(pf *File) {
|
|
|
|
f, _ := os.OpenFile(pf.Filebase+".sort.pb.go", os.O_WRONLY|os.O_CREATE|os.O_TRUNC, 0644)
|
2024-11-29 15:27:56 -06:00
|
|
|
|
2025-01-09 12:54:04 -06:00
|
|
|
// header(f, pf)
|
2024-12-01 00:46:06 -06:00
|
|
|
|
2025-01-09 12:54:04 -06:00
|
|
|
// pf.iterTop(f, sortmap["base"])
|
|
|
|
// iterNext(f, sortmap)
|
2024-11-29 17:31:49 -06:00
|
|
|
iterAppend(f, sortmap) // Append() enforce no unique keys
|
|
|
|
iterSortAll(f, sortmap)
|
|
|
|
|
|
|
|
if argv.Append != "" {
|
2024-11-30 12:17:38 -06:00
|
|
|
sortmap["append"] = string(argv.Append)
|
|
|
|
iterAppend(f, sortmap) // Append() enforce unique key argv.Append
|
2024-11-29 17:31:49 -06:00
|
|
|
}
|
|
|
|
|
2024-11-30 15:06:57 -06:00
|
|
|
for _, s := range uniqueKeys {
|
2024-12-01 22:21:09 -06:00
|
|
|
// log.Info("found unique key in .proto", s)
|
2024-11-30 15:06:57 -06:00
|
|
|
sortmap["sortBy"] = s
|
|
|
|
sortmap["sortKey"] = s
|
|
|
|
|
|
|
|
iterSortBy(f, sortmap)
|
|
|
|
|
|
|
|
sortmap["append"] = sortmap["sortKey"]
|
|
|
|
iterAppend(f, sortmap) // Append() enforce unique key argv.Append
|
|
|
|
|
|
|
|
iterDelete(f, sortmap)
|
|
|
|
iterReplace(f, sortmap)
|
|
|
|
iterFind(f, sortmap)
|
|
|
|
}
|
|
|
|
|
2024-11-29 17:31:49 -06:00
|
|
|
for _, s := range argv.Sort {
|
|
|
|
sortparts := strings.Split(s, ",")
|
2024-11-29 15:27:56 -06:00
|
|
|
sortmap["sortBy"] = sortparts[0]
|
|
|
|
sortmap["sortKey"] = sortparts[1]
|
|
|
|
|
2024-11-29 17:31:49 -06:00
|
|
|
iterSortBy(f, sortmap)
|
2024-11-29 15:27:56 -06:00
|
|
|
|
|
|
|
sortmap["append"] = sortmap["sortKey"]
|
|
|
|
iterAppend(f, sortmap) // Append() enforce unique key argv.Append
|
|
|
|
|
|
|
|
iterDelete(f, sortmap)
|
|
|
|
iterReplace(f, sortmap)
|
2024-11-29 17:45:17 -06:00
|
|
|
iterFind(f, sortmap)
|
2024-11-29 15:27:56 -06:00
|
|
|
}
|
|
|
|
iterEnd(f, sortmap)
|
|
|
|
}
|
|
|
|
|
2025-01-09 15:29:27 -06:00
|
|
|
func (pf *File) syncLock(w io.Writer) {
|
|
|
|
if pf.Bases == nil {
|
|
|
|
log.Info("BASES == nil in syncLock")
|
|
|
|
return
|
|
|
|
}
|
|
|
|
var LOCK string = pf.Bases.Lockname
|
2025-01-09 06:47:35 -06:00
|
|
|
|
|
|
|
fmt.Fprintln(w, "// bad global lock until modifying the .pb.go file is tested")
|
2024-11-29 15:19:04 -06:00
|
|
|
fmt.Fprintln(w, "// sync.RWMutex or sync.Mutex?")
|
2025-01-09 06:47:35 -06:00
|
|
|
fmt.Fprintln(w, "var "+LOCK+" sync.RWMutex")
|
2024-11-29 15:19:04 -06:00
|
|
|
fmt.Fprintln(w, "")
|
|
|
|
}
|
|
|
|
|
2025-01-09 15:29:27 -06:00
|
|
|
func (msg *MsgName) iterTop(w io.Writer) {
|
|
|
|
var BASE string = msg.Name
|
|
|
|
|
2025-01-09 06:47:35 -06:00
|
|
|
fmt.Fprintln(w, "type "+BASE+"Iterator struct {")
|
2024-11-29 15:19:04 -06:00
|
|
|
fmt.Fprintln(w, " sync.RWMutex")
|
|
|
|
fmt.Fprintln(w, "")
|
2025-01-09 06:47:35 -06:00
|
|
|
fmt.Fprintln(w, " things []*"+BASE)
|
2024-11-29 15:19:04 -06:00
|
|
|
fmt.Fprintln(w, " index int")
|
|
|
|
fmt.Fprintln(w, "}")
|
|
|
|
fmt.Fprintln(w, "")
|
2025-01-09 06:47:35 -06:00
|
|
|
fmt.Fprintln(w, "// New"+BASE+"Iterator initializes a new iterator.")
|
|
|
|
fmt.Fprintln(w, "func New"+BASE+"Iterator(things []*"+BASE+") *"+BASE+"Iterator {")
|
|
|
|
fmt.Fprintln(w, " return &"+BASE+"Iterator{things: things}")
|
2024-11-29 15:19:04 -06:00
|
|
|
fmt.Fprintln(w, "}")
|
|
|
|
fmt.Fprintln(w, "")
|
2024-12-27 14:43:21 -06:00
|
|
|
fmt.Fprintln(w, "// Scan moves to the next element and returns false if there are no more things.")
|
2024-11-29 15:19:04 -06:00
|
|
|
fmt.Fprintln(w, "// Use Scan() in a loop, similar to a while loop")
|
|
|
|
fmt.Fprintln(w, "//")
|
|
|
|
fmt.Fprintln(w, "// for iterator.Scan() ")
|
|
|
|
fmt.Fprintln(w, "// d := iterator.Next(")
|
|
|
|
fmt.Fprintln(w, "// fmt.Println(\"found UUID:\", d.Uuid")
|
|
|
|
fmt.Fprintln(w, "// }")
|
2025-01-09 06:47:35 -06:00
|
|
|
fmt.Fprintln(w, "func (it *"+BASE+"Iterator) Scan() bool {")
|
2024-12-27 14:43:21 -06:00
|
|
|
fmt.Fprintln(w, " if it.index >= len(it.things) {")
|
2024-11-29 15:19:04 -06:00
|
|
|
fmt.Fprintln(w, " return false")
|
|
|
|
fmt.Fprintln(w, " }")
|
|
|
|
fmt.Fprintln(w, " it.index++")
|
|
|
|
fmt.Fprintln(w, " return true")
|
|
|
|
fmt.Fprintln(w, "}")
|
|
|
|
fmt.Fprintln(w, "")
|
|
|
|
}
|
|
|
|
|
2025-01-09 15:29:27 -06:00
|
|
|
func (msg *MsgName) iterNext(w io.Writer) {
|
|
|
|
var BASE string = msg.Name
|
|
|
|
|
2024-11-29 15:19:04 -06:00
|
|
|
fmt.Fprintln(w, "// Next() returns the next thing in the array")
|
2025-01-09 12:54:04 -06:00
|
|
|
fmt.Fprintln(w, "func (it *"+BASE+"Iterator) Next() *"+BASE+" {")
|
2024-12-27 14:43:21 -06:00
|
|
|
fmt.Fprintln(w, " if it.things[it.index-1] == nil {")
|
|
|
|
fmt.Fprintln(w, " for i, d := range it.things {")
|
2024-11-29 15:19:04 -06:00
|
|
|
fmt.Fprintln(w, " fmt.Println(\"i =\", i, d)")
|
|
|
|
fmt.Fprintln(w, " }")
|
2024-12-27 14:43:21 -06:00
|
|
|
fmt.Fprintln(w, " // fmt.Println(\"protobuf autogenpb sort error len =\", len(it.things))")
|
2024-12-14 16:27:29 -06:00
|
|
|
fmt.Fprintln(w, " // fmt.Println(\"protobuf autogenpb sort error next == nil\", it.index, it.index-1)")
|
2024-11-29 15:19:04 -06:00
|
|
|
fmt.Fprintln(w, " }")
|
2024-12-27 14:43:21 -06:00
|
|
|
fmt.Fprintln(w, " return it.things[it.index-1]")
|
2024-11-29 15:19:04 -06:00
|
|
|
fmt.Fprintln(w, "}")
|
|
|
|
fmt.Fprintln(w, "")
|
|
|
|
}
|
|
|
|
|
2024-11-29 17:31:49 -06:00
|
|
|
func iterSortAll(w io.Writer, names map[string]string) {
|
2024-11-29 15:19:04 -06:00
|
|
|
fmt.Fprintln(w, "func (all *"+names["Bases"]+") All() *"+names["Base"]+"Iterator {")
|
|
|
|
fmt.Fprintln(w, " "+names["base"]+"Pointers := all.selectAll"+names["Base"]+"()")
|
|
|
|
fmt.Fprintln(w, "")
|
|
|
|
fmt.Fprintln(w, " iterator := New"+names["Base"]+"Iterator("+names["base"]+"Pointers)")
|
|
|
|
fmt.Fprintln(w, " return iterator")
|
|
|
|
fmt.Fprintln(w, "}")
|
|
|
|
fmt.Fprintln(w, "")
|
2024-11-29 17:31:49 -06:00
|
|
|
fmt.Fprintln(w, "func (all *"+names["Bases"]+") Len() int {")
|
2024-12-01 10:42:12 -06:00
|
|
|
if sortmap["lock"] == "all" {
|
|
|
|
fmt.Fprintln(w, " "+names["lock"]+".Lock.RLock()")
|
|
|
|
fmt.Fprintln(w, " defer "+names["lock"]+".Lock.RUnlock()")
|
|
|
|
} else {
|
|
|
|
fmt.Fprintln(w, " "+names["lock"]+".RLock()")
|
|
|
|
fmt.Fprintln(w, " defer "+names["lock"]+".RUnlock()")
|
|
|
|
}
|
2024-11-29 17:31:49 -06:00
|
|
|
fmt.Fprintln(w, "")
|
|
|
|
fmt.Fprintln(w, " return len(all."+names["Bases"]+")")
|
|
|
|
fmt.Fprintln(w, "}")
|
|
|
|
fmt.Fprintln(w, "")
|
|
|
|
}
|
|
|
|
|
|
|
|
func iterSortBy(w io.Writer, names map[string]string) {
|
2024-11-30 15:06:57 -06:00
|
|
|
fmt.Fprintln(w, "func (all *"+names["Bases"]+") SortBy"+names["sortBy"]+"() *"+names["Base"]+"Iterator {")
|
2024-12-27 14:43:21 -06:00
|
|
|
fmt.Fprintln(w, " things := all.selectAll"+names["Base"]+"()")
|
2024-11-29 15:19:04 -06:00
|
|
|
fmt.Fprintln(w, "")
|
2024-12-27 14:43:21 -06:00
|
|
|
fmt.Fprintln(w, " sort.Sort("+names["Base"]+""+names["sortBy"]+"(things))")
|
2024-11-29 15:19:04 -06:00
|
|
|
fmt.Fprintln(w, "")
|
2024-12-27 14:43:21 -06:00
|
|
|
fmt.Fprintln(w, " iterator := New"+names["Base"]+"Iterator(things)")
|
2024-11-29 15:19:04 -06:00
|
|
|
fmt.Fprintln(w, " return iterator")
|
|
|
|
fmt.Fprintln(w, "}")
|
|
|
|
fmt.Fprintln(w, "")
|
|
|
|
|
|
|
|
fmt.Fprintln(w, "type "+names["Base"]+""+names["sortBy"]+" []*"+names["Base"]+"")
|
|
|
|
fmt.Fprintln(w, "")
|
|
|
|
fmt.Fprintln(w, "func (a "+names["Base"]+""+names["sortBy"]+") Len() int { return len(a) }")
|
|
|
|
fmt.Fprintln(w, "func (a "+names["Base"]+""+names["sortBy"]+") Less(i, j int) bool { return a[i]."+names["sortKey"]+" < a[j]."+names["sortKey"]+" }")
|
|
|
|
fmt.Fprintln(w, "func (a "+names["Base"]+""+names["sortBy"]+") Swap(i, j int) { a[i], a[j] = a[j], a[i] }")
|
|
|
|
fmt.Fprintln(w, "")
|
2024-11-29 17:31:49 -06:00
|
|
|
}
|
|
|
|
|
|
|
|
func iterEnd(w io.Writer, names map[string]string) {
|
2024-11-29 15:19:04 -06:00
|
|
|
fmt.Fprintln(w, "// safely returns a slice of pointers to the "+names["Base"]+" protobufs")
|
|
|
|
fmt.Fprintln(w, "func (all *"+names["Bases"]+") selectAll"+names["Base"]+"() []*"+names["Base"]+" {")
|
2024-12-01 10:42:12 -06:00
|
|
|
if sortmap["lock"] == "all" {
|
|
|
|
fmt.Fprintln(w, " "+names["lock"]+".Lock.RLock()")
|
|
|
|
fmt.Fprintln(w, " defer "+names["lock"]+".Lock.RUnlock()")
|
|
|
|
} else {
|
|
|
|
fmt.Fprintln(w, " "+names["lock"]+".RLock()")
|
|
|
|
fmt.Fprintln(w, " defer "+names["lock"]+".RUnlock()")
|
|
|
|
}
|
2024-11-29 15:19:04 -06:00
|
|
|
fmt.Fprintln(w, "")
|
|
|
|
fmt.Fprintln(w, " // Create a new slice to hold pointers to each "+names["Base"]+"")
|
|
|
|
fmt.Fprintln(w, " var aStuff []*"+names["Base"]+"")
|
|
|
|
fmt.Fprintln(w, " aStuff = make([]*"+names["Base"]+", len(all."+names["Bases"]+"))")
|
|
|
|
fmt.Fprintln(w, " for i, p := range all."+names["Bases"]+" {")
|
|
|
|
fmt.Fprintln(w, " aStuff[i] = p // Copy pointers for safe iteration")
|
|
|
|
fmt.Fprintln(w, " }")
|
|
|
|
fmt.Fprintln(w, "")
|
|
|
|
fmt.Fprintln(w, " return aStuff")
|
|
|
|
fmt.Fprintln(w, "}")
|
|
|
|
}
|
|
|
|
|
|
|
|
func iterAppend(w io.Writer, names map[string]string) {
|
2025-01-09 12:54:04 -06:00
|
|
|
}
|
|
|
|
|
2025-01-09 16:18:06 -06:00
|
|
|
func (pf *File) appendUnique(w io.Writer) {
|
2025-01-09 15:51:45 -06:00
|
|
|
var MSG string = pf.Bases.Name
|
2025-01-09 16:18:06 -06:00
|
|
|
var BASE string = pf.Base.Name
|
2025-01-09 15:51:45 -06:00
|
|
|
var LOCK string = pf.Bases.Lockname
|
|
|
|
|
2025-01-09 12:54:04 -06:00
|
|
|
if argv.Mutex {
|
2025-01-09 16:02:53 -06:00
|
|
|
// use the mutex lock from the modified protoc.pb.go file
|
2025-01-09 15:51:45 -06:00
|
|
|
LOCK = "all.Lock"
|
2025-01-09 16:02:53 -06:00
|
|
|
} else {
|
|
|
|
LOCK = pf.Bases.Lockname
|
2024-12-01 10:42:12 -06:00
|
|
|
}
|
2025-01-09 12:54:04 -06:00
|
|
|
|
|
|
|
fmt.Fprintln(w, "// enforces "+BASE+" is unique")
|
|
|
|
fmt.Fprintln(w, "func (all *"+MSG+") AppendUnique(newP *"+BASE+") bool {")
|
|
|
|
fmt.Fprintln(w, " "+LOCK+".RLock()")
|
|
|
|
fmt.Fprintln(w, " defer "+LOCK+".RUnlock()")
|
2024-11-29 15:19:04 -06:00
|
|
|
fmt.Fprintln(w, "")
|
2025-01-09 12:54:04 -06:00
|
|
|
fmt.Fprintln(w, " for _, p := range all."+MSG+" {")
|
2025-01-09 15:51:45 -06:00
|
|
|
for _, KEY := range pf.Base.Unique {
|
2025-01-09 12:54:04 -06:00
|
|
|
fmt.Fprintln(w, " if p."+KEY+" == newP."+KEY+" {")
|
2024-11-29 15:19:04 -06:00
|
|
|
fmt.Fprintln(w, " return false")
|
|
|
|
fmt.Fprintln(w, " }")
|
|
|
|
}
|
2025-01-09 12:54:04 -06:00
|
|
|
fmt.Fprintln(w, " }")
|
|
|
|
fmt.Fprintln(w, "")
|
|
|
|
fmt.Fprintln(w, " all."+MSG+" = append(all."+MSG+", newP)")
|
2024-11-29 15:19:04 -06:00
|
|
|
fmt.Fprintln(w, " return true")
|
|
|
|
fmt.Fprintln(w, "}")
|
|
|
|
fmt.Fprintln(w, "")
|
2025-01-09 15:51:45 -06:00
|
|
|
|
|
|
|
for _, KEY := range pf.Base.Unique {
|
|
|
|
fmt.Fprintln(w, "// enforces "+BASE+" is unique")
|
|
|
|
fmt.Fprintln(w, "func (all *"+MSG+") AppendUnique"+KEY+"(newP *"+BASE+") bool {")
|
|
|
|
fmt.Fprintln(w, " "+LOCK+".RLock()")
|
|
|
|
fmt.Fprintln(w, " defer "+LOCK+".RUnlock()")
|
|
|
|
fmt.Fprintln(w, "")
|
|
|
|
fmt.Fprintln(w, " for _, p := range all."+MSG+" {")
|
|
|
|
fmt.Fprintln(w, " if p."+KEY+" == newP."+KEY+" {")
|
|
|
|
fmt.Fprintln(w, " return false")
|
|
|
|
fmt.Fprintln(w, " }")
|
|
|
|
fmt.Fprintln(w, " }")
|
|
|
|
fmt.Fprintln(w, "")
|
|
|
|
fmt.Fprintln(w, " all."+MSG+" = append(all."+MSG+", newP)")
|
|
|
|
fmt.Fprintln(w, " return true")
|
|
|
|
fmt.Fprintln(w, "}")
|
|
|
|
fmt.Fprintln(w, "")
|
|
|
|
}
|
2024-11-29 15:19:04 -06:00
|
|
|
}
|
|
|
|
|
|
|
|
func iterReplace(w io.Writer, names map[string]string) {
|
|
|
|
if names["append"] == "" {
|
|
|
|
// can't continue without a key field
|
|
|
|
}
|
|
|
|
fmt.Fprintln(w, "// enforces "+names["append"]+" is unique")
|
|
|
|
fmt.Fprintln(w, "func (all *"+names["Bases"]+") Replace"+names["append"]+"(newP *"+names["Base"]+") bool { // todo: make unique name here")
|
|
|
|
|
2024-12-01 10:42:12 -06:00
|
|
|
if sortmap["lock"] == "all" {
|
|
|
|
fmt.Fprintln(w, " "+names["lock"]+".Lock.RLock()")
|
|
|
|
fmt.Fprintln(w, " defer "+names["lock"]+".Lock.RUnlock()")
|
|
|
|
} else {
|
|
|
|
fmt.Fprintln(w, " "+names["lock"]+".RLock()")
|
|
|
|
fmt.Fprintln(w, " defer "+names["lock"]+".RUnlock()")
|
|
|
|
}
|
2024-11-29 15:19:04 -06:00
|
|
|
fmt.Fprintln(w, "")
|
|
|
|
fmt.Fprintln(w, " for _, p := range all."+names["Bases"]+" {")
|
|
|
|
fmt.Fprintln(w, " if p."+names["append"]+" == newP."+names["append"]+" {")
|
|
|
|
fmt.Fprintln(w, " return false")
|
|
|
|
fmt.Fprintln(w, " }")
|
|
|
|
fmt.Fprintln(w, " }")
|
|
|
|
fmt.Fprintln(w, "")
|
|
|
|
fmt.Fprintln(w, " all."+names["Bases"]+" = append(all."+names["Bases"]+", newP)")
|
|
|
|
fmt.Fprintln(w, " return true")
|
|
|
|
fmt.Fprintln(w, "}")
|
|
|
|
fmt.Fprintln(w, "")
|
|
|
|
}
|
|
|
|
|
|
|
|
func iterDelete(w io.Writer, names map[string]string) {
|
2024-11-30 23:20:10 -06:00
|
|
|
fmt.Fprintln(w, "func (all *"+names["Bases"]+") DeleteBy"+names["append"]+"(s string) bool {")
|
2024-12-01 10:42:12 -06:00
|
|
|
if sortmap["lock"] == "all" {
|
|
|
|
fmt.Fprintln(w, " "+names["lock"]+".Lock.RLock()")
|
|
|
|
fmt.Fprintln(w, " defer "+names["lock"]+".Lock.RUnlock()")
|
|
|
|
} else {
|
|
|
|
fmt.Fprintln(w, " "+names["lock"]+".RLock()")
|
|
|
|
fmt.Fprintln(w, " defer "+names["lock"]+".RUnlock()")
|
|
|
|
}
|
2024-11-30 23:20:10 -06:00
|
|
|
fmt.Fprintln(w, "")
|
|
|
|
fmt.Fprintln(w, " for i, _ := range all."+names["Bases"]+" {")
|
|
|
|
fmt.Fprintln(w, " if all."+names["Bases"]+"[i]."+names["append"]+" == s {")
|
|
|
|
fmt.Fprintln(w, " all."+names["Bases"]+"[i] = all."+names["Bases"]+"[len(all."+names["Bases"]+")-1]")
|
|
|
|
fmt.Fprintln(w, " all."+names["Bases"]+" = all."+names["Bases"]+"[:len(all."+names["Bases"]+")-1]")
|
|
|
|
fmt.Fprintln(w, " return true")
|
|
|
|
fmt.Fprintln(w, " }")
|
|
|
|
fmt.Fprintln(w, " }")
|
|
|
|
fmt.Fprintln(w, " return false")
|
|
|
|
fmt.Fprintln(w, "}")
|
|
|
|
fmt.Fprintln(w, "")
|
|
|
|
}
|
|
|
|
|
|
|
|
// this tries to return the deleted one but is wrong/gives warning if mutex lock is in struct
|
|
|
|
func iterDeleteWithCopy(w io.Writer, names map[string]string) {
|
2024-11-29 15:19:04 -06:00
|
|
|
fmt.Fprintln(w, "func (all *"+names["Bases"]+") DeleteBy"+names["append"]+"(s string) *"+names["Base"]+" {")
|
2024-12-01 10:42:12 -06:00
|
|
|
if sortmap["lock"] == "all" {
|
|
|
|
fmt.Fprintln(w, " "+names["lock"]+".Lock.RLock()")
|
|
|
|
fmt.Fprintln(w, " defer "+names["lock"]+".Lock.RUnlock()")
|
|
|
|
} else {
|
|
|
|
fmt.Fprintln(w, " "+names["lock"]+".RLock()")
|
|
|
|
fmt.Fprintln(w, " defer "+names["lock"]+".RUnlock()")
|
|
|
|
}
|
2024-11-29 15:19:04 -06:00
|
|
|
fmt.Fprintln(w, "")
|
|
|
|
fmt.Fprintln(w, " var newr "+names["Base"])
|
|
|
|
fmt.Fprintln(w, "")
|
|
|
|
fmt.Fprintln(w, " for i, _ := range all."+names["Bases"]+" {")
|
|
|
|
fmt.Fprintln(w, " if all."+names["Bases"]+"[i]."+names["append"]+" == s {")
|
|
|
|
fmt.Fprintln(w, " newr = *all."+names["Bases"]+"[i]")
|
|
|
|
fmt.Fprintln(w, " all."+names["Bases"]+"[i] = all."+names["Bases"]+"[len(all."+names["Bases"]+")-1]")
|
|
|
|
fmt.Fprintln(w, " all."+names["Bases"]+" = all."+names["Bases"]+"[:len(all."+names["Bases"]+")-1]")
|
|
|
|
fmt.Fprintln(w, " return &newr")
|
|
|
|
fmt.Fprintln(w, " }")
|
|
|
|
fmt.Fprintln(w, " }")
|
|
|
|
fmt.Fprintln(w, " return nil")
|
|
|
|
fmt.Fprintln(w, "}")
|
|
|
|
fmt.Fprintln(w, "")
|
|
|
|
}
|
2024-11-29 17:45:17 -06:00
|
|
|
|
|
|
|
func iterFind(w io.Writer, names map[string]string) {
|
|
|
|
fmt.Fprintln(w, "// find a dependancy by the go path")
|
|
|
|
fmt.Fprintln(w, "func (all *"+names["Bases"]+") FindBy"+names["append"]+"(s string) *"+names["Base"]+" {")
|
2024-12-01 16:43:08 -06:00
|
|
|
fmt.Fprintln(w, " if all == nil {")
|
|
|
|
fmt.Fprintln(w, " return nil")
|
|
|
|
fmt.Fprintln(w, " }")
|
|
|
|
fmt.Fprintln(w, "")
|
2024-12-01 10:42:12 -06:00
|
|
|
if sortmap["lock"] == "all" {
|
|
|
|
fmt.Fprintln(w, " "+names["lock"]+".Lock.RLock()")
|
|
|
|
fmt.Fprintln(w, " defer "+names["lock"]+".Lock.RUnlock()")
|
|
|
|
} else {
|
|
|
|
fmt.Fprintln(w, " "+names["lock"]+".RLock()")
|
|
|
|
fmt.Fprintln(w, " defer "+names["lock"]+".RUnlock()")
|
|
|
|
}
|
2024-11-29 17:45:17 -06:00
|
|
|
fmt.Fprintln(w, "")
|
|
|
|
fmt.Fprintln(w, " for i, _ := range all."+names["Bases"]+" {")
|
|
|
|
fmt.Fprintln(w, " if all."+names["Bases"]+"[i]."+names["append"]+" == s {")
|
|
|
|
fmt.Fprintln(w, " return all."+names["Bases"]+"[i]")
|
|
|
|
fmt.Fprintln(w, " }")
|
|
|
|
fmt.Fprintln(w, " }")
|
|
|
|
fmt.Fprintln(w, " return nil")
|
|
|
|
fmt.Fprintln(w, "}")
|
|
|
|
fmt.Fprintln(w, "")
|
|
|
|
}
|