Cleanup JsonUI and add support for a resize method
This commit is contained in:
parent
433940485f
commit
b832a61193
|
@ -276,14 +276,11 @@ parse_json(const char* pos, const char* end)
|
||||||
return {};
|
return {};
|
||||||
|
|
||||||
if (*pos == ',')
|
if (*pos == ',')
|
||||||
{
|
|
||||||
++pos;
|
++pos;
|
||||||
continue;
|
else if (*pos == ']')
|
||||||
}
|
|
||||||
if (*pos == ']')
|
|
||||||
return Result{std::move(array), pos+1};
|
return Result{std::move(array), pos+1};
|
||||||
else
|
else
|
||||||
throw runtime_error("unable to parse array, expected , or ]");
|
throw runtime_error("unable to parse array, expected ',' or ']'");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if (*pos == '{')
|
if (*pos == '{')
|
||||||
|
@ -312,17 +309,14 @@ parse_json(const char* pos, const char* end)
|
||||||
return {};
|
return {};
|
||||||
|
|
||||||
if (*pos == ',')
|
if (*pos == ',')
|
||||||
{
|
|
||||||
++pos;
|
++pos;
|
||||||
continue;
|
else if (*pos == '}')
|
||||||
}
|
|
||||||
if (*pos == '}')
|
|
||||||
return Result{std::move(object), pos+1};
|
return Result{std::move(object), pos+1};
|
||||||
else
|
else
|
||||||
throw runtime_error("unable to parse object, expected , or }");
|
throw runtime_error("unable to parse object, expected ',' or '}'");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
return {};
|
throw runtime_error("Could not parse json");
|
||||||
}
|
}
|
||||||
|
|
||||||
void JsonUI::eval_json(const Value& json)
|
void JsonUI::eval_json(const Value& json)
|
||||||
|
@ -350,6 +344,15 @@ void JsonUI::eval_json(const Value& json)
|
||||||
m_pending_keys.push_back(key);
|
m_pending_keys.push_back(key);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
else if (method == "resize")
|
||||||
|
{
|
||||||
|
if (params.size() != 2)
|
||||||
|
throw runtime_error("resize expects 2 parameters");
|
||||||
|
|
||||||
|
CharCoord dim{params[0].as<int>(), params[1].as<int>()};
|
||||||
|
m_dimensions = dim;
|
||||||
|
m_pending_keys.push_back(resize(dim));
|
||||||
|
}
|
||||||
else
|
else
|
||||||
throw runtime_error("unknown method");
|
throw runtime_error("unknown method");
|
||||||
}
|
}
|
||||||
|
@ -377,18 +380,26 @@ void JsonUI::parse_requests(EventMode mode)
|
||||||
if (size == -1 or size == 0)
|
if (size == -1 or size == 0)
|
||||||
break;
|
break;
|
||||||
|
|
||||||
m_incoming_text += StringView{buf, buf + size};
|
m_requests += StringView{buf, buf + size};
|
||||||
}
|
}
|
||||||
|
|
||||||
if (not m_incoming_text.empty())
|
if (not m_requests.empty())
|
||||||
{
|
{
|
||||||
Value json;
|
Value json;
|
||||||
const char* pos;
|
const char* pos;
|
||||||
std::tie(json, pos) = parse_json(m_incoming_text.begin(), m_incoming_text.end());
|
std::tie(json, pos) = parse_json(m_requests.begin(), m_requests.end());
|
||||||
if (json)
|
if (json)
|
||||||
|
{
|
||||||
|
try
|
||||||
{
|
{
|
||||||
eval_json(json);
|
eval_json(json);
|
||||||
m_incoming_text = String{pos, m_incoming_text.end()};
|
}
|
||||||
|
catch (runtime_error& error)
|
||||||
|
{
|
||||||
|
write_stderr(format("error while executing request '{}': '{}'",
|
||||||
|
StringView{m_requests.begin(), pos}, error.what()));
|
||||||
|
}
|
||||||
|
m_requests = String{pos, m_requests.end()};
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -403,5 +414,4 @@ UnitTest test_json_parser{[]()
|
||||||
kak_assert(value);
|
kak_assert(value);
|
||||||
}};
|
}};
|
||||||
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -55,7 +55,7 @@ private:
|
||||||
FDWatcher m_stdin_watcher;
|
FDWatcher m_stdin_watcher;
|
||||||
Vector<Key> m_pending_keys;
|
Vector<Key> m_pending_keys;
|
||||||
CharCoord m_dimensions;
|
CharCoord m_dimensions;
|
||||||
String m_incoming_text;
|
String m_requests;
|
||||||
};
|
};
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue
Block a user