-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathaliases.go
95 lines (77 loc) · 3.72 KB
/
aliases.go
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
// SPDX-FileCopyrightText: 2024 Christoph Mewes
// SPDX-License-Identifier: MIT
package rudi
import (
"context"
"go.xrstf.de/rudi/pkg/builtin"
"go.xrstf.de/rudi/pkg/coalescing"
"go.xrstf.de/rudi/pkg/runtime/functions"
"go.xrstf.de/rudi/pkg/runtime/interpreter"
"go.xrstf.de/rudi/pkg/runtime/types"
)
// Context is the evaluation context for a Rudi program, consisting of
// the global document, variables and functions.
type Context = types.Context
// Variables is a map of Rudi variables.
type Variables = types.Variables
// Functions is a map of Rudi functions.
type Functions = types.Functions
// Function is a single Rudi function, available to be used inside a Rudi script.
type Function = types.Function
// Document is the global document that is being processed by a Rudi script.
type Document = types.Document
// Coalescer is responsible for type handling and equality rules. Build your own
// or use any of the predefined versions:
//
// - coalescing.NewStrict() – mostly strict, but allows nulls to be converted
// and allows ints to become floats
// - coalescing.NewPedantic() – even more strict, allows absolutely no conversions
// - coalescing.NewHumane() – gentle type handling that allows lossless
// conversions like 1 => "1" or allowing (false == nil).
type Coalescer = coalescing.Coalescer
// NewContext wraps the document, variables and functions into a Context.
func NewContext(runtime types.Runtime, ctx context.Context, doc Document, variables Variables, funcs Functions, coalescer Coalescer) (Context, error) {
if runtime == nil {
runtime = interpreter.New()
}
return types.NewContext(runtime, ctx, doc, variables, funcs, coalescer)
}
// NewFunctions returns an empty set of runtime functions.
func NewFunctions() Functions {
return types.NewFunctions()
}
// NewSafeBuiltInFunctions returns a copy of all the safe built-in Rudi functions. These are all the
// functions that do not break runtime guarantees like programs always terminating in a reasonable
// time. See also NewUnsafeBuiltInFunctions, which contains functions like func! that allow to define
// new functions within Rudi code, but could lead to infinite loops or resource exhaustion.
func NewSafeBuiltInFunctions() Functions {
return builtin.SafeFunctions.DeepCopy()
}
// NewUnsafeBuiltInFunctions returns a copy of all the unsafe built-in Rudi functions. These are
// functions with extended side effects, please refer to the documentation or code for which
// functions exactly are considered "unsafe" in Rudi.
func NewUnsafeBuiltInFunctions() Functions {
return builtin.UnsafeFunctions.DeepCopy()
}
// NewVariables returns an empty set of runtime variables.
func NewVariables() Variables {
return types.NewVariables()
}
// NewDocument wraps any sort of data as a Rudi document.
func NewDocument(data any) (Document, error) {
return types.NewDocument(data)
}
// NewFunctionBuilder is the recommended way to define new Rudi functions. The function builder can
// take multiple forms (e.g. if you have (foo INT) and (foo STRING)) and will create a function that
// automatically evaluates and coalesces Rudi expressions and matches them to the given forms. The
// first matching form is then evaluated.
func NewFunctionBuilder(forms ...any) *functions.Builder {
return functions.NewBuilder(forms...)
}
// NewLowLevelFunction wraps a raw tuple function to be used in Rudi. This is mostly useful for
// defining really low-level functions and functions with special side effects. Most of the time,
// you'd want to use NewFunctionBuilder(), which will use reflection to make it much more straight
// forward to make a Go function available in Rudi.
func NewLowLevelFunction(f types.TupleFunction, description string) Function {
return types.NewFunction(f, description)
}