annotate osx/include/capnp/json.capnp @ 62:0994c39f1e94

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