| // Protocol Buffers - Google's data interchange format |
| // Copyright 2008 Google Inc. All rights reserved. |
| // https://developers.google.com/protocol-buffers/ |
| // |
| // Redistribution and use in source and binary forms, with or without |
| // modification, are permitted provided that the following conditions are |
| // met: |
| // |
| // * Redistributions of source code must retain the above copyright |
| // notice, this list of conditions and the following disclaimer. |
| // * Redistributions in binary form must reproduce the above |
| // copyright notice, this list of conditions and the following disclaimer |
| // in the documentation and/or other materials provided with the |
| // distribution. |
| // * Neither the name of Google Inc. nor the names of its |
| // contributors may be used to endorse or promote products derived from |
| // this software without specific prior written permission. |
| // |
| // THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS |
| // "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT |
| // LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR |
| // A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT |
| // OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, |
| // SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT |
| // LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, |
| // DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY |
| // THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT |
| // (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE |
| // OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. |
| |
| /** |
| * @fileoverview This file contains constants and typedefs used by |
| * jspb.BinaryReader and BinaryWriter. |
| * |
| * @author aappleby@google.com (Austin Appleby) |
| */ |
| |
| goog.provide('jspb.AnyFieldType'); |
| goog.provide('jspb.BinaryConstants'); |
| goog.provide('jspb.BinaryMessage'); |
| goog.provide('jspb.BuilderFunction'); |
| goog.provide('jspb.ByteSource'); |
| goog.provide('jspb.ClonerFunction'); |
| goog.provide('jspb.ComparerFunction'); |
| goog.provide('jspb.ConstBinaryMessage'); |
| goog.provide('jspb.PrunerFunction'); |
| goog.provide('jspb.ReaderFunction'); |
| goog.provide('jspb.RecyclerFunction'); |
| goog.provide('jspb.RepeatedFieldType'); |
| goog.provide('jspb.ScalarFieldType'); |
| goog.provide('jspb.WriterFunction'); |
| |
| |
| goog.forwardDeclare('jspb.BinaryMessage'); |
| goog.forwardDeclare('jspb.BinaryReader'); |
| goog.forwardDeclare('jspb.BinaryWriter'); |
| goog.forwardDeclare('jspb.Message'); |
| goog.forwardDeclare('jsproto.BinaryExtension'); |
| |
| |
| |
| /** |
| * Base interface class for all const messages. |
| * @interface |
| */ |
| jspb.ConstBinaryMessage = function() {}; |
| |
| /** |
| * Generate a debug string for this proto that is in proto2 text format. |
| * @return {string} The debug string. |
| */ |
| jspb.ConstBinaryMessage.prototype.toDebugString; |
| |
| /** |
| * Helper to generate a debug string for this proto at some indent level. The |
| * first line is not indented. |
| * @param {number} indentLevel The number of spaces by which to indent lines. |
| * @return {string} The debug string. |
| * @protected |
| */ |
| jspb.ConstBinaryMessage.prototype.toDebugStringInternal; |
| |
| /** |
| * Base interface class for all messages. Does __not__ define any methods, as |
| * doing so on a widely-used interface defeats dead-code elimination. |
| * @interface |
| * @extends {jspb.ConstBinaryMessage} |
| */ |
| jspb.BinaryMessage = function() {}; |
| |
| |
| /** |
| * The types convertible to Uint8Arrays. Strings are assumed to be |
| * base64-encoded. |
| * @typedef {ArrayBuffer|Uint8Array|Array<number>|string} |
| */ |
| jspb.ByteSource; |
| |
| |
| /** |
| * A scalar field in jspb can be a boolean, number, or string. |
| * @typedef {boolean|number|string} |
| */ |
| jspb.ScalarFieldType; |
| |
| |
| /** |
| * A repeated field in jspb is an array of scalars, blobs, or messages. |
| * @typedef {!Array<jspb.ScalarFieldType>| |
| !Array<!Uint8Array>| |
| !Array<!jspb.ConstBinaryMessage>| |
| !Array<!jspb.BinaryMessage>} |
| */ |
| jspb.RepeatedFieldType; |
| |
| |
| /** |
| * A field in jspb can be a scalar, a block of bytes, another proto, or an |
| * array of any of the above. |
| * @typedef {jspb.ScalarFieldType| |
| jspb.RepeatedFieldType| |
| !Uint8Array| |
| !jspb.ConstBinaryMessage| |
| !jspb.BinaryMessage| |
| !jsproto.BinaryExtension} |
| */ |
| jspb.AnyFieldType; |
| |
| |
| /** |
| * A builder function creates an instance of a message object. |
| * @typedef {function():!jspb.BinaryMessage} |
| */ |
| jspb.BuilderFunction; |
| |
| |
| /** |
| * A cloner function creates a deep copy of a message object. |
| * @typedef {function(jspb.ConstBinaryMessage):jspb.BinaryMessage} |
| */ |
| jspb.ClonerFunction; |
| |
| |
| /** |
| * A recycler function destroys an instance of a message object. |
| * @typedef {function(!jspb.BinaryMessage):void} |
| */ |
| jspb.RecyclerFunction; |
| |
| |
| /** |
| * A reader function initializes a message using data from a BinaryReader. |
| * @typedef {function(!jspb.BinaryMessage, !jspb.BinaryReader):void} |
| */ |
| jspb.ReaderFunction; |
| |
| |
| /** |
| * A writer function serializes a message to a BinaryWriter. |
| * @typedef {function((!jspb.Message|!jspb.ConstBinaryMessage), |
| * !jspb.BinaryWriter):void} |
| */ |
| jspb.WriterFunction; |
| |
| |
| /** |
| * A pruner function removes default-valued fields and empty submessages from a |
| * message and returns either the pruned message or null if the entire message |
| * was pruned away. |
| * @typedef {function(?jspb.BinaryMessage):?jspb.BinaryMessage} |
| */ |
| jspb.PrunerFunction; |
| |
| |
| /** |
| * A comparer function returns true if two protos are equal. |
| * @typedef {!function(?jspb.ConstBinaryMessage, |
| * ?jspb.ConstBinaryMessage):boolean} |
| */ |
| jspb.ComparerFunction; |
| |
| |
| /** |
| * Field type codes, taken from proto2/public/wire_format_lite.h. |
| * @enum {number} |
| */ |
| jspb.BinaryConstants.FieldType = { |
| INVALID: -1, |
| DOUBLE: 1, |
| FLOAT: 2, |
| INT64: 3, |
| UINT64: 4, |
| INT32: 5, |
| FIXED64: 6, |
| FIXED32: 7, |
| BOOL: 8, |
| STRING: 9, |
| GROUP: 10, |
| MESSAGE: 11, |
| BYTES: 12, |
| UINT32: 13, |
| ENUM: 14, |
| SFIXED32: 15, |
| SFIXED64: 16, |
| SINT32: 17, |
| SINT64: 18, |
| |
| // Extended types for Javascript |
| |
| FHASH64: 30, // 64-bit hash string, fixed-length encoding. |
| VHASH64: 31 // 64-bit hash string, varint encoding. |
| }; |
| |
| |
| /** |
| * Wire-format type codes, taken from proto2/public/wire_format_lite.h. |
| * @enum {number} |
| */ |
| jspb.BinaryConstants.WireType = { |
| INVALID: -1, |
| VARINT: 0, |
| FIXED64: 1, |
| DELIMITED: 2, |
| START_GROUP: 3, |
| END_GROUP: 4, |
| FIXED32: 5 |
| }; |
| |
| |
| /** |
| * Translates field type to wire type. |
| * @param {jspb.BinaryConstants.FieldType} fieldType |
| * @return {jspb.BinaryConstants.WireType} |
| */ |
| jspb.BinaryConstants.FieldTypeToWireType = function(fieldType) { |
| var fieldTypes = jspb.BinaryConstants.FieldType; |
| var wireTypes = jspb.BinaryConstants.WireType; |
| switch (fieldType) { |
| case fieldTypes.INT32: |
| case fieldTypes.INT64: |
| case fieldTypes.UINT32: |
| case fieldTypes.UINT64: |
| case fieldTypes.SINT32: |
| case fieldTypes.SINT64: |
| case fieldTypes.BOOL: |
| case fieldTypes.ENUM: |
| case fieldTypes.VHASH64: |
| return wireTypes.VARINT; |
| |
| case fieldTypes.DOUBLE: |
| case fieldTypes.FIXED64: |
| case fieldTypes.SFIXED64: |
| case fieldTypes.FHASH64: |
| return wireTypes.FIXED64; |
| |
| case fieldTypes.STRING: |
| case fieldTypes.MESSAGE: |
| case fieldTypes.BYTES: |
| return wireTypes.DELIMITED; |
| |
| case fieldTypes.FLOAT: |
| case fieldTypes.FIXED32: |
| case fieldTypes.SFIXED32: |
| return wireTypes.FIXED32; |
| |
| case fieldTypes.INVALID: |
| case fieldTypes.GROUP: |
| default: |
| return wireTypes.INVALID; |
| } |
| }; |
| |
| |
| /** |
| * Flag to indicate a missing field. |
| * @const {number} |
| */ |
| jspb.BinaryConstants.INVALID_FIELD_NUMBER = -1; |
| |
| |
| /** |
| * The smallest denormal float32 value. |
| * @const {number} |
| */ |
| jspb.BinaryConstants.FLOAT32_EPS = 1.401298464324817e-45; |
| |
| |
| /** |
| * The smallest normal float64 value. |
| * @const {number} |
| */ |
| jspb.BinaryConstants.FLOAT32_MIN = 1.1754943508222875e-38; |
| |
| |
| /** |
| * The largest finite float32 value. |
| * @const {number} |
| */ |
| jspb.BinaryConstants.FLOAT32_MAX = 3.4028234663852886e+38; |
| |
| |
| /** |
| * The smallest denormal float64 value. |
| * @const {number} |
| */ |
| jspb.BinaryConstants.FLOAT64_EPS = 5e-324; |
| |
| |
| /** |
| * The smallest normal float64 value. |
| * @const {number} |
| */ |
| jspb.BinaryConstants.FLOAT64_MIN = 2.2250738585072014e-308; |
| |
| |
| /** |
| * The largest finite float64 value. |
| * @const {number} |
| */ |
| jspb.BinaryConstants.FLOAT64_MAX = 1.7976931348623157e+308; |
| |
| |
| /** |
| * Convenience constant equal to 2^20. |
| * @const {number} |
| */ |
| jspb.BinaryConstants.TWO_TO_20 = 1048576; |
| |
| |
| /** |
| * Convenience constant equal to 2^23. |
| * @const {number} |
| */ |
| jspb.BinaryConstants.TWO_TO_23 = 8388608; |
| |
| |
| /** |
| * Convenience constant equal to 2^31. |
| * @const {number} |
| */ |
| jspb.BinaryConstants.TWO_TO_31 = 2147483648; |
| |
| |
| /** |
| * Convenience constant equal to 2^32. |
| * @const {number} |
| */ |
| jspb.BinaryConstants.TWO_TO_32 = 4294967296; |
| |
| |
| /** |
| * Convenience constant equal to 2^52. |
| * @const {number} |
| */ |
| jspb.BinaryConstants.TWO_TO_52 = 4503599627370496; |
| |
| |
| /** |
| * Convenience constant equal to 2^63. |
| * @const {number} |
| */ |
| jspb.BinaryConstants.TWO_TO_63 = 9223372036854775808; |
| |
| |
| /** |
| * Convenience constant equal to 2^64. |
| * @const {number} |
| */ |
| jspb.BinaryConstants.TWO_TO_64 = 18446744073709551616; |
| |
| |
| /** |
| * Eight-character string of zeros, used as the default 64-bit hash value. |
| * @const {string} |
| */ |
| jspb.BinaryConstants.ZERO_HASH = '\0\0\0\0\0\0\0\0'; |