LLVM 19.0.0git
|
Classes | |
class | Array |
An Array is a JSON array, which contains heterogeneous JSON values. More... | |
class | Object |
An Object is a JSON object, which maps strings to heterogenous JSON values. More... | |
class | ObjectKey |
ObjectKey is a used to capture keys in Object. More... | |
class | ObjectMapper |
Helper for mapping JSON objects onto protocol structs. More... | |
class | OStream |
json::OStream allows writing well-formed JSON without materializing all structures as json::Value ahead of time. More... | |
class | ParseError |
class | Path |
A "cursor" marking a position within a Value. More... | |
class | Value |
A Value is an JSON value of unknown type. More... | |
Functions | |
bool | isUTF8 (llvm::StringRef S, size_t *ErrOffset=nullptr) |
Returns true if S is valid UTF-8, which is required for use as JSON. | |
std::string | fixUTF8 (llvm::StringRef S) |
Replaces invalid UTF-8 sequences in S with the replacement character (U+FFFD). | |
template<typename T > | |
Value | toJSON (const std::optional< T > &Opt) |
bool | operator== (const Object &LHS, const Object &RHS) |
bool | operator!= (const Object &LHS, const Object &RHS) |
bool | operator!= (const Array &L, const Array &R) |
bool | operator== (const Value &, const Value &) |
bool | operator!= (const Value &L, const Value &R) |
bool | operator== (const Array &L, const Array &R) |
bool | operator== (const ObjectKey &L, const ObjectKey &R) |
bool | operator!= (const ObjectKey &L, const ObjectKey &R) |
bool | operator< (const ObjectKey &L, const ObjectKey &R) |
bool | fromJSON (const Value &E, std::string &Out, Path P) |
bool | fromJSON (const Value &E, int &Out, Path P) |
bool | fromJSON (const Value &E, int64_t &Out, Path P) |
bool | fromJSON (const Value &E, double &Out, Path P) |
bool | fromJSON (const Value &E, bool &Out, Path P) |
bool | fromJSON (const Value &E, uint64_t &Out, Path P) |
bool | fromJSON (const Value &E, std::nullptr_t &Out, Path P) |
template<typename T > | |
bool | fromJSON (const Value &E, std::optional< T > &Out, Path P) |
template<typename T > | |
bool | fromJSON (const Value &E, std::vector< T > &Out, Path P) |
template<typename T > | |
bool | fromJSON (const Value &E, std::map< std::string, T > &Out, Path P) |
llvm::Expected< Value > | parse (llvm::StringRef JSON) |
Parses the provided JSON source, or returns a ParseError. | |
template<typename T > | |
Expected< T > | parse (const llvm::StringRef &JSON, const char *RootName="") |
Version of parse() that converts the parsed value to the type T. | |
llvm::raw_ostream & | operator<< (llvm::raw_ostream &OS, const Value &V) |
Serializes this Value to JSON, writing it to the provided stream. | |
static void | quote (llvm::raw_ostream &OS, llvm::StringRef S) |
Variables | |
template<typename T > | |
constexpr bool | is_uint_64_bit_v |
std::string llvm::json::fixUTF8 | ( | llvm::StringRef | S | ) |
Replaces invalid UTF-8 sequences in S
with the replacement character (U+FFFD).
The returned string is valid UTF-8. This is much slower than isUTF8, so test that first.
Definition at line 711 of file JSON.cpp.
References llvm::ConvertUTF32toUTF8(), llvm::ConvertUTF8toUTF32(), llvm::StringRef::data(), llvm::lenientConversion, llvm::StringRef::size(), and llvm::strictConversion.
Referenced by llvm::json::OStream::attributeBegin(), llvm::json::ObjectKey::ObjectKey(), and llvm::json::Value::Value().
bool llvm::json::fromJSON | ( | const Value & | E, |
std::map< std::string, T > & | Out, | ||
Path | P | ||
) |
Definition at line 811 of file JSON.h.
References E, fromJSON(), and P.
bool llvm::json::fromJSON | ( | const Value & | E, |
std::optional< T > & | Out, | ||
Path | P | ||
) |
Definition at line 786 of file JSON.h.
References E, fromJSON(), and P.
Definition at line 729 of file JSON.h.
Referenced by fromJSON(), llvm::json::ObjectMapper::map(), llvm::json::ObjectMapper::mapOptional(), parse(), and WorkloadImportsManager::WorkloadImportsManager().
bool llvm::json::isUTF8 | ( | llvm::StringRef | S, |
size_t * | ErrOffset = nullptr |
||
) |
Returns true if S
is valid UTF-8, which is required for use as JSON.
If it returns false, Offset
is set to a byte offset near the first error.
Definition at line 697 of file JSON.cpp.
References llvm::StringRef::data(), llvm::Data, llvm::isLegalUTF8String(), LLVM_LIKELY, and llvm::StringRef::size().
Referenced by llvm::json::OStream::attributeBegin(), llvm::json::ObjectKey::ObjectKey(), and llvm::json::Value::Value().
|
inline |
Serializes this Value to JSON, writing it to the provided stream.
The formatting is compact (no extra whitespace) and deterministic. For pretty-printing, use the formatv() format_provider below.
Definition at line 1087 of file JSON.h.
References OS, and llvm::json::OStream::value().
Expected< T > llvm::json::parse | ( | const llvm::StringRef & | JSON, |
const char * | RootName = "" |
||
) |
Version of parse() that converts the parsed value to the type T.
RootName describes the root object and is used in error messages.
Definition at line 912 of file JSON.h.
References fromJSON().
Expected< Value > llvm::json::parse | ( | llvm::StringRef | JSON | ) |
Parses the provided JSON source, or returns a ParseError.
The returned Value is self-contained and owns its strings (they do not refer to the original source).
Definition at line 686 of file JSON.cpp.
Referenced by WorkloadImportsManager::WorkloadImportsManager().
|
static |
Definition at line 728 of file JSON.cpp.
References llvm::CallingConv::C, llvm::Lower, OS, and llvm::write_hex().
Referenced by llvm::json::OStream::attributeBegin(), and llvm::json::OStream::value().