Documentation ¶
Index ¶
- Variables
- func ContainsLogIn(it Iterator, val Value)
- func ContainsLogOut(it Iterator, val Value, good bool) bool
- func InitTripleStore(name, dbpath string, opts Options) error
- func NextLogIn(it Iterator)
- func PrintResultTreeEvaluator(it Nexter)
- func RegisterTripleStore(name string, newFunc NewStoreFunc, initFunc InitStoreFunc)
- func StringResultTreeEvaluator(it Nexter) string
- func TripleStores() []string
- type BulkLoader
- type FixedIterator
- type InitStoreFunc
- type Iterator
- type IteratorStats
- type NewStoreFunc
- type Nexter
- type Options
- type ResultTree
- type Tagger
- type TripleStore
- type Type
- type Value
Constants ¶
This section is empty.
Variables ¶
var ErrCannotBulkLoad = errors.New("triplestore: cannot bulk load")
Functions ¶
func ContainsLogIn ¶
Utility logging functions for when an iterator gets called Next upon, or Contains upon, as well as what they return. Highly useful for tracing the execution path of a query.
func InitTripleStore ¶
func PrintResultTreeEvaluator ¶
func PrintResultTreeEvaluator(it Nexter)
func RegisterTripleStore ¶
func RegisterTripleStore(name string, newFunc NewStoreFunc, initFunc InitStoreFunc)
func TripleStores ¶
func TripleStores() []string
Types ¶
type BulkLoader ¶
type BulkLoader interface { // BulkLoad loads Quads from a quad.Unmarshaler in bulk to the TripleStore. // It returns ErrCannotBulkLoad if bulk loading is not possible. For example if // you cannot load in bulk to a non-empty database, and the db is non-empty. BulkLoad(quad.Unmarshaler) error }
type FixedIterator ¶
FixedIterator wraps iterators that are modifiable by addition of fixed value sets.
type InitStoreFunc ¶
type Iterator ¶
type Iterator interface { Tagger() *Tagger // Fills a tag-to-result-value map. TagResults(map[string]Value) // Returns the current result. Result() Value // DEPRECATED -- Fills a ResultTree struct with Result(). ResultTree() *ResultTree // These methods are the heart and soul of the iterator, as they constitute // the iteration interface. // // To get the full results of iteration, do the following: // while (!Next()): // emit result // while (!NextResult()): // emit result // // All of them should set iterator.Last to be the last returned value, to // make results work. // // NextResult() advances iterators that may have more than one valid result, // from the bottom up. NextResult() bool // Contains returns whether the value is within the set held by the iterator. Contains(Value) bool // Start iteration from the beginning Reset() // Create a new iterator just like this one Clone() Iterator // These methods relate to choosing the right iterator, or optimizing an // iterator tree // // Stats() returns the relative costs of calling the iteration methods for // this iterator, as well as the size. Roughly, it will take NextCost * Size // "cost units" to get everything out of the iterator. This is a wibbly-wobbly // thing, and not exact, but a useful heuristic. Stats() IteratorStats // Helpful accessor for the number of things in the iterator. The first return // value is the size, and the second return value is whether that number is exact, // or a conservative estimate. Size() (int64, bool) // Returns a string relating to what the function of the iterator is. By // knowing the names of the iterators, we can devise optimization strategies. Type() Type // Optimizes an iterator. Can replace the iterator, or merely move things // around internally. if it chooses to replace it with a better iterator, // returns (the new iterator, true), if not, it returns (self, false). Optimize() (Iterator, bool) // Return a slice of the subiterators for this iterator. SubIterators() []Iterator // Return a string representation of the iterator, indented by the given amount. DebugString(int) string // Close the iterator and do internal cleanup. Close() // UID returns the unique identifier of the iterator. UID() uint64 }
type IteratorStats ¶
type NewStoreFunc ¶
type NewStoreFunc func(string, Options) (TripleStore, error)
type ResultTree ¶
type ResultTree struct {
// contains filtered or unexported fields
}
func NewResultTree ¶
func NewResultTree(result Value) *ResultTree
func (*ResultTree) AddSubtree ¶
func (t *ResultTree) AddSubtree(sub *ResultTree)
func (*ResultTree) String ¶
func (t *ResultTree) String() string
type Tagger ¶
type Tagger struct {
// contains filtered or unexported fields
}
type TripleStore ¶
type TripleStore interface { // Add a triple to the store. AddTriple(*quad.Quad) // Add a set of triples to the store, atomically if possible. AddTripleSet([]*quad.Quad) // Removes a triple matching the given one from the database, // if it exists. Does nothing otherwise. RemoveTriple(*quad.Quad) // Given an opaque token, returns the triple for that token from the store. Quad(Value) *quad.Quad // Given a direction and a token, creates an iterator of links which have // that node token in that directional field. TripleIterator(quad.Direction, Value) Iterator // Returns an iterator enumerating all nodes in the graph. NodesAllIterator() Iterator // Returns an iterator enumerating all links in the graph. TriplesAllIterator() Iterator // Given a node ID, return the opaque token used by the TripleStore // to represent that id. ValueOf(string) Value // Given an opaque token, return the node that it represents. NameOf(Value) string // Returns the number of triples currently stored. Size() int64 // Creates a fixed iterator which can compare Values FixedIterator() FixedIterator // Optimize an iterator in the context of the triple store. // Suppose we have a better index for the passed tree; this // gives the TripleStore the opportunity to replace it // with a more efficient iterator. OptimizeIterator(it Iterator) (Iterator, bool) // Close the triple store and clean up. (Flush to disk, cleanly // sever connections, etc) Close() // Convenience function for speed. Given a triple token and a direction // return the node token for that direction. Sometimes, a TripleStore // can do this without going all the way to the backing store, and // gives the TripleStore the opportunity to make this optimization. // // Iterators will call this. At worst, a valid implementation is // ts.IdFor(ts.quad.Quad(id).Get(dir)) TripleDirection(id Value, d quad.Direction) Value }
func NewTripleStore ¶
func NewTripleStore(name, dbpath string, opts Options) (TripleStore, error)
type Type ¶
type Type int
Type enumerates the set of Iterator types.
func RegisterIterator ¶
RegisterIterator adds a new iterator type to the set of acceptable types, returning the registered Type. Calls to Register are idempotent and must be made prior to use of the iterator. The conventional approach for use is to include a call to Register in a package init() function, saving the Type to a private package var.
type Value ¶
type Value interface{}
Defines an opaque "triple store value" type. However the backend wishes to implement it, a Value is merely a token to a triple or a node that the backing store itself understands, and the base iterators pass around.
For example, in a very traditional, graphd-style graph, these are int64s (guids of the primitives). In a very direct sort of graph, these could be pointers to structs, or merely triples, or whatever works best for the backing store.