mirror of
https://github.com/RGBCube/serenity
synced 2025-05-31 13:48:12 +00:00
Shell: Add an option to autosave history every N ms
...and set it to 10 seconds by default.
This commit is contained in:
parent
4d01183f5c
commit
a527256356
4 changed files with 45 additions and 0 deletions
|
@ -1844,6 +1844,8 @@ Shell::Shell(Line::Editor& editor, bool attempt_interactive)
|
|||
|
||||
return EDITOR_INTERNAL_FUNCTION(finish)(editor);
|
||||
});
|
||||
|
||||
start_timer(3000);
|
||||
}
|
||||
|
||||
Shell::~Shell()
|
||||
|
@ -2056,6 +2058,36 @@ Optional<int> Shell::resolve_job_spec(const String& str)
|
|||
return {};
|
||||
}
|
||||
|
||||
void Shell::timer_event(Core::TimerEvent& event)
|
||||
{
|
||||
event.accept();
|
||||
|
||||
if (m_is_subshell)
|
||||
return;
|
||||
|
||||
StringView option = getenv("HISTORY_AUTOSAVE_TIME_MS");
|
||||
|
||||
auto time = option.to_uint();
|
||||
if (!time.has_value() || time.value() == 0) {
|
||||
m_history_autosave_time.clear();
|
||||
stop_timer();
|
||||
start_timer(3000);
|
||||
return;
|
||||
}
|
||||
|
||||
if (m_history_autosave_time != time) {
|
||||
m_history_autosave_time = time.value();
|
||||
stop_timer();
|
||||
start_timer(m_history_autosave_time.value());
|
||||
}
|
||||
|
||||
if (!m_history_autosave_time.has_value())
|
||||
return;
|
||||
|
||||
if (m_editor)
|
||||
m_editor->save_history(get_history_path());
|
||||
}
|
||||
|
||||
void FileDescriptionCollector::collect()
|
||||
{
|
||||
for (auto fd : m_fds)
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue