lucked out. compiled and ran and worked on the first pass

This commit is contained in:
Jeff Carr 2025-01-10 21:33:00 -06:00
parent 47a7163ff3
commit 6ce9c29135
4 changed files with 89 additions and 40 deletions

View File

@ -109,10 +109,10 @@ func (pb *Fruits) addThings() {
tmp := new(Fruit) tmp := new(Fruit)
tmp.Brand = name tmp.Brand = name
tmp.City = "paris" tmp.City = "paris"
if pb.AppendUniqueBrand(tmp) { if pb.AppendUniqueByBrand(tmp) {
// log.Printf("AppendUniqueBrand() ok len=%s %s %d\n", tmp.Brand, tmp.City, pb.Len()) // log.Printf("AppendUniqueBrand() ok len=%s %s %d\n", tmp.Brand, tmp.City, pb.Len())
} else { } else {
log.Printf("AppendUniqueBrand() ERROR len=%s %s %d\n", tmp.Brand, tmp.City, pb.Len()) log.Printf("AppendUniqueByBrand() ERROR len=%s %s %d\n", tmp.Brand, tmp.City, pb.Len())
os.Exit(-1) os.Exit(-1)
} }
pb.Append(tmp) pb.Append(tmp)

75
sort.go
View File

@ -35,75 +35,84 @@ func (pb *Files) makeNewSortfile(pf *File) error {
pf.selectAllFunc(wSort) pf.selectAllFunc(wSort)
pf.iterSelect(wSort) pf.iterSelect(wSort)
pf.appendUnique(wFind) // Append() enforce no unique keys
pf.sortByFunc(wSort) pf.sortByFunc(wSort)
if argv.Delete {
pf.deleteWithCopyFunc(wFind) /*
} else { pf.appendUnique(wFind) // Append() enforce no unique keys
pf.deleteFunc(wFind) if argv.Delete {
} pf.deleteWithCopyFunc(wFind)
pf.findFunc(wFind) } else {
pf.deleteFunc(wFind)
}
pf.findFunc(wFind)
*/
// attempt to add sort functions for pf.Base // attempt to add sort functions for pf.Base
pf.processMessage(pf.Bases, wSort, wFind) pf.processMessage(pf.Bases, wSort, wFind)
// pf.processMessage(pf.Base, wSort, wFind) pf.processMessage(pf.Base, wSort, wFind)
return nil return nil
} }
func (pf *File) processMessage(msg *MsgName, wSort, wFind io.Writer) error { func (pf *File) processMessage(msg *MsgName, wSort, wFind io.Writer) error {
log.Printf("Generating functions for %s\n", msg.Name) var FRUIT string = cases.Title(language.English, cases.NoLower).String(msg.Name)
log.Printf("Generating functions for %s\n", FRUIT)
for _, v := range msg.Vars { for _, v := range msg.Vars {
if !v.IsRepeated { if !v.IsRepeated {
log.Printf("\tSKIP %s %s\n", v.VarName, v.VarType) log.Printf("\tSKIP %s %s\n", v.VarName, v.VarType)
continue continue
} }
if err := pf.addSortByMsg(msg, v, wSort, wFind); err != nil { // use easier to read variable names APPLE and APPLES in the code
return err var APPLE string = v.VarType
var APPLES string = cases.Title(language.English, cases.NoLower).String(v.VarName)
// try and find the message struct for APPLE
var found *MsgName
for _, m := range pf.MsgNames {
if m.Name == APPLE {
found = m
break
}
} }
if found == nil {
return fmt.Errorf("failed to find struct %s", APPLE)
}
found.addSortByMsg(FRUIT, APPLES, APPLE, wSort, wFind)
} }
return nil return nil
} }
func (pf *File) addSortByMsg(parent *MsgName, find *MsgVar, wSort, wFind io.Writer) error { func (parent *MsgName) addSortByMsg(FRUIT, APPLES, APPLE string, wSort, wFind io.Writer) error {
log.Printf("\tLOOK HERE: %s %s\n", find.VarName, find.VarType) log.Printf("\tFOUND!: %s %s for %s\n", APPLES, APPLE, FRUIT)
var found *MsgName
for _, msg := range pf.MsgNames {
if msg.Name == find.VarType {
found = msg
break
}
}
if found == nil {
return fmt.Errorf("failed to find struct %s", find.VarType)
}
log.Printf("FOUND!: %s %s for %s\n", find.VarName, find.VarType, found.Name)
var COLORS []string var COLORS []string
var FRUIT string = parent.Name
var APPLES string = cases.Title(language.English, cases.NoLower).String(find.VarName)
var APPLE string = find.VarType
for _, v := range found.Vars { for _, v := range parent.Vars {
if v.HasSort { if v.HasSort {
// log.Printf("\tSort!: %s %s for %s\n", find.VarName, find.VarType, v.VarName) // log.Printf("\tSort!: %s %s for %s\n", APPLES, APPLE, v.VarName)
newS := cases.Title(language.English, cases.NoLower).String(v.VarName) newS := cases.Title(language.English, cases.NoLower).String(v.VarName)
log.Printf("\t(x %s) SortdBy%s() *%sIter\n", parent.Name, newS, find.VarType) log.Printf("\t(x %s) SortdBy%s() *%sIter\n", parent.Name, newS, APPLE)
} }
if v.HasUnique { if v.HasUnique {
newS := cases.Title(language.English, cases.NoLower).String(v.VarName) newS := cases.Title(language.English, cases.NoLower).String(v.VarName)
var COLOR string = newS var COLOR string = newS
COLORS = append(COLORS, COLOR) COLORS = append(COLORS, COLOR)
log.Printf("\t(x %s) AppendUniqueBy%s(%s)\n", parent.Name, newS, find.VarType) log.Printf("\t(x %s) AppendUniqueBy%s(%s)\n", parent.Name, newS, APPLE)
parent.appendUniqueBy(wFind, FRUIT, APPLES, APPLE, COLOR) parent.appendUniqueBy(wFind, FRUIT, APPLES, APPLE, COLOR)
if v.VarType == "string" { if v.VarType == "string" {
log.Printf("\t(x %s) FindBy%s(string) *%s\n", FRUIT, COLOR, APPLE) log.Printf("\t(x %s) FindBy%s(string) *%s\n", FRUIT, COLOR, APPLE)
parent.findBy(wFind, FRUIT, APPLES, APPLE, COLOR) parent.findBy(wFind, FRUIT, APPLES, APPLE, COLOR)
log.Printf("\t(x %s) DeleteBy%s(string) *%s\n", parent.Name, newS, find.VarType) log.Printf("\t(x %s) DeleteBy%s(string) *%s\n", parent.Name, newS, APPLE)
parent.deleteBy(wFind, FRUIT, APPLES, APPLE, COLOR) if argv.Delete {
parent.deleteByWithCopy(wFind, FRUIT, APPLES, APPLE, COLOR)
} else {
parent.deleteBy(wFind, FRUIT, APPLES, APPLE, COLOR)
}
} }
} }
} }
parent.insertByColors(wFind, FRUIT, APPLES, APPLE, COLORS)
if len(COLORS) > 0 { if len(COLORS) > 0 {
parent.appendUnique(wFind, FRUIT, APPLES, APPLE, COLORS) parent.appendUnique(wFind, FRUIT, APPLES, APPLE, COLORS)
} }

View File

@ -127,7 +127,7 @@ func (pf *File) iterSelect(w io.Writer) {
fmt.Fprintln(w, "}") fmt.Fprintln(w, "}")
} }
func (pf *File) appendUnique(w io.Writer) { func (pf *File) appendUniqueOld(w io.Writer) {
var MSG string = pf.Bases.Name var MSG string = pf.Bases.Name
var BASE string = pf.Base.Name var BASE string = pf.Base.Name
var LOCK string = pf.Bases.Lockname var LOCK string = pf.Bases.Lockname

View File

@ -14,6 +14,46 @@ func (msg *MsgName) getLockname(s string) string {
return msg.Lockname return msg.Lockname
} }
// I like these functions the best.
func (msg *MsgName) simpleAppend(w io.Writer, FRUIT, APPLES, APPLE string) {
LOCK := msg.getLockname("x")
// append -- no check at all
fmt.Fprintln(w, "// TESTING 2")
fmt.Fprintln(w, "// just a simple Append() shortcut (but still uses the mutex lock)")
fmt.Fprintln(w, "func (x *"+FRUIT+") Append(y *"+APPLE+") {")
fmt.Fprintln(w, " "+LOCK+".Lock()")
fmt.Fprintln(w, " defer "+LOCK+".Unlock()")
fmt.Fprintln(w, "")
fmt.Fprintln(w, " x."+APPLES+" = append(x."+APPLES+", y)")
fmt.Fprintln(w, "}")
fmt.Fprintln(w, "")
}
func (msg *MsgName) insertByColors(w io.Writer, FRUIT, APPLES, APPLE string, COLORS []string) {
LOCK := msg.getLockname("x")
for _, COLOR := range COLORS {
fmt.Fprintln(w, "// TESTING")
fmt.Fprintln(w, "// returns an "+APPLE+" if "+COLOR+" matches, otherwise create")
fmt.Fprintln(w, "func (x *"+FRUIT+") InsertBy"+COLOR+" (y string) "+APPLE+" {")
fmt.Fprintln(w, " "+LOCK+".Lock()")
fmt.Fprintln(w, " defer "+LOCK+".Unlock()")
fmt.Fprintln(w, "")
fmt.Fprintln(w, " for _, p := range x."+APPLES+" {")
fmt.Fprintln(w, " if p."+COLOR+" == "+COLOR+" {")
fmt.Fprintln(w, " return p")
fmt.Fprintln(w, " }")
fmt.Fprintln(w, " }")
fmt.Fprintln(w, "")
fmt.Fprintln(w, " z := new("+APPLE+")")
fmt.Fprintln(w, " z."+COLOR+" := y")
fmt.Fprintln(w, " x."+APPLES+" = append(x."+APPLES+", z)")
fmt.Fprintln(w, " return true")
fmt.Fprintln(w, "}")
fmt.Fprintln(w, "")
}
}
func (msg *MsgName) appendUnique(w io.Writer, FRUIT, APPLES, APPLE string, COLORS []string) { func (msg *MsgName) appendUnique(w io.Writer, FRUIT, APPLES, APPLE string, COLORS []string) {
LOCK := msg.getLockname("x") LOCK := msg.getLockname("x")
@ -86,8 +126,8 @@ func (msg *MsgName) deleteBy(w io.Writer, FRUIT, APPLES, APPLE, COLOR string) {
fmt.Fprintln(w, "// TESTING") fmt.Fprintln(w, "// TESTING")
fmt.Fprintln(w, "func (x *"+FRUIT+") DeleteBy"+COLOR+"(s string) bool {") fmt.Fprintln(w, "func (x *"+FRUIT+") DeleteBy"+COLOR+"(s string) bool {")
fmt.Fprintln(w, " "+LOCK+".RLock()") fmt.Fprintln(w, " "+LOCK+".Lock()")
fmt.Fprintln(w, " defer "+LOCK+".RUnlock()") fmt.Fprintln(w, " defer "+LOCK+".Unlock()")
fmt.Fprintln(w, "") fmt.Fprintln(w, "")
fmt.Fprintln(w, " for i, _ := range x."+APPLES+" {") fmt.Fprintln(w, " for i, _ := range x."+APPLES+" {")
fmt.Fprintln(w, " if x."+APPLES+"[i]."+COLOR+" == s {") fmt.Fprintln(w, " if x."+APPLES+"[i]."+COLOR+" == s {")
@ -107,8 +147,8 @@ func (msg *MsgName) deleteByWithCopy(w io.Writer, FRUIT, APPLES, APPLE, COLOR st
fmt.Fprintln(w, "// TESTING") fmt.Fprintln(w, "// TESTING")
fmt.Fprintln(w, "func (x *"+FRUIT+") DeleteBy"+COLOR+"(s string) *"+APPLE+" {") fmt.Fprintln(w, "func (x *"+FRUIT+") DeleteBy"+COLOR+"(s string) *"+APPLE+" {")
fmt.Fprintln(w, " "+LOCK+".RLock()") fmt.Fprintln(w, " "+LOCK+".Lock()")
fmt.Fprintln(w, " defer "+LOCK+".RUnlock()") fmt.Fprintln(w, " defer "+LOCK+".Unlock()")
fmt.Fprintln(w, "") fmt.Fprintln(w, "")
fmt.Fprintln(w, " var newr "+APPLE) fmt.Fprintln(w, " var newr "+APPLE)
fmt.Fprintln(w, "") fmt.Fprintln(w, "")