2018-10-07 07:07:44 +02:00
|
|
|
package utils
|
|
|
|
|
|
|
|
import (
|
|
|
|
"context"
|
2018-10-14 19:06:27 +02:00
|
|
|
|
2018-10-07 07:07:44 +02:00
|
|
|
"github.com/MontFerret/ferret/pkg/runtime/core"
|
|
|
|
"github.com/MontFerret/ferret/pkg/runtime/logging"
|
|
|
|
"github.com/MontFerret/ferret/pkg/runtime/values"
|
|
|
|
)
|
|
|
|
|
2018-11-06 02:31:26 +02:00
|
|
|
// Print writes messages into the system log.
|
|
|
|
func Print(ctx context.Context, args ...core.Value) (core.Value, error) {
|
2018-10-07 07:07:44 +02:00
|
|
|
err := core.ValidateArgs(args, 1, core.MaxArgs)
|
|
|
|
|
|
|
|
if err != nil {
|
|
|
|
return values.None, err
|
|
|
|
}
|
|
|
|
|
|
|
|
messages := make([]interface{}, 0, len(args))
|
|
|
|
|
2019-06-19 23:58:56 +02:00
|
|
|
for idx, input := range args {
|
|
|
|
if idx == 0 {
|
|
|
|
messages = append(messages, input)
|
|
|
|
} else {
|
|
|
|
messages = append(messages, " "+input.String())
|
|
|
|
}
|
2018-10-07 07:07:44 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
logger := logging.FromContext(ctx)
|
|
|
|
|
|
|
|
logger.Print(messages...)
|
|
|
|
|
|
|
|
return values.None, nil
|
|
|
|
}
|