annotate osx/include/capnp/json.capnp @ 169:223a55898ab9 tip default

Add null config files
author Chris Cannam <cannam@all-day-breakfast.com>
date Mon, 02 Mar 2020 14:03:47 +0000
parents 45360b968bf4
children
rev   line source
cannam@147 1 # Copyright (c) 2015 Sandstorm Development Group, Inc. and contributors
cannam@147 2 # Licensed under the MIT License:
cannam@147 3 #
cannam@147 4 # Permission is hereby granted, free of charge, to any person obtaining a copy
cannam@147 5 # of this software and associated documentation files (the "Software"), to deal
cannam@147 6 # in the Software without restriction, including without limitation the rights
cannam@147 7 # to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
cannam@147 8 # copies of the Software, and to permit persons to whom the Software is
cannam@147 9 # furnished to do so, subject to the following conditions:
cannam@147 10 #
cannam@147 11 # The above copyright notice and this permission notice shall be included in
cannam@147 12 # all copies or substantial portions of the Software.
cannam@147 13 #
cannam@147 14 # THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
cannam@147 15 # IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
cannam@147 16 # FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
cannam@147 17 # AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
cannam@147 18 # LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
cannam@147 19 # OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
cannam@147 20 # THE SOFTWARE.
cannam@147 21
cannam@147 22 @0x8ef99297a43a5e34;
cannam@147 23
cannam@147 24 $import "/capnp/c++.capnp".namespace("capnp");
cannam@147 25
cannam@147 26 struct JsonValue {
cannam@147 27 union {
cannam@147 28 null @0 :Void;
cannam@147 29 boolean @1 :Bool;
cannam@147 30 number @2 :Float64;
cannam@147 31 string @3 :Text;
cannam@147 32 array @4 :List(JsonValue);
cannam@147 33 object @5 :List(Field);
cannam@147 34 # Standard JSON values.
cannam@147 35
cannam@147 36 call @6 :Call;
cannam@147 37 # Non-standard: A "function call", applying a named function (named by a single identifier)
cannam@147 38 # to a parameter list. Examples:
cannam@147 39 #
cannam@147 40 # BinData(0, "Zm9vCg==")
cannam@147 41 # ISODate("2015-04-15T08:44:50.218Z")
cannam@147 42 #
cannam@147 43 # Mongo DB users will recognize the above as exactly the syntax Mongo uses to represent BSON
cannam@147 44 # "binary" and "date" types in text, since JSON has no analog of these. This is basically the
cannam@147 45 # reason this extension exists. We do NOT recommend using `call` unless you specifically need
cannam@147 46 # to be compatible with some silly format that uses this syntax.
cannam@147 47 }
cannam@147 48
cannam@147 49 struct Field {
cannam@147 50 name @0 :Text;
cannam@147 51 value @1 :JsonValue;
cannam@147 52 }
cannam@147 53
cannam@147 54 struct Call {
cannam@147 55 function @0 :Text;
cannam@147 56 params @1 :List(JsonValue);
cannam@147 57 }
cannam@147 58 }