Updated docs for SetBuiltinFunctions and SetBuiltinModules (#131)
* Updated docs for SetBuiltinFunctions and SetBuiltinModules * minor update
This commit is contained in:
parent
c437def4a0
commit
a3735846a5
1 changed files with 4 additions and 4 deletions
|
@ -120,11 +120,13 @@ To securely compile and execute _potentially_ unsafe script code, you can use th
|
||||||
|
|
||||||
#### Script.SetBuiltinFunctions(funcs []*objects.BuiltinFunction)
|
#### Script.SetBuiltinFunctions(funcs []*objects.BuiltinFunction)
|
||||||
|
|
||||||
SetBuiltinFunctions resets all builtin functions in the compiler to the ones provided in the input parameter. Compiler will report a compile-time error if the a function not set is referenced. All builtin functions are included by default unless `SetBuiltinFunctions` is called.
|
SetBuiltinFunctions resets all builtin functions in the compiler to the ones provided in the input parameter. Compiler will report a compile-time error if the a function not set is referenced. Passing `nil` will disable all builtin functions. All builtin functions **are included by default** unless `SetBuiltinFunctions` is called.
|
||||||
|
|
||||||
```golang
|
```golang
|
||||||
s := script.New([]byte(`print([1, 2, 3])`))
|
s := script.New([]byte(`print([1, 2, 3])`))
|
||||||
|
|
||||||
|
_, err := s.Run() // prints [1, 2, 3]
|
||||||
|
|
||||||
s.SetBuiltinFunctions(nil)
|
s.SetBuiltinFunctions(nil)
|
||||||
|
|
||||||
_, err := s.Run() // compile error
|
_, err := s.Run() // compile error
|
||||||
|
@ -136,13 +138,11 @@ _, err := s.Run() // prints [1, 2, 3]
|
||||||
|
|
||||||
#### Script.SetBuiltinModules(modules map[string]*objects.ImmutableMap)
|
#### Script.SetBuiltinModules(modules map[string]*objects.ImmutableMap)
|
||||||
|
|
||||||
SetBuiltinModules adds builtin modules provided in the input parameter. This can be used to add [standard library](https://github.com/d5/tengo/blob/master/docs/stdlib.md) modules into the compiler and VM. Compiler will report a compile-time error if the code tries to import a module that hasn't been included. No standard library modules are included by default unless `SetBuiltinModules` is called.
|
SetBuiltinModules adds builtin modules provided in the input parameter. This can be used to add [standard library](https://github.com/d5/tengo/blob/master/docs/stdlib.md) modules into the compiler and VM. Compiler will report a compile-time error if the code tries to import a module that hasn't been included. Passing `nil` will disable all builtin modules. No standard library modules are included by default unless `SetBuiltinModules` is called.
|
||||||
|
|
||||||
```golang
|
```golang
|
||||||
s := script.New([]byte(`math := import("math"); a := math.abs(-19.84)`))
|
s := script.New([]byte(`math := import("math"); a := math.abs(-19.84)`))
|
||||||
|
|
||||||
s.SetBuiltinModules(nil)
|
|
||||||
|
|
||||||
_, err := s.Run() // compile error
|
_, err := s.Run() // compile error
|
||||||
|
|
||||||
s.SetBuiltinModules(stdlib.Modules)
|
s.SetBuiltinModules(stdlib.Modules)
|
||||||
|
|
Loading…
Reference in a new issue