cache combos between pages
This commit is contained in:
parent
d26d4a972c
commit
9d43354c68
|
@ -0,0 +1,65 @@
|
||||||
|
//
|
||||||
|
// Copyright (c) 2019 Ted Unangst <tedu@tedunangst.com>
|
||||||
|
//
|
||||||
|
// Permission to use, copy, modify, and distribute this software for any
|
||||||
|
// purpose with or without fee is hereby granted, provided that the above
|
||||||
|
// copyright notice and this permission notice appear in all copies.
|
||||||
|
//
|
||||||
|
// THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
|
||||||
|
// WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
|
||||||
|
// MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
|
||||||
|
// ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
|
||||||
|
// WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
|
||||||
|
// ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
|
||||||
|
// OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
|
||||||
|
|
||||||
|
package main
|
||||||
|
|
||||||
|
import (
|
||||||
|
"reflect"
|
||||||
|
"sync"
|
||||||
|
)
|
||||||
|
|
||||||
|
type cacheFiller func(key interface{}) (interface{}, bool)
|
||||||
|
|
||||||
|
type Cache struct {
|
||||||
|
cache map[interface{}]interface{}
|
||||||
|
filler cacheFiller
|
||||||
|
lock sync.Mutex
|
||||||
|
}
|
||||||
|
|
||||||
|
func cacheNew(filler cacheFiller) *Cache {
|
||||||
|
c := new(Cache)
|
||||||
|
c.cache = make(map[interface{}]interface{})
|
||||||
|
c.filler = filler
|
||||||
|
return c
|
||||||
|
}
|
||||||
|
|
||||||
|
func (cache *Cache) Get(key interface{}, value interface{}) bool {
|
||||||
|
cache.lock.Lock()
|
||||||
|
defer cache.lock.Unlock()
|
||||||
|
v, ok := cache.cache[key]
|
||||||
|
if !ok {
|
||||||
|
v, ok = cache.filler(key)
|
||||||
|
if ok {
|
||||||
|
cache.cache[key] = v
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if ok {
|
||||||
|
ptr := reflect.ValueOf(v)
|
||||||
|
reflect.ValueOf(value).Elem().Set(ptr)
|
||||||
|
}
|
||||||
|
return ok
|
||||||
|
}
|
||||||
|
|
||||||
|
func (cache *Cache) Clear(key interface{}) {
|
||||||
|
cache.lock.Lock()
|
||||||
|
defer cache.lock.Unlock()
|
||||||
|
delete(cache.cache, key)
|
||||||
|
}
|
||||||
|
|
||||||
|
func (cache *Cache) Flush() {
|
||||||
|
cache.lock.Lock()
|
||||||
|
defer cache.lock.Unlock()
|
||||||
|
cache.cache = make(map[interface{}]interface{})
|
||||||
|
}
|
17
web.go
17
web.go
|
@ -1079,10 +1079,9 @@ func showhonkers(w http.ResponseWriter, r *http.Request) {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
func showcombos(w http.ResponseWriter, r *http.Request) {
|
var combocache = cacheNew(func(key interface{}) (interface{}, bool) {
|
||||||
userinfo := login.GetUserInfo(r)
|
userid := key.(int64)
|
||||||
templinfo := getInfo(r)
|
honkers := gethonkers(userid)
|
||||||
honkers := gethonkers(userinfo.UserID)
|
|
||||||
var combos []string
|
var combos []string
|
||||||
for _, h := range honkers {
|
for _, h := range honkers {
|
||||||
combos = append(combos, h.Combos...)
|
combos = append(combos, h.Combos...)
|
||||||
|
@ -1094,6 +1093,14 @@ func showcombos(w http.ResponseWriter, r *http.Request) {
|
||||||
}
|
}
|
||||||
combos = oneofakind(combos)
|
combos = oneofakind(combos)
|
||||||
sort.Strings(combos)
|
sort.Strings(combos)
|
||||||
|
return combos, true
|
||||||
|
})
|
||||||
|
|
||||||
|
func showcombos(w http.ResponseWriter, r *http.Request) {
|
||||||
|
userinfo := login.GetUserInfo(r)
|
||||||
|
var combos []string
|
||||||
|
combocache.Get(userinfo.UserID, &combos)
|
||||||
|
templinfo := getInfo(r)
|
||||||
templinfo["Combos"] = combos
|
templinfo["Combos"] = combos
|
||||||
err := readviews.Execute(w, "combos.html", templinfo)
|
err := readviews.Execute(w, "combos.html", templinfo)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
|
@ -1109,6 +1116,8 @@ func submithonker(w http.ResponseWriter, r *http.Request) {
|
||||||
combos := r.FormValue("combos")
|
combos := r.FormValue("combos")
|
||||||
honkerid, _ := strconv.ParseInt(r.FormValue("honkerid"), 10, 0)
|
honkerid, _ := strconv.ParseInt(r.FormValue("honkerid"), 10, 0)
|
||||||
|
|
||||||
|
defer combocache.Clear(u.UserID)
|
||||||
|
|
||||||
if honkerid > 0 {
|
if honkerid > 0 {
|
||||||
goodbye := r.FormValue("goodbye")
|
goodbye := r.FormValue("goodbye")
|
||||||
if goodbye == "F" {
|
if goodbye == "F" {
|
||||||
|
|
Loading…
Reference in New Issue