feat(frontends/lean/server): add timebound to WAIT command, closes #156
Signed-off-by: Leonardo de Moura <leonardo@microsoft.com>
This commit is contained in:
parent
dab9ef31e3
commit
53292d8297
2 changed files with 33 additions and 7 deletions
|
@ -232,12 +232,20 @@ void server::worker::request_interrupt() {
|
||||||
m_thread.request_interrupt();
|
m_thread.request_interrupt();
|
||||||
}
|
}
|
||||||
|
|
||||||
void server::worker::wait() {
|
bool server::worker::wait(optional<unsigned> const & ms) {
|
||||||
while (true) {
|
while (true) {
|
||||||
unique_lock<mutex> lk(m_todo_mutex);
|
unique_lock<mutex> lk(m_todo_mutex);
|
||||||
if (!m_todo_file)
|
if (!m_todo_file)
|
||||||
break;
|
return true;
|
||||||
m_todo_cv.wait(lk);
|
if (ms) {
|
||||||
|
chrono::milliseconds d(*ms);
|
||||||
|
m_todo_cv.wait_for(lk, d);
|
||||||
|
if (!m_todo_file)
|
||||||
|
return true;
|
||||||
|
return false;
|
||||||
|
} else {
|
||||||
|
m_todo_cv.wait(lk);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -361,6 +369,16 @@ unsigned consume_num(std::string const & data, unsigned & i) {
|
||||||
return r;
|
return r;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
optional<unsigned> server::get_optional_num(std::string const & line, std::string const & cmd) {
|
||||||
|
std::string data = line.substr(cmd.size());
|
||||||
|
unsigned i = 0;
|
||||||
|
consume_spaces(data, i);
|
||||||
|
if (i == data.size())
|
||||||
|
return optional<unsigned>();
|
||||||
|
unsigned r = consume_num(data, i);
|
||||||
|
return optional<unsigned>(r);
|
||||||
|
}
|
||||||
|
|
||||||
void check_line_num(unsigned line_num) {
|
void check_line_num(unsigned line_num) {
|
||||||
if (line_num == 0)
|
if (line_num == 0)
|
||||||
throw exception("line numbers are indexed from 1");
|
throw exception("line numbers are indexed from 1");
|
||||||
|
@ -740,6 +758,13 @@ void server::find_goal_matches(unsigned line_num, unsigned col_num, std::string
|
||||||
m_out << "-- ENDFINDG" << std::endl;
|
m_out << "-- ENDFINDG" << std::endl;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void server::wait(optional<unsigned> ms) {
|
||||||
|
m_out << "-- BEGINWAIT" << std::endl;
|
||||||
|
if (!m_worker.wait(ms))
|
||||||
|
m_out << "-- INTERRUPTED\n";
|
||||||
|
m_out << "-- ENDWAIT" << std::endl;
|
||||||
|
}
|
||||||
|
|
||||||
bool server::operator()(std::istream & in) {
|
bool server::operator()(std::istream & in) {
|
||||||
for (std::string line; std::getline(in, line);) {
|
for (std::string line; std::getline(in, line);) {
|
||||||
try {
|
try {
|
||||||
|
@ -779,9 +804,8 @@ bool server::operator()(std::istream & in) {
|
||||||
} else if (is_command(g_options, line)) {
|
} else if (is_command(g_options, line)) {
|
||||||
show_options();
|
show_options();
|
||||||
} else if (is_command(g_wait, line)) {
|
} else if (is_command(g_wait, line)) {
|
||||||
m_out << "-- BEGINWAIT" << std::endl;
|
optional<unsigned> ms = get_optional_num(line, g_wait);
|
||||||
m_worker.wait();
|
wait(ms);
|
||||||
m_out << "-- ENDWAIT" << std::endl;
|
|
||||||
} else if (is_command(g_show, line)) {
|
} else if (is_command(g_show, line)) {
|
||||||
show(false);
|
show(false);
|
||||||
} else if (is_command(g_valid, line)) {
|
} else if (is_command(g_valid, line)) {
|
||||||
|
|
|
@ -57,7 +57,7 @@ class server {
|
||||||
~worker();
|
~worker();
|
||||||
void set_todo(file_ptr const & f, unsigned line_num, options const & o);
|
void set_todo(file_ptr const & f, unsigned line_num, options const & o);
|
||||||
void request_interrupt();
|
void request_interrupt();
|
||||||
void wait();
|
bool wait(optional<unsigned> const & ms);
|
||||||
};
|
};
|
||||||
|
|
||||||
file_map m_file_map;
|
file_map m_file_map;
|
||||||
|
@ -89,7 +89,9 @@ class server {
|
||||||
void interrupt_worker();
|
void interrupt_worker();
|
||||||
void show_options();
|
void show_options();
|
||||||
void show(bool valid);
|
void show(bool valid);
|
||||||
|
void wait(optional<unsigned> ms);
|
||||||
unsigned get_line_num(std::string const & line, std::string const & cmd);
|
unsigned get_line_num(std::string const & line, std::string const & cmd);
|
||||||
|
optional<unsigned> get_optional_num(std::string const & line, std::string const & cmd);
|
||||||
pair<unsigned, optional<unsigned>> get_line_opt_col_num(std::string const & line, std::string const & cmd);
|
pair<unsigned, optional<unsigned>> get_line_opt_col_num(std::string const & line, std::string const & cmd);
|
||||||
pair<unsigned, unsigned> get_line_col_num(std::string const & line, std::string const & cmd);
|
pair<unsigned, unsigned> get_line_col_num(std::string const & line, std::string const & cmd);
|
||||||
void find_goal_matches(unsigned line_num, unsigned col_num, std::string const & filters);
|
void find_goal_matches(unsigned line_num, unsigned col_num, std::string const & filters);
|
||||||
|
|
Loading…
Reference in a new issue