diff options
-rw-r--r-- | Userland/js.cpp | 5 |
1 files changed, 5 insertions, 0 deletions
diff --git a/Userland/js.cpp b/Userland/js.cpp index e19965cbb8..316160e0d7 100644 --- a/Userland/js.cpp +++ b/Userland/js.cpp @@ -29,6 +29,7 @@ #include <AK/StringBuilder.h> #include <LibCore/ArgsParser.h> #include <LibCore/File.h> +#include <LibCore/StandardPaths.h> #include <LibJS/AST.h> #include <LibJS/Console.h> #include <LibJS/Interpreter.h> @@ -68,6 +69,7 @@ private: static bool s_dump_ast = false; static bool s_print_last_result = false; static RefPtr<Line::Editor> s_editor; +static String s_history_path = String::formatted("{}/.js-history", Core::StandardPaths::home_directory()); static int s_repl_line_level = 0; static bool s_fail_repl = false; @@ -572,10 +574,12 @@ int main(int argc, char** argv) interpreter->vm().set_underscore_is_last_value(true); s_editor = Line::Editor::construct(); + s_editor->load_history(s_history_path); signal(SIGINT, [](int) { if (!s_editor->is_editing()) sigint_handler(); + s_editor->save_history(s_history_path); }); s_editor->on_display_refresh = [syntax_highlight](Line::Editor& editor) { @@ -763,6 +767,7 @@ int main(int argc, char** argv) }; s_editor->on_tab_complete = move(complete); repl(*interpreter); + s_editor->save_history(s_history_path); } else { interpreter = JS::Interpreter::create<JS::GlobalObject>(*vm); ReplConsoleClient console_client(interpreter->global_object().console()); |