| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376 | // 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';
 |