0
0
Fork 0
mirror of https://github.com/matrix-construct/construct synced 2024-11-29 10:12:39 +01:00

fixup! ircd::json: Add comment for struct object

This commit is contained in:
Jason Volk 2017-08-23 14:30:21 -06:00
parent df87d820e1
commit 74da170996

View file

@ -36,9 +36,16 @@ namespace json {
// complexity *every time you invoke them*. This is not necessarily a bad // complexity *every time you invoke them*. This is not necessarily a bad
// thing in the appropriate use case. Our parser is pretty efficient; this // thing in the appropriate use case. Our parser is pretty efficient; this
// device conducts zero copies, zero allocations and zero indexing; instead // device conducts zero copies, zero allocations and zero indexing; instead
// the parser provides string_views to members during the iteration. Those // the parser provides string_views to members during the iteration.
// string_views are also trivially convertible to more ircd::json::object's //
// of course, providing any recursion. // The returned values are character ranges (string_view's) which themselves
// are type agnostic to their contents. The type of a value is determined at
// the user's discretion by querying the content of the string_view using a
// util function like json::type() etc. In other words, a value carries type
// data from its own original content. This means the user is responsible for
// removing prefix and suffix characters like '{' or '"' after determining the
// type if they want a truly pure value string. Our zero-copy string_view utils
// make this to a simple ballet of pointers.
// //
// Other devices for dealing with strings of JSON are available: if an index // Other devices for dealing with strings of JSON are available: if an index
// should be populated (ircd::json::index), or if a certain set of keys // should be populated (ircd::json::index), or if a certain set of keys
@ -47,6 +54,13 @@ namespace json {
// Some serialization/write functions are actually provided here, these // Some serialization/write functions are actually provided here, these
// are to *rewrite* JSON into our desired output form. // are to *rewrite* JSON into our desired output form.
// //
// Recursive traversal cannot be achieved via a single key string value; so
// any string_view argument for a key will not be recursive. In other words,
// due to the fact that a JS identifier can have almost any character we have
// to use a different *type* like a vector of strings; in our common case we
// use an initializer_list typedef'ed as `path` and those overloads will be
// recursive.
//
struct object struct object
:string_view :string_view
{ {