| /** | 
|  * The `repl` module provides a Read-Eval-Print-Loop (REPL) implementation that | 
|  * is available both as a standalone program or includible in other applications. | 
|  * It can be accessed using: | 
|  * | 
|  * ```js | 
|  * const repl = require('repl'); | 
|  * ``` | 
|  * @see [source](https://github.com/nodejs/node/blob/v18.0.0/lib/repl.js) | 
|  */ | 
| declare module 'repl' { | 
|     import { Interface, Completer, AsyncCompleter } from 'node:readline'; | 
|     import { Context } from 'node:vm'; | 
|     import { InspectOptions } from 'node:util'; | 
|     interface ReplOptions { | 
|         /** | 
|          * The input prompt to display. | 
|          * @default "> " | 
|          */ | 
|         prompt?: string | undefined; | 
|         /** | 
|          * The `Readable` stream from which REPL input will be read. | 
|          * @default process.stdin | 
|          */ | 
|         input?: NodeJS.ReadableStream | undefined; | 
|         /** | 
|          * The `Writable` stream to which REPL output will be written. | 
|          * @default process.stdout | 
|          */ | 
|         output?: NodeJS.WritableStream | undefined; | 
|         /** | 
|          * If `true`, specifies that the output should be treated as a TTY terminal, and have | 
|          * ANSI/VT100 escape codes written to it. | 
|          * Default: checking the value of the `isTTY` property on the output stream upon | 
|          * instantiation. | 
|          */ | 
|         terminal?: boolean | undefined; | 
|         /** | 
|          * The function to be used when evaluating each given line of input. | 
|          * Default: an async wrapper for the JavaScript `eval()` function. An `eval` function can | 
|          * error with `repl.Recoverable` to indicate the input was incomplete and prompt for | 
|          * additional lines. | 
|          * | 
|          * @see https://nodejs.org/dist/latest-v10.x/docs/api/repl.html#repl_default_evaluation | 
|          * @see https://nodejs.org/dist/latest-v10.x/docs/api/repl.html#repl_custom_evaluation_functions | 
|          */ | 
|         eval?: REPLEval | undefined; | 
|         /** | 
|          * Defines if the repl prints output previews or not. | 
|          * @default `true` Always `false` in case `terminal` is falsy. | 
|          */ | 
|         preview?: boolean | undefined; | 
|         /** | 
|          * If `true`, specifies that the default `writer` function should include ANSI color | 
|          * styling to REPL output. If a custom `writer` function is provided then this has no | 
|          * effect. | 
|          * Default: the REPL instance's `terminal` value. | 
|          */ | 
|         useColors?: boolean | undefined; | 
|         /** | 
|          * If `true`, specifies that the default evaluation function will use the JavaScript | 
|          * `global` as the context as opposed to creating a new separate context for the REPL | 
|          * instance. The node CLI REPL sets this value to `true`. | 
|          * Default: `false`. | 
|          */ | 
|         useGlobal?: boolean | undefined; | 
|         /** | 
|          * If `true`, specifies that the default writer will not output the return value of a | 
|          * command if it evaluates to `undefined`. | 
|          * Default: `false`. | 
|          */ | 
|         ignoreUndefined?: boolean | undefined; | 
|         /** | 
|          * The function to invoke to format the output of each command before writing to `output`. | 
|          * Default: a wrapper for `util.inspect`. | 
|          * | 
|          * @see https://nodejs.org/dist/latest-v10.x/docs/api/repl.html#repl_customizing_repl_output | 
|          */ | 
|         writer?: REPLWriter | undefined; | 
|         /** | 
|          * An optional function used for custom Tab auto completion. | 
|          * | 
|          * @see https://nodejs.org/dist/latest-v11.x/docs/api/readline.html#readline_use_of_the_completer_function | 
|          */ | 
|         completer?: Completer | AsyncCompleter | undefined; | 
|         /** | 
|          * A flag that specifies whether the default evaluator executes all JavaScript commands in | 
|          * strict mode or default (sloppy) mode. | 
|          * Accepted values are: | 
|          * - `repl.REPL_MODE_SLOPPY` - evaluates expressions in sloppy mode. | 
|          * - `repl.REPL_MODE_STRICT` - evaluates expressions in strict mode. This is equivalent to | 
|          *   prefacing every repl statement with `'use strict'`. | 
|          */ | 
|         replMode?: typeof REPL_MODE_SLOPPY | typeof REPL_MODE_STRICT | undefined; | 
|         /** | 
|          * Stop evaluating the current piece of code when `SIGINT` is received, i.e. `Ctrl+C` is | 
|          * pressed. This cannot be used together with a custom `eval` function. | 
|          * Default: `false`. | 
|          */ | 
|         breakEvalOnSigint?: boolean | undefined; | 
|     } | 
|     type REPLEval = (this: REPLServer, evalCmd: string, context: Context, file: string, cb: (err: Error | null, result: any) => void) => void; | 
|     type REPLWriter = (this: REPLServer, obj: any) => string; | 
|     /** | 
|      * This is the default "writer" value, if none is passed in the REPL options, | 
|      * and it can be overridden by custom print functions. | 
|      */ | 
|     const writer: REPLWriter & { | 
|         options: InspectOptions; | 
|     }; | 
|     type REPLCommandAction = (this: REPLServer, text: string) => void; | 
|     interface REPLCommand { | 
|         /** | 
|          * Help text to be displayed when `.help` is entered. | 
|          */ | 
|         help?: string | undefined; | 
|         /** | 
|          * The function to execute, optionally accepting a single string argument. | 
|          */ | 
|         action: REPLCommandAction; | 
|     } | 
|     /** | 
|      * Instances of `repl.REPLServer` are created using the {@link start} method | 
|      * or directly using the JavaScript `new` keyword. | 
|      * | 
|      * ```js | 
|      * const repl = require('repl'); | 
|      * | 
|      * const options = { useColors: true }; | 
|      * | 
|      * const firstInstance = repl.start(options); | 
|      * const secondInstance = new repl.REPLServer(options); | 
|      * ``` | 
|      * @since v0.1.91 | 
|      */ | 
|     class REPLServer extends Interface { | 
|         /** | 
|          * The `vm.Context` provided to the `eval` function to be used for JavaScript | 
|          * evaluation. | 
|          */ | 
|         readonly context: Context; | 
|         /** | 
|          * @deprecated since v14.3.0 - Use `input` instead. | 
|          */ | 
|         readonly inputStream: NodeJS.ReadableStream; | 
|         /** | 
|          * @deprecated since v14.3.0 - Use `output` instead. | 
|          */ | 
|         readonly outputStream: NodeJS.WritableStream; | 
|         /** | 
|          * The `Readable` stream from which REPL input will be read. | 
|          */ | 
|         readonly input: NodeJS.ReadableStream; | 
|         /** | 
|          * The `Writable` stream to which REPL output will be written. | 
|          */ | 
|         readonly output: NodeJS.WritableStream; | 
|         /** | 
|          * The commands registered via `replServer.defineCommand()`. | 
|          */ | 
|         readonly commands: NodeJS.ReadOnlyDict<REPLCommand>; | 
|         /** | 
|          * A value indicating whether the REPL is currently in "editor mode". | 
|          * | 
|          * @see https://nodejs.org/dist/latest-v10.x/docs/api/repl.html#repl_commands_and_special_keys | 
|          */ | 
|         readonly editorMode: boolean; | 
|         /** | 
|          * A value indicating whether the `_` variable has been assigned. | 
|          * | 
|          * @see https://nodejs.org/dist/latest-v10.x/docs/api/repl.html#repl_assignment_of_the_underscore_variable | 
|          */ | 
|         readonly underscoreAssigned: boolean; | 
|         /** | 
|          * The last evaluation result from the REPL (assigned to the `_` variable inside of the REPL). | 
|          * | 
|          * @see https://nodejs.org/dist/latest-v10.x/docs/api/repl.html#repl_assignment_of_the_underscore_variable | 
|          */ | 
|         readonly last: any; | 
|         /** | 
|          * A value indicating whether the `_error` variable has been assigned. | 
|          * | 
|          * @since v9.8.0 | 
|          * @see https://nodejs.org/dist/latest-v10.x/docs/api/repl.html#repl_assignment_of_the_underscore_variable | 
|          */ | 
|         readonly underscoreErrAssigned: boolean; | 
|         /** | 
|          * The last error raised inside the REPL (assigned to the `_error` variable inside of the REPL). | 
|          * | 
|          * @since v9.8.0 | 
|          * @see https://nodejs.org/dist/latest-v10.x/docs/api/repl.html#repl_assignment_of_the_underscore_variable | 
|          */ | 
|         readonly lastError: any; | 
|         /** | 
|          * Specified in the REPL options, this is the function to be used when evaluating each | 
|          * given line of input. If not specified in the REPL options, this is an async wrapper | 
|          * for the JavaScript `eval()` function. | 
|          */ | 
|         readonly eval: REPLEval; | 
|         /** | 
|          * Specified in the REPL options, this is a value indicating whether the default | 
|          * `writer` function should include ANSI color styling to REPL output. | 
|          */ | 
|         readonly useColors: boolean; | 
|         /** | 
|          * Specified in the REPL options, this is a value indicating whether the default `eval` | 
|          * function will use the JavaScript `global` as the context as opposed to creating a new | 
|          * separate context for the REPL instance. | 
|          */ | 
|         readonly useGlobal: boolean; | 
|         /** | 
|          * Specified in the REPL options, this is a value indicating whether the default `writer` | 
|          * function should output the result of a command if it evaluates to `undefined`. | 
|          */ | 
|         readonly ignoreUndefined: boolean; | 
|         /** | 
|          * Specified in the REPL options, this is the function to invoke to format the output of | 
|          * each command before writing to `outputStream`. If not specified in the REPL options, | 
|          * this will be a wrapper for `util.inspect`. | 
|          */ | 
|         readonly writer: REPLWriter; | 
|         /** | 
|          * Specified in the REPL options, this is the function to use for custom Tab auto-completion. | 
|          */ | 
|         readonly completer: Completer | AsyncCompleter; | 
|         /** | 
|          * Specified in the REPL options, this is a flag that specifies whether the default `eval` | 
|          * function should execute all JavaScript commands in strict mode or default (sloppy) mode. | 
|          * Possible values are: | 
|          * - `repl.REPL_MODE_SLOPPY` - evaluates expressions in sloppy mode. | 
|          * - `repl.REPL_MODE_STRICT` - evaluates expressions in strict mode. This is equivalent to | 
|          *    prefacing every repl statement with `'use strict'`. | 
|          */ | 
|         readonly replMode: typeof REPL_MODE_SLOPPY | typeof REPL_MODE_STRICT; | 
|         /** | 
|          * NOTE: According to the documentation: | 
|          * | 
|          * > Instances of `repl.REPLServer` are created using the `repl.start()` method and | 
|          * > _should not_ be created directly using the JavaScript `new` keyword. | 
|          * | 
|          * `REPLServer` cannot be subclassed due to implementation specifics in NodeJS. | 
|          * | 
|          * @see https://nodejs.org/dist/latest-v10.x/docs/api/repl.html#repl_class_replserver | 
|          */ | 
|         private constructor(); | 
|         /** | 
|          * The `replServer.defineCommand()` method is used to add new `.`\-prefixed commands | 
|          * to the REPL instance. Such commands are invoked by typing a `.` followed by the`keyword`. The `cmd` is either a `Function` or an `Object` with the following | 
|          * properties: | 
|          * | 
|          * The following example shows two new commands added to the REPL instance: | 
|          * | 
|          * ```js | 
|          * const repl = require('repl'); | 
|          * | 
|          * const replServer = repl.start({ prompt: '> ' }); | 
|          * replServer.defineCommand('sayhello', { | 
|          *   help: 'Say hello', | 
|          *   action(name) { | 
|          *     this.clearBufferedCommand(); | 
|          *     console.log(`Hello, ${name}!`); | 
|          *     this.displayPrompt(); | 
|          *   } | 
|          * }); | 
|          * replServer.defineCommand('saybye', function saybye() { | 
|          *   console.log('Goodbye!'); | 
|          *   this.close(); | 
|          * }); | 
|          * ``` | 
|          * | 
|          * The new commands can then be used from within the REPL instance: | 
|          * | 
|          * ```console | 
|          * > .sayhello Node.js User | 
|          * Hello, Node.js User! | 
|          * > .saybye | 
|          * Goodbye! | 
|          * ``` | 
|          * @since v0.3.0 | 
|          * @param keyword The command keyword (_without_ a leading `.` character). | 
|          * @param cmd The function to invoke when the command is processed. | 
|          */ | 
|         defineCommand(keyword: string, cmd: REPLCommandAction | REPLCommand): void; | 
|         /** | 
|          * The `replServer.displayPrompt()` method readies the REPL instance for input | 
|          * from the user, printing the configured `prompt` to a new line in the `output`and resuming the `input` to accept new input. | 
|          * | 
|          * When multi-line input is being entered, an ellipsis is printed rather than the | 
|          * 'prompt'. | 
|          * | 
|          * When `preserveCursor` is `true`, the cursor placement will not be reset to `0`. | 
|          * | 
|          * The `replServer.displayPrompt` method is primarily intended to be called from | 
|          * within the action function for commands registered using the`replServer.defineCommand()` method. | 
|          * @since v0.1.91 | 
|          */ | 
|         displayPrompt(preserveCursor?: boolean): void; | 
|         /** | 
|          * The `replServer.clearBufferedCommand()` method clears any command that has been | 
|          * buffered but not yet executed. This method is primarily intended to be | 
|          * called from within the action function for commands registered using the`replServer.defineCommand()` method. | 
|          * @since v9.0.0 | 
|          */ | 
|         clearBufferedCommand(): void; | 
|         /** | 
|          * Initializes a history log file for the REPL instance. When executing the | 
|          * Node.js binary and using the command-line REPL, a history file is initialized | 
|          * by default. However, this is not the case when creating a REPL | 
|          * programmatically. Use this method to initialize a history log file when working | 
|          * with REPL instances programmatically. | 
|          * @since v11.10.0 | 
|          * @param historyPath the path to the history file | 
|          * @param callback called when history writes are ready or upon error | 
|          */ | 
|         setupHistory(path: string, callback: (err: Error | null, repl: this) => void): void; | 
|         /** | 
|          * events.EventEmitter | 
|          * 1. close - inherited from `readline.Interface` | 
|          * 2. line - inherited from `readline.Interface` | 
|          * 3. pause - inherited from `readline.Interface` | 
|          * 4. resume - inherited from `readline.Interface` | 
|          * 5. SIGCONT - inherited from `readline.Interface` | 
|          * 6. SIGINT - inherited from `readline.Interface` | 
|          * 7. SIGTSTP - inherited from `readline.Interface` | 
|          * 8. exit | 
|          * 9. reset | 
|          */ | 
|         addListener(event: string, listener: (...args: any[]) => void): this; | 
|         addListener(event: 'close', listener: () => void): this; | 
|         addListener(event: 'line', listener: (input: string) => void): this; | 
|         addListener(event: 'pause', listener: () => void): this; | 
|         addListener(event: 'resume', listener: () => void): this; | 
|         addListener(event: 'SIGCONT', listener: () => void): this; | 
|         addListener(event: 'SIGINT', listener: () => void): this; | 
|         addListener(event: 'SIGTSTP', listener: () => void): this; | 
|         addListener(event: 'exit', listener: () => void): this; | 
|         addListener(event: 'reset', listener: (context: Context) => void): this; | 
|         emit(event: string | symbol, ...args: any[]): boolean; | 
|         emit(event: 'close'): boolean; | 
|         emit(event: 'line', input: string): boolean; | 
|         emit(event: 'pause'): boolean; | 
|         emit(event: 'resume'): boolean; | 
|         emit(event: 'SIGCONT'): boolean; | 
|         emit(event: 'SIGINT'): boolean; | 
|         emit(event: 'SIGTSTP'): boolean; | 
|         emit(event: 'exit'): boolean; | 
|         emit(event: 'reset', context: Context): boolean; | 
|         on(event: string, listener: (...args: any[]) => void): this; | 
|         on(event: 'close', listener: () => void): this; | 
|         on(event: 'line', listener: (input: string) => void): this; | 
|         on(event: 'pause', listener: () => void): this; | 
|         on(event: 'resume', listener: () => void): this; | 
|         on(event: 'SIGCONT', listener: () => void): this; | 
|         on(event: 'SIGINT', listener: () => void): this; | 
|         on(event: 'SIGTSTP', listener: () => void): this; | 
|         on(event: 'exit', listener: () => void): this; | 
|         on(event: 'reset', listener: (context: Context) => void): this; | 
|         once(event: string, listener: (...args: any[]) => void): this; | 
|         once(event: 'close', listener: () => void): this; | 
|         once(event: 'line', listener: (input: string) => void): this; | 
|         once(event: 'pause', listener: () => void): this; | 
|         once(event: 'resume', listener: () => void): this; | 
|         once(event: 'SIGCONT', listener: () => void): this; | 
|         once(event: 'SIGINT', listener: () => void): this; | 
|         once(event: 'SIGTSTP', listener: () => void): this; | 
|         once(event: 'exit', listener: () => void): this; | 
|         once(event: 'reset', listener: (context: Context) => void): this; | 
|         prependListener(event: string, listener: (...args: any[]) => void): this; | 
|         prependListener(event: 'close', listener: () => void): this; | 
|         prependListener(event: 'line', listener: (input: string) => void): this; | 
|         prependListener(event: 'pause', listener: () => void): this; | 
|         prependListener(event: 'resume', listener: () => void): this; | 
|         prependListener(event: 'SIGCONT', listener: () => void): this; | 
|         prependListener(event: 'SIGINT', listener: () => void): this; | 
|         prependListener(event: 'SIGTSTP', listener: () => void): this; | 
|         prependListener(event: 'exit', listener: () => void): this; | 
|         prependListener(event: 'reset', listener: (context: Context) => void): this; | 
|         prependOnceListener(event: string, listener: (...args: any[]) => void): this; | 
|         prependOnceListener(event: 'close', listener: () => void): this; | 
|         prependOnceListener(event: 'line', listener: (input: string) => void): this; | 
|         prependOnceListener(event: 'pause', listener: () => void): this; | 
|         prependOnceListener(event: 'resume', listener: () => void): this; | 
|         prependOnceListener(event: 'SIGCONT', listener: () => void): this; | 
|         prependOnceListener(event: 'SIGINT', listener: () => void): this; | 
|         prependOnceListener(event: 'SIGTSTP', listener: () => void): this; | 
|         prependOnceListener(event: 'exit', listener: () => void): this; | 
|         prependOnceListener(event: 'reset', listener: (context: Context) => void): this; | 
|     } | 
|     /** | 
|      * A flag passed in the REPL options. Evaluates expressions in sloppy mode. | 
|      */ | 
|     const REPL_MODE_SLOPPY: unique symbol; | 
|     /** | 
|      * A flag passed in the REPL options. Evaluates expressions in strict mode. | 
|      * This is equivalent to prefacing every repl statement with `'use strict'`. | 
|      */ | 
|     const REPL_MODE_STRICT: unique symbol; | 
|     /** | 
|      * The `repl.start()` method creates and starts a {@link REPLServer} instance. | 
|      * | 
|      * If `options` is a string, then it specifies the input prompt: | 
|      * | 
|      * ```js | 
|      * const repl = require('repl'); | 
|      * | 
|      * // a Unix style prompt | 
|      * repl.start('$ '); | 
|      * ``` | 
|      * @since v0.1.91 | 
|      */ | 
|     function start(options?: string | ReplOptions): REPLServer; | 
|     /** | 
|      * Indicates a recoverable error that a `REPLServer` can use to support multi-line input. | 
|      * | 
|      * @see https://nodejs.org/dist/latest-v10.x/docs/api/repl.html#repl_recoverable_errors | 
|      */ | 
|     class Recoverable extends SyntaxError { | 
|         err: Error; | 
|         constructor(err: Error); | 
|     } | 
| } | 
| declare module 'node:repl' { | 
|     export * from 'repl'; | 
| } |