all repos — honk @ a1d0514f09e23db62c89c08bb579afb868d73689

my fork of honk

one off hack to cache query results between requests... need generalization
Ted Unangst tedu@tedunangst.com
Wed, 30 Oct 2019 00:20:41 -0400
commit

a1d0514f09e23db62c89c08bb579afb868d73689

parent

54d806465ae6f586a9c64f5f0fa914d83dd75707

1 files changed, 29 insertions(+), 1 deletions(-)

jump to
M database.godatabase.go

@@ -24,6 +24,7 @@ "log"

"sort" "strconv" "strings" + "sync" "time" "humungus.tedunangst.com/r/webs/cache"

@@ -215,10 +216,37 @@ dt := time.Now().UTC().Add(-7 * 24 * time.Hour).Format(dbtimeformat)

rows, err := stmtHonksForUserFirstClass.Query(wanted, userid, dt, userid, userid) return getsomehonks(rows, err) } + +var mehonks = make(map[int64][]*Honk) +var melock sync.Mutex + func gethonksforme(userid int64, wanted int64) []*Honk { + if wanted > 0 { + dt := time.Now().UTC().Add(-7 * 24 * time.Hour).Format(dbtimeformat) + rows, err := stmtHonksForMe.Query(wanted, userid, dt, userid) + return getsomehonks(rows, err) + } + + melock.Lock() + defer melock.Unlock() + honks := mehonks[userid] + if len(honks) == 0 { + dt := time.Now().UTC().Add(-7 * 24 * time.Hour).Format(dbtimeformat) + rows, err := stmtHonksForMe.Query(wanted, userid, dt, userid) + honks = getsomehonks(rows, err) + mehonks[userid] = honks + return honks + } + wanted = honks[0].ID dt := time.Now().UTC().Add(-7 * 24 * time.Hour).Format(dbtimeformat) rows, err := stmtHonksForMe.Query(wanted, userid, dt, userid) - return getsomehonks(rows, err) + honks = getsomehonks(rows, err) + honks = append(honks, mehonks[userid]...) + if len(honks) > 250 { + honks = honks[:250] + } + mehonks[userid] = honks + return honks } func getsavedhonks(userid int64, wanted int64) []*Honk { rows, err := stmtHonksISaved.Query(wanted, userid)