Documentation ¶
Index ¶
Constants ¶
This section is empty.
Variables ¶
var ( // ErrDead is an error returned when the pengine has died. ErrDead = fmt.Errorf("pengine: died") // ErrFailed is an error returned when a query failed (returned no results). ErrFailed = fmt.Errorf("pengine: query failed") )
Functions ¶
func RPC ¶
func RPC(url, query, options engine.Term, k func(*engine.Env) *engine.Promise, env *engine.Env) *engine.Promise
RPC is like pengine_rpc/3 from SWI, provided for as a native predicate for ichiban/prolog. This is a native predicate for Prolog. To use the API from Go, use AskProlog.
Supports the following options: application(Atom), chunk(Integer), src_text(Atom), src_url(Atom), debug(Boolean).
See: https://www.swi-prolog.org/pldoc/man?predicate=pengine_rpc/3
Types ¶
type Answers ¶
type Answers[T any] interface { // Next prepares the next query result and returns true if there is a result. Next(context.Context) bool // Current returns the current query result. Current() T // Close kills this query (in pengine terms, stops it). // It is not necessary to call Close if all results were iterated through unless the pengine is configured otherwise. Close() error // Cumulative returns the cumulative time taken by this query, as reported by pengines. Cumulative() time.Duration // Engine returns this query's underlying Engine. Engine() *Engine // Err returns the error encountered by this query. // This should always be checked after iteration finishes. // Returns ErrFailed if the query failed at least once without succeeding at least once. Err() error }
Answers is an iterator of query results. Use Next to prepare a result of type T and then Current to obtain it. Make sure to check Err after you finish iterating. Err will return ErrFailed if the query failed at least once without succeeding at least once.
answers, err := client.Ask(ctx, "between(1,6,X)") if err != nil { panic(err) } var got []json.Number for as.Next() { cur := as.Current() x := cur["X"] got = append(got, x.Number) } // got = {"1", "2", "3", ...} if err := answers.Err(); err != nil { panic(err) }
func Ask ¶
Ask creates a new pengine with the given initial query, executing it and returning an answers iterator. Queries must be in Prolog syntax without the terminating period or linebreak, such as:
between(1,3,X)
This uses the JSON format, so T can be anything that can unmarshal from the pengine result data. This package provides a Solutions type that can handle most results in a general manner.
func AskProlog ¶
AskProlog creates a new pengine with the given initial query, executing it and returning an answers iterator. Queries must be in Prolog syntax without the terminating period or linebreak, such as:
between(1,3,X)
This uses the Prolog format and answers are ichiban/prolog terms. Because ichiban/prolog is used to interpret results, using SWI's nonstandard syntax extensions like dictionaries may break it.
type Client ¶
type Client struct { // URL of the pengines server, required. URL string // Application name, optional. (example: "pengines_sandbox") Application string // Chunk is the number of query results to accumulate in one response. 1 by default. Chunk int // SourceText is Prolog source code to load (optional). // // TODO(guregu): Currently not supported in the Prolog format (use URL instead). SourceText string // SourceURL specifies a URL of Prolog source for the pengine to load (optional). SourceURL string // HTTP is the HTTP client used to make API requests. // If nil, http.DefaultClient is used. HTTP *http.Client // If true, prints debug logs. Debug bool }
Client is a Pengines endpoint.
func (Client) Ask ¶
Ask creates a new engine with the given initial query and executes it, returning the answers iterator.
type Engine ¶
type Engine struct {
// contains filtered or unexported fields
}
Engine is a pengine.
func (*Engine) AskProlog ¶
AskProlog queries this engine with Prolog format results. Queries must be in Prolog syntax without the terminating period or linebreak, such as:
between(1,3,X)
Because ichiban/prolog is used to interpret results, using SWI's nonstandard syntax extensions like dictionaries may break it.
type Solution ¶
Solution is a mapping of variable names to values.
answers, err := Ask[Solution](ctx, "between(1,6,X)") // ... for as.Next() { cur := as.Current() // grab variables by name x := cur["X"] }
type Term ¶
type Term struct { Atom *string Number *json.Number Compound *Compound Variable *string Boolean *bool List []Term Null bool }
Term represents a Prolog term. One of the fields should be "truthy". This can be handy for parsing query results in JSON format.
func (Term) Prolog ¶
Prolog converts this term to an ichiban/prolog term. Because pengine's JSON format is lossy in terms of Prolog types, this might not always be accurate. There is ambiguity between atoms, strings, and variables. If you are mainly dealing with Prolog terms, use AskProlog to use the Prolog format instead.
func (*Term) UnmarshalJSON ¶
UnmarshalJSON implements json.Unmarshaler.