diff --git a/AK/JsonValue.cpp b/AK/JsonValue.cpp index 6b6e10d9a8..1f8aee9afb 100644 --- a/AK/JsonValue.cpp +++ b/AK/JsonValue.cpp @@ -65,6 +65,17 @@ JsonValue::JsonValue(int value) m_value.as_int = value; } +JsonValue::JsonValue(unsigned value) +{ + if (value > INT32_MAX) { + m_type = Type::Double; + m_value.as_double = value; + } else { + m_type = Type::Int; + m_value.as_int = (int)value; + } +} + JsonValue::JsonValue(double value) : m_type(Type::Double) { diff --git a/AK/JsonValue.h b/AK/JsonValue.h index 23d96326fe..d738906189 100644 --- a/AK/JsonValue.h +++ b/AK/JsonValue.h @@ -31,6 +31,7 @@ public: JsonValue& operator=(JsonValue&&); JsonValue(int); + JsonValue(unsigned); JsonValue(double); JsonValue(bool); JsonValue(const String&); @@ -40,6 +41,13 @@ public: String to_string() const; void to_string(StringBuilder&) const; + String as_string() const + { + if (m_type == Type::String) + return *m_value.as_string; + return { }; + } + private: void clear(); void copy_from(const JsonValue&);