@webarray/esphome-native-api
Version:
TypeScript/Node.js client for ESPHome native API with encryption and deep sleep support
1,028 lines (965 loc) • 2.71 MB
JavaScript
/*eslint-disable block-scoped-var, id-length, no-control-regex, no-magic-numbers, no-prototype-builtins, no-redeclare, no-shadow, no-var, sort-vars*/
"use strict";
var $protobuf = require("protobufjs/minimal");
// Common aliases
var $Reader = $protobuf.Reader, $Writer = $protobuf.Writer, $util = $protobuf.util;
// Exported root namespace
var $root = $protobuf.roots["default"] || ($protobuf.roots["default"] = {});
/**
* APISourceType enum.
* @exports APISourceType
* @enum {number}
* @property {number} SOURCE_BOTH=0 SOURCE_BOTH value
* @property {number} SOURCE_SERVER=1 SOURCE_SERVER value
* @property {number} SOURCE_CLIENT=2 SOURCE_CLIENT value
*/
$root.APISourceType = (function() {
var valuesById = {}, values = Object.create(valuesById);
values[valuesById[0] = "SOURCE_BOTH"] = 0;
values[valuesById[1] = "SOURCE_SERVER"] = 1;
values[valuesById[2] = "SOURCE_CLIENT"] = 2;
return values;
})();
$root.VoidMessage = (function() {
/**
* Properties of a VoidMessage.
* @exports IVoidMessage
* @interface IVoidMessage
*/
/**
* Constructs a new VoidMessage.
* @exports VoidMessage
* @classdesc Represents a VoidMessage.
* @implements IVoidMessage
* @constructor
* @param {IVoidMessage=} [properties] Properties to set
*/
function VoidMessage(properties) {
if (properties)
for (var keys = Object.keys(properties), i = 0; i < keys.length; ++i)
if (properties[keys[i]] != null)
this[keys[i]] = properties[keys[i]];
}
/**
* Creates a new VoidMessage instance using the specified properties.
* @function create
* @memberof VoidMessage
* @static
* @param {IVoidMessage=} [properties] Properties to set
* @returns {VoidMessage} VoidMessage instance
*/
VoidMessage.create = function create(properties) {
return new VoidMessage(properties);
};
/**
* Encodes the specified VoidMessage message. Does not implicitly {@link VoidMessage.verify|verify} messages.
* @function encode
* @memberof VoidMessage
* @static
* @param {IVoidMessage} message VoidMessage message or plain object to encode
* @param {$protobuf.Writer} [writer] Writer to encode to
* @returns {$protobuf.Writer} Writer
*/
VoidMessage.encode = function encode(message, writer) {
if (!writer)
writer = $Writer.create();
return writer;
};
/**
* Encodes the specified VoidMessage message, length delimited. Does not implicitly {@link VoidMessage.verify|verify} messages.
* @function encodeDelimited
* @memberof VoidMessage
* @static
* @param {IVoidMessage} message VoidMessage message or plain object to encode
* @param {$protobuf.Writer} [writer] Writer to encode to
* @returns {$protobuf.Writer} Writer
*/
VoidMessage.encodeDelimited = function encodeDelimited(message, writer) {
return this.encode(message, writer).ldelim();
};
/**
* Decodes a VoidMessage message from the specified reader or buffer.
* @function decode
* @memberof VoidMessage
* @static
* @param {$protobuf.Reader|Uint8Array} reader Reader or buffer to decode from
* @param {number} [length] Message length if known beforehand
* @returns {VoidMessage} VoidMessage
* @throws {Error} If the payload is not a reader or valid buffer
* @throws {$protobuf.util.ProtocolError} If required fields are missing
*/
VoidMessage.decode = function decode(reader, length, error) {
if (!(reader instanceof $Reader))
reader = $Reader.create(reader);
var end = length === undefined ? reader.len : reader.pos + length, message = new $root.VoidMessage();
while (reader.pos < end) {
var tag = reader.uint32();
if (tag === error)
break;
switch (tag >>> 3) {
default:
reader.skipType(tag & 7);
break;
}
}
return message;
};
/**
* Decodes a VoidMessage message from the specified reader or buffer, length delimited.
* @function decodeDelimited
* @memberof VoidMessage
* @static
* @param {$protobuf.Reader|Uint8Array} reader Reader or buffer to decode from
* @returns {VoidMessage} VoidMessage
* @throws {Error} If the payload is not a reader or valid buffer
* @throws {$protobuf.util.ProtocolError} If required fields are missing
*/
VoidMessage.decodeDelimited = function decodeDelimited(reader) {
if (!(reader instanceof $Reader))
reader = new $Reader(reader);
return this.decode(reader, reader.uint32());
};
/**
* Verifies a VoidMessage message.
* @function verify
* @memberof VoidMessage
* @static
* @param {Object.<string,*>} message Plain object to verify
* @returns {string|null} `null` if valid, otherwise the reason why it is not
*/
VoidMessage.verify = function verify(message) {
if (typeof message !== "object" || message === null)
return "object expected";
return null;
};
/**
* Creates a VoidMessage message from a plain object. Also converts values to their respective internal types.
* @function fromObject
* @memberof VoidMessage
* @static
* @param {Object.<string,*>} object Plain object
* @returns {VoidMessage} VoidMessage
*/
VoidMessage.fromObject = function fromObject(object) {
if (object instanceof $root.VoidMessage)
return object;
return new $root.VoidMessage();
};
/**
* Creates a plain object from a VoidMessage message. Also converts values to other types if specified.
* @function toObject
* @memberof VoidMessage
* @static
* @param {VoidMessage} message VoidMessage
* @param {$protobuf.IConversionOptions} [options] Conversion options
* @returns {Object.<string,*>} Plain object
*/
VoidMessage.toObject = function toObject() {
return {};
};
/**
* Converts this VoidMessage to JSON.
* @function toJSON
* @memberof VoidMessage
* @instance
* @returns {Object.<string,*>} JSON object
*/
VoidMessage.prototype.toJSON = function toJSON() {
return this.constructor.toObject(this, $protobuf.util.toJSONOptions);
};
/**
* Gets the default type url for VoidMessage
* @function getTypeUrl
* @memberof VoidMessage
* @static
* @param {string} [typeUrlPrefix] your custom typeUrlPrefix(default "type.googleapis.com")
* @returns {string} The default type url
*/
VoidMessage.getTypeUrl = function getTypeUrl(typeUrlPrefix) {
if (typeUrlPrefix === undefined) {
typeUrlPrefix = "type.googleapis.com";
}
return typeUrlPrefix + "/VoidMessage";
};
return VoidMessage;
})();
$root.google = (function() {
/**
* Namespace google.
* @exports google
* @namespace
*/
var google = {};
google.protobuf = (function() {
/**
* Namespace protobuf.
* @memberof google
* @namespace
*/
var protobuf = {};
protobuf.FileDescriptorSet = (function() {
/**
* Properties of a FileDescriptorSet.
* @memberof google.protobuf
* @interface IFileDescriptorSet
* @property {Array.<google.protobuf.IFileDescriptorProto>|null} [file] FileDescriptorSet file
*/
/**
* Constructs a new FileDescriptorSet.
* @memberof google.protobuf
* @classdesc Represents a FileDescriptorSet.
* @implements IFileDescriptorSet
* @constructor
* @param {google.protobuf.IFileDescriptorSet=} [properties] Properties to set
*/
function FileDescriptorSet(properties) {
this.file = [];
if (properties)
for (var keys = Object.keys(properties), i = 0; i < keys.length; ++i)
if (properties[keys[i]] != null)
this[keys[i]] = properties[keys[i]];
}
/**
* FileDescriptorSet file.
* @member {Array.<google.protobuf.IFileDescriptorProto>} file
* @memberof google.protobuf.FileDescriptorSet
* @instance
*/
FileDescriptorSet.prototype.file = $util.emptyArray;
/**
* Creates a new FileDescriptorSet instance using the specified properties.
* @function create
* @memberof google.protobuf.FileDescriptorSet
* @static
* @param {google.protobuf.IFileDescriptorSet=} [properties] Properties to set
* @returns {google.protobuf.FileDescriptorSet} FileDescriptorSet instance
*/
FileDescriptorSet.create = function create(properties) {
return new FileDescriptorSet(properties);
};
/**
* Encodes the specified FileDescriptorSet message. Does not implicitly {@link google.protobuf.FileDescriptorSet.verify|verify} messages.
* @function encode
* @memberof google.protobuf.FileDescriptorSet
* @static
* @param {google.protobuf.IFileDescriptorSet} message FileDescriptorSet message or plain object to encode
* @param {$protobuf.Writer} [writer] Writer to encode to
* @returns {$protobuf.Writer} Writer
*/
FileDescriptorSet.encode = function encode(message, writer) {
if (!writer)
writer = $Writer.create();
if (message.file != null && message.file.length)
for (var i = 0; i < message.file.length; ++i)
$root.google.protobuf.FileDescriptorProto.encode(message.file[i], writer.uint32(/* id 1, wireType 2 =*/10).fork()).ldelim();
return writer;
};
/**
* Encodes the specified FileDescriptorSet message, length delimited. Does not implicitly {@link google.protobuf.FileDescriptorSet.verify|verify} messages.
* @function encodeDelimited
* @memberof google.protobuf.FileDescriptorSet
* @static
* @param {google.protobuf.IFileDescriptorSet} message FileDescriptorSet message or plain object to encode
* @param {$protobuf.Writer} [writer] Writer to encode to
* @returns {$protobuf.Writer} Writer
*/
FileDescriptorSet.encodeDelimited = function encodeDelimited(message, writer) {
return this.encode(message, writer).ldelim();
};
/**
* Decodes a FileDescriptorSet message from the specified reader or buffer.
* @function decode
* @memberof google.protobuf.FileDescriptorSet
* @static
* @param {$protobuf.Reader|Uint8Array} reader Reader or buffer to decode from
* @param {number} [length] Message length if known beforehand
* @returns {google.protobuf.FileDescriptorSet} FileDescriptorSet
* @throws {Error} If the payload is not a reader or valid buffer
* @throws {$protobuf.util.ProtocolError} If required fields are missing
*/
FileDescriptorSet.decode = function decode(reader, length, error) {
if (!(reader instanceof $Reader))
reader = $Reader.create(reader);
var end = length === undefined ? reader.len : reader.pos + length, message = new $root.google.protobuf.FileDescriptorSet();
while (reader.pos < end) {
var tag = reader.uint32();
if (tag === error)
break;
switch (tag >>> 3) {
case 1: {
if (!(message.file && message.file.length))
message.file = [];
message.file.push($root.google.protobuf.FileDescriptorProto.decode(reader, reader.uint32()));
break;
}
default:
reader.skipType(tag & 7);
break;
}
}
return message;
};
/**
* Decodes a FileDescriptorSet message from the specified reader or buffer, length delimited.
* @function decodeDelimited
* @memberof google.protobuf.FileDescriptorSet
* @static
* @param {$protobuf.Reader|Uint8Array} reader Reader or buffer to decode from
* @returns {google.protobuf.FileDescriptorSet} FileDescriptorSet
* @throws {Error} If the payload is not a reader or valid buffer
* @throws {$protobuf.util.ProtocolError} If required fields are missing
*/
FileDescriptorSet.decodeDelimited = function decodeDelimited(reader) {
if (!(reader instanceof $Reader))
reader = new $Reader(reader);
return this.decode(reader, reader.uint32());
};
/**
* Verifies a FileDescriptorSet message.
* @function verify
* @memberof google.protobuf.FileDescriptorSet
* @static
* @param {Object.<string,*>} message Plain object to verify
* @returns {string|null} `null` if valid, otherwise the reason why it is not
*/
FileDescriptorSet.verify = function verify(message) {
if (typeof message !== "object" || message === null)
return "object expected";
if (message.file != null && message.hasOwnProperty("file")) {
if (!Array.isArray(message.file))
return "file: array expected";
for (var i = 0; i < message.file.length; ++i) {
var error = $root.google.protobuf.FileDescriptorProto.verify(message.file[i]);
if (error)
return "file." + error;
}
}
return null;
};
/**
* Creates a FileDescriptorSet message from a plain object. Also converts values to their respective internal types.
* @function fromObject
* @memberof google.protobuf.FileDescriptorSet
* @static
* @param {Object.<string,*>} object Plain object
* @returns {google.protobuf.FileDescriptorSet} FileDescriptorSet
*/
FileDescriptorSet.fromObject = function fromObject(object) {
if (object instanceof $root.google.protobuf.FileDescriptorSet)
return object;
var message = new $root.google.protobuf.FileDescriptorSet();
if (object.file) {
if (!Array.isArray(object.file))
throw TypeError(".google.protobuf.FileDescriptorSet.file: array expected");
message.file = [];
for (var i = 0; i < object.file.length; ++i) {
if (typeof object.file[i] !== "object")
throw TypeError(".google.protobuf.FileDescriptorSet.file: object expected");
message.file[i] = $root.google.protobuf.FileDescriptorProto.fromObject(object.file[i]);
}
}
return message;
};
/**
* Creates a plain object from a FileDescriptorSet message. Also converts values to other types if specified.
* @function toObject
* @memberof google.protobuf.FileDescriptorSet
* @static
* @param {google.protobuf.FileDescriptorSet} message FileDescriptorSet
* @param {$protobuf.IConversionOptions} [options] Conversion options
* @returns {Object.<string,*>} Plain object
*/
FileDescriptorSet.toObject = function toObject(message, options) {
if (!options)
options = {};
var object = {};
if (options.arrays || options.defaults)
object.file = [];
if (message.file && message.file.length) {
object.file = [];
for (var j = 0; j < message.file.length; ++j)
object.file[j] = $root.google.protobuf.FileDescriptorProto.toObject(message.file[j], options);
}
return object;
};
/**
* Converts this FileDescriptorSet to JSON.
* @function toJSON
* @memberof google.protobuf.FileDescriptorSet
* @instance
* @returns {Object.<string,*>} JSON object
*/
FileDescriptorSet.prototype.toJSON = function toJSON() {
return this.constructor.toObject(this, $protobuf.util.toJSONOptions);
};
/**
* Gets the default type url for FileDescriptorSet
* @function getTypeUrl
* @memberof google.protobuf.FileDescriptorSet
* @static
* @param {string} [typeUrlPrefix] your custom typeUrlPrefix(default "type.googleapis.com")
* @returns {string} The default type url
*/
FileDescriptorSet.getTypeUrl = function getTypeUrl(typeUrlPrefix) {
if (typeUrlPrefix === undefined) {
typeUrlPrefix = "type.googleapis.com";
}
return typeUrlPrefix + "/google.protobuf.FileDescriptorSet";
};
return FileDescriptorSet;
})();
/**
* Edition enum.
* @name google.protobuf.Edition
* @enum {number}
* @property {number} EDITION_UNKNOWN=0 EDITION_UNKNOWN value
* @property {number} EDITION_LEGACY=900 EDITION_LEGACY value
* @property {number} EDITION_PROTO2=998 EDITION_PROTO2 value
* @property {number} EDITION_PROTO3=999 EDITION_PROTO3 value
* @property {number} EDITION_2023=1000 EDITION_2023 value
* @property {number} EDITION_2024=1001 EDITION_2024 value
* @property {number} EDITION_1_TEST_ONLY=1 EDITION_1_TEST_ONLY value
* @property {number} EDITION_2_TEST_ONLY=2 EDITION_2_TEST_ONLY value
* @property {number} EDITION_99997_TEST_ONLY=99997 EDITION_99997_TEST_ONLY value
* @property {number} EDITION_99998_TEST_ONLY=99998 EDITION_99998_TEST_ONLY value
* @property {number} EDITION_99999_TEST_ONLY=99999 EDITION_99999_TEST_ONLY value
* @property {number} EDITION_MAX=2147483647 EDITION_MAX value
*/
protobuf.Edition = (function() {
var valuesById = {}, values = Object.create(valuesById);
values[valuesById[0] = "EDITION_UNKNOWN"] = 0;
values[valuesById[900] = "EDITION_LEGACY"] = 900;
values[valuesById[998] = "EDITION_PROTO2"] = 998;
values[valuesById[999] = "EDITION_PROTO3"] = 999;
values[valuesById[1000] = "EDITION_2023"] = 1000;
values[valuesById[1001] = "EDITION_2024"] = 1001;
values[valuesById[1] = "EDITION_1_TEST_ONLY"] = 1;
values[valuesById[2] = "EDITION_2_TEST_ONLY"] = 2;
values[valuesById[99997] = "EDITION_99997_TEST_ONLY"] = 99997;
values[valuesById[99998] = "EDITION_99998_TEST_ONLY"] = 99998;
values[valuesById[99999] = "EDITION_99999_TEST_ONLY"] = 99999;
values[valuesById[2147483647] = "EDITION_MAX"] = 2147483647;
return values;
})();
protobuf.FileDescriptorProto = (function() {
/**
* Properties of a FileDescriptorProto.
* @memberof google.protobuf
* @interface IFileDescriptorProto
* @property {string|null} [name] FileDescriptorProto name
* @property {string|null} ["package"] FileDescriptorProto package
* @property {Array.<string>|null} [dependency] FileDescriptorProto dependency
* @property {Array.<number>|null} [public_dependency] FileDescriptorProto public_dependency
* @property {Array.<number>|null} [weak_dependency] FileDescriptorProto weak_dependency
* @property {Array.<string>|null} [option_dependency] FileDescriptorProto option_dependency
* @property {Array.<google.protobuf.IDescriptorProto>|null} [message_type] FileDescriptorProto message_type
* @property {Array.<google.protobuf.IEnumDescriptorProto>|null} [enum_type] FileDescriptorProto enum_type
* @property {Array.<google.protobuf.IServiceDescriptorProto>|null} [service] FileDescriptorProto service
* @property {Array.<google.protobuf.IFieldDescriptorProto>|null} [extension] FileDescriptorProto extension
* @property {google.protobuf.IFileOptions|null} [options] FileDescriptorProto options
* @property {google.protobuf.ISourceCodeInfo|null} [source_code_info] FileDescriptorProto source_code_info
* @property {string|null} [syntax] FileDescriptorProto syntax
* @property {google.protobuf.Edition|null} [edition] FileDescriptorProto edition
*/
/**
* Constructs a new FileDescriptorProto.
* @memberof google.protobuf
* @classdesc Represents a FileDescriptorProto.
* @implements IFileDescriptorProto
* @constructor
* @param {google.protobuf.IFileDescriptorProto=} [properties] Properties to set
*/
function FileDescriptorProto(properties) {
this.dependency = [];
this.public_dependency = [];
this.weak_dependency = [];
this.option_dependency = [];
this.message_type = [];
this.enum_type = [];
this.service = [];
this.extension = [];
if (properties)
for (var keys = Object.keys(properties), i = 0; i < keys.length; ++i)
if (properties[keys[i]] != null)
this[keys[i]] = properties[keys[i]];
}
/**
* FileDescriptorProto name.
* @member {string} name
* @memberof google.protobuf.FileDescriptorProto
* @instance
*/
FileDescriptorProto.prototype.name = "";
/**
* FileDescriptorProto package.
* @member {string} package
* @memberof google.protobuf.FileDescriptorProto
* @instance
*/
FileDescriptorProto.prototype["package"] = "";
/**
* FileDescriptorProto dependency.
* @member {Array.<string>} dependency
* @memberof google.protobuf.FileDescriptorProto
* @instance
*/
FileDescriptorProto.prototype.dependency = $util.emptyArray;
/**
* FileDescriptorProto public_dependency.
* @member {Array.<number>} public_dependency
* @memberof google.protobuf.FileDescriptorProto
* @instance
*/
FileDescriptorProto.prototype.public_dependency = $util.emptyArray;
/**
* FileDescriptorProto weak_dependency.
* @member {Array.<number>} weak_dependency
* @memberof google.protobuf.FileDescriptorProto
* @instance
*/
FileDescriptorProto.prototype.weak_dependency = $util.emptyArray;
/**
* FileDescriptorProto option_dependency.
* @member {Array.<string>} option_dependency
* @memberof google.protobuf.FileDescriptorProto
* @instance
*/
FileDescriptorProto.prototype.option_dependency = $util.emptyArray;
/**
* FileDescriptorProto message_type.
* @member {Array.<google.protobuf.IDescriptorProto>} message_type
* @memberof google.protobuf.FileDescriptorProto
* @instance
*/
FileDescriptorProto.prototype.message_type = $util.emptyArray;
/**
* FileDescriptorProto enum_type.
* @member {Array.<google.protobuf.IEnumDescriptorProto>} enum_type
* @memberof google.protobuf.FileDescriptorProto
* @instance
*/
FileDescriptorProto.prototype.enum_type = $util.emptyArray;
/**
* FileDescriptorProto service.
* @member {Array.<google.protobuf.IServiceDescriptorProto>} service
* @memberof google.protobuf.FileDescriptorProto
* @instance
*/
FileDescriptorProto.prototype.service = $util.emptyArray;
/**
* FileDescriptorProto extension.
* @member {Array.<google.protobuf.IFieldDescriptorProto>} extension
* @memberof google.protobuf.FileDescriptorProto
* @instance
*/
FileDescriptorProto.prototype.extension = $util.emptyArray;
/**
* FileDescriptorProto options.
* @member {google.protobuf.IFileOptions|null|undefined} options
* @memberof google.protobuf.FileDescriptorProto
* @instance
*/
FileDescriptorProto.prototype.options = null;
/**
* FileDescriptorProto source_code_info.
* @member {google.protobuf.ISourceCodeInfo|null|undefined} source_code_info
* @memberof google.protobuf.FileDescriptorProto
* @instance
*/
FileDescriptorProto.prototype.source_code_info = null;
/**
* FileDescriptorProto syntax.
* @member {string} syntax
* @memberof google.protobuf.FileDescriptorProto
* @instance
*/
FileDescriptorProto.prototype.syntax = "";
/**
* FileDescriptorProto edition.
* @member {google.protobuf.Edition} edition
* @memberof google.protobuf.FileDescriptorProto
* @instance
*/
FileDescriptorProto.prototype.edition = 0;
/**
* Creates a new FileDescriptorProto instance using the specified properties.
* @function create
* @memberof google.protobuf.FileDescriptorProto
* @static
* @param {google.protobuf.IFileDescriptorProto=} [properties] Properties to set
* @returns {google.protobuf.FileDescriptorProto} FileDescriptorProto instance
*/
FileDescriptorProto.create = function create(properties) {
return new FileDescriptorProto(properties);
};
/**
* Encodes the specified FileDescriptorProto message. Does not implicitly {@link google.protobuf.FileDescriptorProto.verify|verify} messages.
* @function encode
* @memberof google.protobuf.FileDescriptorProto
* @static
* @param {google.protobuf.IFileDescriptorProto} message FileDescriptorProto message or plain object to encode
* @param {$protobuf.Writer} [writer] Writer to encode to
* @returns {$protobuf.Writer} Writer
*/
FileDescriptorProto.encode = function encode(message, writer) {
if (!writer)
writer = $Writer.create();
if (message.name != null && Object.hasOwnProperty.call(message, "name"))
writer.uint32(/* id 1, wireType 2 =*/10).string(message.name);
if (message["package"] != null && Object.hasOwnProperty.call(message, "package"))
writer.uint32(/* id 2, wireType 2 =*/18).string(message["package"]);
if (message.dependency != null && message.dependency.length)
for (var i = 0; i < message.dependency.length; ++i)
writer.uint32(/* id 3, wireType 2 =*/26).string(message.dependency[i]);
if (message.message_type != null && message.message_type.length)
for (var i = 0; i < message.message_type.length; ++i)
$root.google.protobuf.DescriptorProto.encode(message.message_type[i], writer.uint32(/* id 4, wireType 2 =*/34).fork()).ldelim();
if (message.enum_type != null && message.enum_type.length)
for (var i = 0; i < message.enum_type.length; ++i)
$root.google.protobuf.EnumDescriptorProto.encode(message.enum_type[i], writer.uint32(/* id 5, wireType 2 =*/42).fork()).ldelim();
if (message.service != null && message.service.length)
for (var i = 0; i < message.service.length; ++i)
$root.google.protobuf.ServiceDescriptorProto.encode(message.service[i], writer.uint32(/* id 6, wireType 2 =*/50).fork()).ldelim();
if (message.extension != null && message.extension.length)
for (var i = 0; i < message.extension.length; ++i)
$root.google.protobuf.FieldDescriptorProto.encode(message.extension[i], writer.uint32(/* id 7, wireType 2 =*/58).fork()).ldelim();
if (message.options != null && Object.hasOwnProperty.call(message, "options"))
$root.google.protobuf.FileOptions.encode(message.options, writer.uint32(/* id 8, wireType 2 =*/66).fork()).ldelim();
if (message.source_code_info != null && Object.hasOwnProperty.call(message, "source_code_info"))
$root.google.protobuf.SourceCodeInfo.encode(message.source_code_info, writer.uint32(/* id 9, wireType 2 =*/74).fork()).ldelim();
if (message.public_dependency != null && message.public_dependency.length)
for (var i = 0; i < message.public_dependency.length; ++i)
writer.uint32(/* id 10, wireType 0 =*/80).int32(message.public_dependency[i]);
if (message.weak_dependency != null && message.weak_dependency.length)
for (var i = 0; i < message.weak_dependency.length; ++i)
writer.uint32(/* id 11, wireType 0 =*/88).int32(message.weak_dependency[i]);
if (message.syntax != null && Object.hasOwnProperty.call(message, "syntax"))
writer.uint32(/* id 12, wireType 2 =*/98).string(message.syntax);
if (message.edition != null && Object.hasOwnProperty.call(message, "edition"))
writer.uint32(/* id 14, wireType 0 =*/112).int32(message.edition);
if (message.option_dependency != null && message.option_dependency.length)
for (var i = 0; i < message.option_dependency.length; ++i)
writer.uint32(/* id 15, wireType 2 =*/122).string(message.option_dependency[i]);
return writer;
};
/**
* Encodes the specified FileDescriptorProto message, length delimited. Does not implicitly {@link google.protobuf.FileDescriptorProto.verify|verify} messages.
* @function encodeDelimited
* @memberof google.protobuf.FileDescriptorProto
* @static
* @param {google.protobuf.IFileDescriptorProto} message FileDescriptorProto message or plain object to encode
* @param {$protobuf.Writer} [writer] Writer to encode to
* @returns {$protobuf.Writer} Writer
*/
FileDescriptorProto.encodeDelimited = function encodeDelimited(message, writer) {
return this.encode(message, writer).ldelim();
};
/**
* Decodes a FileDescriptorProto message from the specified reader or buffer.
* @function decode
* @memberof google.protobuf.FileDescriptorProto
* @static
* @param {$protobuf.Reader|Uint8Array} reader Reader or buffer to decode from
* @param {number} [length] Message length if known beforehand
* @returns {google.protobuf.FileDescriptorProto} FileDescriptorProto
* @throws {Error} If the payload is not a reader or valid buffer
* @throws {$protobuf.util.ProtocolError} If required fields are missing
*/
FileDescriptorProto.decode = function decode(reader, length, error) {
if (!(reader instanceof $Reader))
reader = $Reader.create(reader);
var end = length === undefined ? reader.len : reader.pos + length, message = new $root.google.protobuf.FileDescriptorProto();
while (reader.pos < end) {
var tag = reader.uint32();
if (tag === error)
break;
switch (tag >>> 3) {
case 1: {
message.name = reader.string();
break;
}
case 2: {
message["package"] = reader.string();
break;
}
case 3: {
if (!(message.dependency && message.dependency.length))
message.dependency = [];
message.dependency.push(reader.string());
break;
}
case 10: {
if (!(message.public_dependency && message.public_dependency.length))
message.public_dependency = [];
if ((tag & 7) === 2) {
var end2 = reader.uint32() + reader.pos;
while (reader.pos < end2)
message.public_dependency.push(reader.int32());
} else
message.public_dependency.push(reader.int32());
break;
}
case 11: {
if (!(message.weak_dependency && message.weak_dependency.length))
message.weak_dependency = [];
if ((tag & 7) === 2) {
var end2 = reader.uint32() + reader.pos;
while (reader.pos < end2)
message.weak_dependency.push(reader.int32());
} else
message.weak_dependency.push(reader.int32());
break;
}
case 15: {
if (!(message.option_dependency && message.option_dependency.length))
message.option_dependency = [];
message.option_dependency.push(reader.string());
break;
}
case 4: {
if (!(message.message_type && message.message_type.length))
message.message_type = [];
message.message_type.push($root.google.protobuf.DescriptorProto.decode(reader, reader.uint32()));
break;
}
case 5: {
if (!(message.enum_type && message.enum_type.length))
message.enum_type = [];
message.enum_type.push($root.google.protobuf.EnumDescriptorProto.decode(reader, reader.uint32()));
break;
}
case 6: {
if (!(message.service && message.service.length))
message.service = [];
message.service.push($root.google.protobuf.ServiceDescriptorProto.decode(reader, reader.uint32()));
break;
}
case 7: {
if (!(message.extension && message.extension.length))
message.extension = [];
message.extension.push($root.google.protobuf.FieldDescriptorProto.decode(reader, reader.uint32()));
break;
}
case 8: {
message.options = $root.google.protobuf.FileOptions.decode(reader, reader.uint32());
break;
}
case 9: {
message.source_code_info = $root.google.protobuf.SourceCodeInfo.decode(reader, reader.uint32());
break;
}
case 12: {
message.syntax = reader.string();
break;
}
case 14: {
message.edition = reader.int32();
break;
}
default:
reader.skipType(tag & 7);
break;
}
}
return message;
};
/**
* Decodes a FileDescriptorProto message from the specified reader or buffer, length delimited.
* @function decodeDelimited
* @memberof google.protobuf.FileDescriptorProto
* @static
* @param {$protobuf.Reader|Uint8Array} reader Reader or buffer to decode from
* @returns {google.protobuf.FileDescriptorProto} FileDescriptorProto
* @throws {Error} If the payload is not a reader or valid buffer
* @throws {$protobuf.util.ProtocolError} If required fields are missing
*/
FileDescriptorProto.decodeDelimited = function decodeDelimited(reader) {
if (!(reader instanceof $Reader))
reader = new $Reader(reader);
return this.decode(reader, reader.uint32());
};
/**
* Verifies a FileDescriptorProto message.
* @function verify
* @memberof google.protobuf.FileDescriptorProto
* @static
* @param {Object.<string,*>} message Plain object to verify
* @returns {string|null} `null` if valid, otherwise the reason why it is not
*/
FileDescriptorProto.verify = function verify(message) {
if (typeof message !== "object" || message === null)
return "object expected";
if (message.name != null && message.hasOwnProperty("name"))
if (!$util.isString(message.name))
return "name: string expected";
if (message["package"] != null && message.hasOwnProperty("package"))
if (!$util.isString(message["package"]))
return "package: string expected";
if (message.dependency != null && message.hasOwnProperty("dependency")) {
if (!Array.isArray(message.dependency))
return "dependency: array expected";
for (var i = 0; i < message.dependency.length; ++i)
if (!$util.isString(message.dependency[i]))
return "dependency: string[] expected";
}
if (message.public_dependency != null && message.hasOwnProperty("public_dependency")) {
if (!Array.isArray(message.public_dependency))
return "public_dependency: array expected";
for (var i = 0; i < message.public_dependency.length; ++i)
if (!$util.isInteger(message.public_dependency[i]))
return "public_dependency: integer[] expected";
}
if (message.weak_dependency != null && message.hasOwnProperty("weak_dependency")) {
if (!Array.isArray(message.weak_dependency))
return "weak_dependency: array expected";
for (var i = 0; i < message.weak_dependency.length; ++i)
if (!$util.isInteger(message.weak_dependency[i]))
return "weak_dependency: integer[] expected";
}
if (message.option_dependency != null && message.hasOwnProperty("option_dependency")) {
if (!Array.isArray(message.option_dependency))
return "option_dependency: array expected";
for (var i = 0; i < message.option_dependency.length; ++i)
if (!$util.isString(message.option_dependency[i]))
return "option_dependency: string[] expected";
}
if (message.message_type != null && message.hasOwnProperty("message_type")) {
if (!Array.isArray(message.message_type))
return "message_type: array expected";
for (var i = 0; i < message.message_type.length; ++i) {
var error = $root.google.protobuf.DescriptorProto.verify(message.message_type[i]);
if (error)
return "message_type." + error;
}
}
if (message.enum_type != null && message.hasOwnProperty("enum_type")) {
if (!Array.isArray(message.enum_type))
return "enum_type: array expected";
for (var i = 0; i < message.enum_type.length; ++i) {
var error = $root.google.protobuf.EnumDescriptorProto.verify(message.enum_type[i]);
if (error)
return "enum_type." + error;
}
}
if (message.service != null && message.hasOwnProperty("service")) {
if (!Array.isArray(message.service))
return "service: array expected";
for (var i = 0; i < message.service.length; ++i) {
var error = $root.google.protobuf.ServiceDescriptorProto.verify(message.service[i]);
if (error)
return "service." + error;
}
}
if (message.extension != null && message.hasOwnProperty("extension")) {
if (!Array.isArray(message.extension))
return "extension: array expected";
for (var i = 0; i < message.extension.length; ++i) {
var error = $root.google.protobuf.FieldDescriptorProto.verify(message.extension[i]);
if (error)
return "extension." + error;
}
}
if (message.options != null && message.hasOwnProperty("options")) {
var error = $root.google.protobuf.FileOptions.verify(message.options);
if (error)
return "options." + error;
}
if (message.source_code_info != null && message.hasOwnProperty("source_code_info")) {
var error = $root.google.protobuf.SourceCodeInfo.verify(message.source_code_info);
if (error)
return "source_code_info." + error;
}
if (message.syntax != null && message.hasOwnProperty("syntax"))
if (!$util.isString(message.syntax))
return "syntax: string expected";
if (message.edition != null && message.hasOwnProperty("edition"))
switch (message.edition) {
default:
return "edition: enum value expected";
case 0:
case 900:
case 998:
case 999:
case 1000:
case 1001:
case 1:
case 2:
case 99997:
case 99998:
case 99999:
case 2147483647:
break;
}
return null;
};
/**
* Creates a FileDescriptorProto message from a plain object. Also converts values to their respective internal types.
* @function fromObject
* @memberof google.protobuf.FileDescriptorProto
* @static
* @param {Object.<string,*>} object Plain object
* @returns {google.protobuf.FileDescriptorProto} FileDescriptorProto
*/
FileDescriptorProto.fromObject = function fromObject(object) {
if (object instanceof $root.google.protobuf.FileDescriptorProto)
return object;
var message = new $root.google.protobuf.FileDescriptorProto();
if (object.name != null)
message.name = String(object.name);
if (object["package"] != null)
message["package"] = String(object["package"]);
if (object.dependency) {
if (!Array.isArray(object.dependency))
throw TypeError(".google.protobuf.FileDescriptorProto.dependency: array expected");
message.dependency = [];
for (var i = 0; i < object.dependency.length; ++i)
message.dependency[i] = String(object.dependency[i]);
}
if (object.public_dependency) {
if (!Array.isArray(object.public_dependency))
throw TypeError(".google.protobuf.FileDescriptorProto.public_dependency: array expected");
message.public_dependency = [];
for (var i = 0; i < object.public_dependency.length; ++i)
message.public_dependency[i] = object.public_dependency[i] | 0;
}
if (object.weak_dependency) {
if (!Array.isArray(object.weak_dependency))
throw TypeError(".google.protobuf.FileDescriptorProto.weak_dependency: array expected");
message.weak_dependency = [];
for (var i = 0; i < object.weak_dependency.length; ++i)
message.weak_dependency[i] = object.weak_dependency[i] | 0;
}
if (object.option_dependency) {
if (!Array.isArray(object.option_dependency))
throw TypeError(".google.protobuf.FileDescriptorProto.option_dependency: array expected");
message.option_dependency = [];
for (var i = 0; i < object.option_dependency.length; ++i)
message.option_dependency[i] = String(object.option_dependency[i]);
}
if (object.message_type) {
if (!Array.isArray(object.message_type))
throw TypeError(".google.protobuf.FileDescriptorProto.message_type: array expected");
message.message_type = [];
for (var i = 0; i < object.message_type.length; ++i) {
if (typeof object.message_type[i] !== "object")
throw TypeError(".google.protobuf.FileDescriptorProto.message_type: object expected");
message.message_type[i] = $root.google.protobuf.DescriptorProto.fromObject(object.message_type[i]);
}
}
if (object.enum_type) {
if (!Array.isArray(object.enum_type))
throw TypeError(".google.protobuf.FileDescriptorProto.enum_type: array expected");
message.enum_type = [];
for (var i = 0; i < object.enum_type.length; ++i) {
if (typeof object.enum_type[i] !== "object")
throw TypeError(".google.protobuf.FileDescriptorProto.enum_type: object expected");
message.enum_type[i] = $root.google.protobuf.EnumDescriptorProto.fromObject(object.enum_type[i]);
}
}
if (object.service) {
if (!Array.isArray(object.service))
throw TypeError(".google.protobuf.FileDescriptorProto.service: array expected");
message.service = [];
for (var i = 0; i < object.service.length; ++i) {
if (typeof object.service[i] !== "object")
throw TypeError(".google.protobuf.FileDescriptorProto.service: object expected");