repl

package
v0.0.0-...-fb7d6bd Latest Latest
Warning

This package is not in the latest version of its module.

Go to latest
Published: May 25, 2021 License: BSD-3-Clause Imports: 9 Imported by: 0

Documentation

Overview

Package repl provides a read/eval/print loop for exprcore.

It supports readline-style command editing, and interrupts through Control-C.

If an input line can be parsed as an expression, the REPL parses and evaluates it and prints its result. Otherwise the REPL reads lines until a blank line, then tries again to parse the multi-line input as an expression. If the input still cannot be parsed as an expression, the REPL parses and executes it as a file (a list of statements), for side effects.

Index

Constants

This section is empty.

Variables

This section is empty.

Functions

func MakeLoad

func MakeLoad() func(thread *exprcore.Thread, module string) (exprcore.StringDict, error)

MakeLoad returns a simple sequential implementation of module loading suitable for use in the REPL. Each function returned by MakeLoad accesses a distinct private cache.

func PrintError

func PrintError(err error)

PrintError prints the error to stderr, or its backtrace if it is a exprcore evaluation error.

func REPL

func REPL(thread *exprcore.Thread, globals exprcore.StringDict)

REPL executes a read, eval, print loop.

Before evaluating each expression, it sets the exprcore thread local variable named "context" to a context.Context that is cancelled by a SIGINT (Control-C). Client-supplied global functions may use this context to make long-running operations interruptable.

Types

This section is empty.

Jump to

Keyboard shortcuts

? : This menu
/ : Search site
f or F : Jump to
y or Y : Canonical URL