Updated docs for SetBuiltinFunctions and SetBuiltinModules (#131)

* Updated docs for SetBuiltinFunctions and SetBuiltinModules

* minor update
This commit is contained in:
earncef 2019-03-04 20:53:09 +01:00 committed by Daniel
parent c437def4a0
commit a3735846a5

View file

@ -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)