diff options
author | Matthew Olsson <matthewcolsson@gmail.com> | 2020-06-10 21:40:27 -0700 |
---|---|---|
committer | Andreas Kling <kling@serenityos.org> | 2020-06-13 12:43:22 +0200 |
commit | e8e728454c5d436a02eaa1d24bc3afe357090c52 (patch) | |
tree | ac40614d78823eaba887e5657132681761c2b7cc /Libraries | |
parent | 39576b22385a2e6b6fc4fbf5e90e6b72157e9ee2 (diff) | |
download | serenity-e8e728454c5d436a02eaa1d24bc3afe357090c52.zip |
AK: JsonParser improvements
- Parsing invalid JSON no longer asserts
Instead of asserting when coming across malformed JSON,
JsonParser::parse now returns an Optional<JsonValue>.
- Disallow trailing commas in JSON objects and arrays
- No longer parse 'undefined', as that is a purely JS thing
- No longer allow non-whitespace after anything consumed by the initial
parse() call. Examples of things that were valid and no longer are:
- undefineddfz
- {"foo": 1}abcd
- [1,2,3]4
- JsonObject.for_each_member now iterates in original insertion order
Diffstat (limited to 'Libraries')
-rw-r--r-- | Libraries/LibCore/EventLoop.cpp | 4 | ||||
-rw-r--r-- | Libraries/LibCore/ProcessStatisticsReader.cpp | 3 | ||||
-rw-r--r-- | Libraries/LibGUI/JsonArrayModel.cpp | 5 | ||||
-rw-r--r-- | Libraries/LibKeyboard/CharacterMapFile.cpp | 4 | ||||
-rw-r--r-- | Libraries/LibWeb/CodeGenerators/Generate_CSS_PropertyID_cpp.cpp | 7 | ||||
-rw-r--r-- | Libraries/LibWeb/CodeGenerators/Generate_CSS_PropertyID_h.cpp | 5 |
6 files changed, 17 insertions, 11 deletions
diff --git a/Libraries/LibCore/EventLoop.cpp b/Libraries/LibCore/EventLoop.cpp index ebf457a3b8..a35da46b8b 100644 --- a/Libraries/LibCore/EventLoop.cpp +++ b/Libraries/LibCore/EventLoop.cpp @@ -105,13 +105,13 @@ public: auto request = m_socket->read(length); auto request_json = JsonValue::from_string(request); - if (!request_json.is_object()) { + if (!request_json.has_value() || !request_json.value().is_object()) { dbg() << "RPC client sent invalid request"; shutdown(); return; } - handle_request(request_json.as_object()); + handle_request(request_json.value().as_object()); }; } virtual ~RPCClient() override diff --git a/Libraries/LibCore/ProcessStatisticsReader.cpp b/Libraries/LibCore/ProcessStatisticsReader.cpp index 13936b9f15..b9a55eb0c3 100644 --- a/Libraries/LibCore/ProcessStatisticsReader.cpp +++ b/Libraries/LibCore/ProcessStatisticsReader.cpp @@ -48,7 +48,8 @@ HashMap<pid_t, Core::ProcessStatistics> ProcessStatisticsReader::get_all() auto file_contents = file->read_all(); auto json = JsonValue::from_string(file_contents); - json.as_array().for_each([&](auto& value) { + ASSERT(json.has_value()); + json.value().as_array().for_each([&](auto& value) { const JsonObject& process_object = value.as_object(); Core::ProcessStatistics process; diff --git a/Libraries/LibGUI/JsonArrayModel.cpp b/Libraries/LibGUI/JsonArrayModel.cpp index fee86003ea..e845602c14 100644 --- a/Libraries/LibGUI/JsonArrayModel.cpp +++ b/Libraries/LibGUI/JsonArrayModel.cpp @@ -42,8 +42,9 @@ void JsonArrayModel::update() auto json = JsonValue::from_string(file->read_all()); - ASSERT(json.is_array()); - m_array = json.as_array(); + ASSERT(json.has_value()); + ASSERT(json.value().is_array()); + m_array = json.value().as_array(); did_update(); } diff --git a/Libraries/LibKeyboard/CharacterMapFile.cpp b/Libraries/LibKeyboard/CharacterMapFile.cpp index c1ee2fa5b6..eb50e7f876 100644 --- a/Libraries/LibKeyboard/CharacterMapFile.cpp +++ b/Libraries/LibKeyboard/CharacterMapFile.cpp @@ -48,7 +48,9 @@ Optional<CharacterMapData> CharacterMapFile::load_from_file(const String& file_n } auto file_contents = file->read_all(); - auto json = JsonValue::from_string(file_contents).as_object(); + auto json_result = JsonValue::from_string(file_contents); + ASSERT(json_result.has_value()); + auto json = json_result.value().as_object(); ByteBuffer map = read_map(json, "map"); ByteBuffer shift_map = read_map(json, "shift_map"); diff --git a/Libraries/LibWeb/CodeGenerators/Generate_CSS_PropertyID_cpp.cpp b/Libraries/LibWeb/CodeGenerators/Generate_CSS_PropertyID_cpp.cpp index 9891d6bae4..7fab48f81d 100644 --- a/Libraries/LibWeb/CodeGenerators/Generate_CSS_PropertyID_cpp.cpp +++ b/Libraries/LibWeb/CodeGenerators/Generate_CSS_PropertyID_cpp.cpp @@ -56,7 +56,8 @@ int main(int argc, char** argv) return 1; auto json = JsonValue::from_string(file->read_all()); - ASSERT(json.is_object()); + ASSERT(json.has_value()); + ASSERT(json.value().is_object()); out() << "#include <AK/Assertions.h>"; out() << "#include <LibWeb/CSS/PropertyID.h>"; @@ -65,7 +66,7 @@ int main(int argc, char** argv) out() << "PropertyID property_id_from_string(const StringView& string) {"; - json.as_object().for_each_member([&](auto& name, auto& value) { + json.value().as_object().for_each_member([&](auto& name, auto& value) { ASSERT(value.is_object()); out() << " if (string.equals_ignoring_case(\"" << name << "\"))"; out() << " return PropertyID::" << title_casify(name) << ";"; @@ -77,7 +78,7 @@ int main(int argc, char** argv) out() << "const char* string_from_property_id(PropertyID property_id) {"; out() << " switch (property_id) {"; - json.as_object().for_each_member([&](auto& name, auto& value) { + json.value().as_object().for_each_member([&](auto& name, auto& value) { ASSERT(value.is_object()); out() << " case PropertyID::" << title_casify(name) << ":"; out() << " return \"" << name << "\";"; diff --git a/Libraries/LibWeb/CodeGenerators/Generate_CSS_PropertyID_h.cpp b/Libraries/LibWeb/CodeGenerators/Generate_CSS_PropertyID_h.cpp index 04cd3d9278..1dbf80d9a3 100644 --- a/Libraries/LibWeb/CodeGenerators/Generate_CSS_PropertyID_h.cpp +++ b/Libraries/LibWeb/CodeGenerators/Generate_CSS_PropertyID_h.cpp @@ -56,7 +56,8 @@ int main(int argc, char** argv) return 1; auto json = JsonValue::from_string(file->read_all()); - ASSERT(json.is_object()); + ASSERT(json.has_value()); + ASSERT(json.value().is_object()); out() << "#pragma once"; out() << "#include <AK/StringView.h>"; @@ -67,7 +68,7 @@ int main(int argc, char** argv) out() << "enum class PropertyID {"; out() << " Invalid,"; - json.as_object().for_each_member([&](auto& name, auto& value) { + json.value().as_object().for_each_member([&](auto& name, auto& value) { ASSERT(value.is_object()); out() << " " << title_casify(name) << ","; }); |