07a10ae9f4
Added BypassGet() to the topic and user caches. Moved 13 more queries to the query generator. The query generator now supports simple insert queries. Removed the pointless console logging for reply and topic deletions. We have modlogs for that. The MySQL files now have build tags to make it easy for you to disable them for other database engines. Those will be coming after the query generator is done. Moved a bunch of inline queries into more appropriate locations. Rewrote _process_where and DB_Where to better handle joins. Atom's continuing it's pointless crusade against trailing tabs.
27 lines
635 B
Go
27 lines
635 B
Go
package main
|
|
import "errors"
|
|
|
|
const CACHE_STATIC int = 0
|
|
const CACHE_DYNAMIC int = 1
|
|
const CACHE_SQL int = 2
|
|
|
|
var ErrStoreCapacityOverflow = errors.New("This datastore has already reached it's max capacity")
|
|
|
|
var users UserStore
|
|
var topics TopicStore
|
|
|
|
type DataStore interface {
|
|
Load(id int) error
|
|
Get(id int) (interface{}, error)
|
|
GetUnsafe(id int) (interface{}, error)
|
|
CascadeGet(id int) (interface{}, error)
|
|
BypassGet(id int) (interface{}, error)
|
|
Set(item interface{}) error
|
|
Add(item interface{}) error
|
|
AddUnsafe(item interface{}) error
|
|
Remove(id int) error
|
|
RemoveUnsafe(id int) error
|
|
GetLength() int
|
|
GetCapacity() int
|
|
}
|