diff options
author | Matthias Andreas Benkard <matthias@benkard.de> | 2008-06-22 14:42:47 +0200 |
---|---|---|
committer | Matthias Andreas Benkard <matthias@benkard.de> | 2008-06-22 14:42:47 +0200 |
commit | 1641912f2c9967b494187e7522d31bb00c53063c (patch) | |
tree | cce29bb068ad0fababda364c210c3a99be7ebdaa /MLKReadEvalPrintLoop.m | |
parent | 9960b8e94943867cc321a5145c327188e14d4d44 (diff) |
Add classes MLKLexicalEnvironment and MLKReadEvalPrintLoop.
Diffstat (limited to 'MLKReadEvalPrintLoop.m')
-rw-r--r-- | MLKReadEvalPrintLoop.m | 98 |
1 files changed, 98 insertions, 0 deletions
diff --git a/MLKReadEvalPrintLoop.m b/MLKReadEvalPrintLoop.m new file mode 100644 index 0000000..1d79a2f --- /dev/null +++ b/MLKReadEvalPrintLoop.m @@ -0,0 +1,98 @@ +/* -*- mode: objc; coding: utf-8 -*- */ +/* Étoilisp/Mulklisp, a Common Lisp subset for the Étoilé runtime. + * Copyright (C) 2008 Matthias Andreas Benkard. + * + * This program is free software: you can redistribute it and/or modify + * it under the terms of the GNU General Public License as published by + * the Free Software Foundation, either version 3 of the License, or (at + * your option) any later version. + * + * This program is distributed in the hope that it will be useful, but + * WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU + * General Public License for more details. + * + * You should have received a copy of the GNU General Public License + * along with this program. If not, see <http://www.gnu.org/licenses/>. + */ + +#import "MLKDynamicContext.h" +#import "MLKInterpreter.h" +#import "MLKLexicalEnvironment.h" +#import "MLKPackage.h" +#import "MLKReadEvalPrintLoop.h" +#import "MLKReader.h" + +#import <Foundation/NSString.h> + +#import <editline/history.h> +#import <editline/readline.h> +#import <histedit.h> + + +static int _argc; +static char **_argv; + + +static const char *prompt (EditLine *e) { + MLKPackage *package = [[MLKDynamicContext currentContext] + valueForBinding:[[MLKPackage + findPackage:@"COMMON-LISP"] + intern:@"*PACKAGE*"]]; + + return [[NSString stringWithFormat:@"%@> ", [package name]] UTF8String]; +} + + +@implementation MLKReadEvalPrintLoop : NSObject ++(void) run +{ + EditLine *editline; + History *commands; + HistEvent event; + + editline = el_init (_argv[0], stdin, stdout, stderr); + el_set (editline, EL_PROMPT, &prompt); + el_set (editline, EL_EDITOR, "emacs"); + + commands = history_init(); + history (commands, &event, H_SETSIZE, 1000); + el_set (editline, EL_HIST, history, commands); + + while (1) + { + const char *line; + ssize_t line_length; + + line = el_gets (editline, &line_length); + + if (line_length > 0) + { + NSString *result; + id code; + + history (commands, &event, H_ENTER, line); + code = [MLKReader readFromString:result]; + result = [MLKInterpreter eval:code + inLexicalContext:[MLKLexicalContext + globalContext] + withEnvironment:[MLKLexicalEnvironment + globalEnvironment]]; + } + + //free (line); + } + + history_end (commands); + el_end (editline); +} +@end + + +int main (int argc, char **argv) +{ + _argc = argc; + _argv = argv; + [MLKReadEvalPrintLoop run]; + return 0; +} |