1
Fork 0
mirror of https://github.com/RGBCube/serenity synced 2025-07-25 16:57:35 +00:00

Shell: Switch to using Core::EventLoop

This commit refactors Shell to a Core::Object and switches its looping
to Core::EventLoop.
This commit is contained in:
AnotherTest 2020-05-16 23:35:13 +04:30 committed by Andreas Kling
parent 172df68666
commit a398898c12
6 changed files with 1975 additions and 1761 deletions

View file

@ -26,7 +26,13 @@
#pragma once
#include "Execution.h"
#include <AK/JsonObject.h>
#include <AK/JsonValue.h>
#include <AK/OwnPtr.h>
#include <AK/String.h>
#include <LibCore/ElapsedTimer.h>
#include <LibCore/Object.h>
class Job {
public:
@ -34,22 +40,52 @@ public:
{
}
~Job()
{
auto elapsed = m_command_timer.elapsed();
dbg() << "Command \"" << m_cmd << "\" finished in " << elapsed << " ms";
}
Job(pid_t pid, unsigned pgid, String cmd, u64 job_id)
: m_pgid(pgid)
, m_pid(pid)
, m_job_id(job_id)
, m_cmd(move(cmd))
{
set_running_in_background(false);
m_command_timer.start();
}
unsigned pgid() const { return m_pgid; }
pid_t pid() const { return m_pid; }
const String& cmd() const { return m_cmd; }
u64 job_id() const { return m_job_id; }
bool exited() const { return m_exited; }
int exit_code() const { return m_exit_code; }
bool is_running_in_background() const { return m_running_in_background; }
Core::ElapsedTimer& timer() { return m_command_timer; }
void set_has_exit(int exit_code)
{
if (m_exited)
return;
m_exit_code = exit_code;
m_exited = true;
}
void set_running_in_background(bool running_in_background)
{
m_running_in_background = running_in_background;
}
private:
unsigned m_pgid { 0 };
pid_t m_pid { 0 };
u64 m_job_id { 0 };
String m_cmd;
bool m_exited { false };
bool m_running_in_background { false };
int m_exit_code { -1 };
Core::ElapsedTimer m_command_timer;
};