protobufjs 7.3.2 → 7.3.3

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (77) hide show
  1. package/LICENSE +39 -39
  2. package/README.md +727 -727
  3. package/ext/debug/README.md +4 -4
  4. package/ext/debug/index.js +71 -71
  5. package/ext/descriptor/README.md +72 -72
  6. package/ext/descriptor/index.d.ts +191 -191
  7. package/ext/descriptor/index.js +1052 -1052
  8. package/ext/descriptor/test.js +54 -54
  9. package/google/LICENSE +27 -27
  10. package/google/README.md +1 -1
  11. package/google/api/annotations.json +82 -82
  12. package/google/api/annotations.proto +10 -10
  13. package/google/api/http.json +85 -85
  14. package/google/api/http.proto +30 -30
  15. package/google/protobuf/api.json +117 -117
  16. package/google/protobuf/api.proto +33 -33
  17. package/google/protobuf/descriptor.json +738 -738
  18. package/google/protobuf/descriptor.proto +286 -286
  19. package/google/protobuf/source_context.json +19 -19
  20. package/google/protobuf/source_context.proto +7 -7
  21. package/google/protobuf/type.json +201 -201
  22. package/google/protobuf/type.proto +89 -89
  23. package/index.d.ts +2741 -2741
  24. package/index.js +4 -4
  25. package/light.d.ts +2 -2
  26. package/light.js +3 -3
  27. package/minimal.d.ts +2 -2
  28. package/minimal.js +4 -4
  29. package/package.json +111 -111
  30. package/scripts/postinstall.js +32 -32
  31. package/src/common.js +399 -399
  32. package/src/converter.js +301 -301
  33. package/src/decoder.js +129 -129
  34. package/src/encoder.js +100 -100
  35. package/src/enum.js +198 -198
  36. package/src/field.js +377 -377
  37. package/src/index-light.js +104 -104
  38. package/src/index-minimal.js +36 -36
  39. package/src/index.js +12 -12
  40. package/src/mapfield.js +126 -126
  41. package/src/message.js +138 -138
  42. package/src/method.js +160 -160
  43. package/src/namespace.js +433 -433
  44. package/src/object.js +243 -243
  45. package/src/oneof.js +203 -203
  46. package/src/parse.js +893 -889
  47. package/src/reader.js +416 -416
  48. package/src/reader_buffer.js +51 -51
  49. package/src/root.js +368 -368
  50. package/src/roots.js +18 -18
  51. package/src/rpc/service.js +142 -142
  52. package/src/rpc.js +36 -36
  53. package/src/service.js +167 -167
  54. package/src/tokenize.js +416 -416
  55. package/src/type.js +589 -589
  56. package/src/types.js +196 -196
  57. package/src/typescript.jsdoc +15 -15
  58. package/src/util/longbits.js +200 -200
  59. package/src/util/minimal.js +438 -438
  60. package/src/util.js +212 -212
  61. package/src/verifier.js +176 -176
  62. package/src/wrappers.js +102 -102
  63. package/src/writer.js +465 -465
  64. package/src/writer_buffer.js +85 -85
  65. package/tsconfig.json +7 -7
  66. package/dist/light/protobuf.js +0 -7381
  67. package/dist/light/protobuf.js.map +0 -1
  68. package/dist/light/protobuf.min.js +0 -8
  69. package/dist/light/protobuf.min.js.map +0 -1
  70. package/dist/minimal/protobuf.js +0 -2736
  71. package/dist/minimal/protobuf.js.map +0 -1
  72. package/dist/minimal/protobuf.min.js +0 -8
  73. package/dist/minimal/protobuf.min.js.map +0 -1
  74. package/dist/protobuf.js +0 -9105
  75. package/dist/protobuf.js.map +0 -1
  76. package/dist/protobuf.min.js +0 -8
  77. package/dist/protobuf.min.js.map +0 -1
package/src/field.js CHANGED
@@ -1,377 +1,377 @@
1
- "use strict";
2
- module.exports = Field;
3
-
4
- // extends ReflectionObject
5
- var ReflectionObject = require("./object");
6
- ((Field.prototype = Object.create(ReflectionObject.prototype)).constructor = Field).className = "Field";
7
-
8
- var Enum = require("./enum"),
9
- types = require("./types"),
10
- util = require("./util");
11
-
12
- var Type; // cyclic
13
-
14
- var ruleRe = /^required|optional|repeated$/;
15
-
16
- /**
17
- * Constructs a new message field instance. Note that {@link MapField|map fields} have their own class.
18
- * @name Field
19
- * @classdesc Reflected message field.
20
- * @extends FieldBase
21
- * @constructor
22
- * @param {string} name Unique name within its namespace
23
- * @param {number} id Unique id within its namespace
24
- * @param {string} type Value type
25
- * @param {string|Object.<string,*>} [rule="optional"] Field rule
26
- * @param {string|Object.<string,*>} [extend] Extended type if different from parent
27
- * @param {Object.<string,*>} [options] Declared options
28
- */
29
-
30
- /**
31
- * Constructs a field from a field descriptor.
32
- * @param {string} name Field name
33
- * @param {IField} json Field descriptor
34
- * @returns {Field} Created field
35
- * @throws {TypeError} If arguments are invalid
36
- */
37
- Field.fromJSON = function fromJSON(name, json) {
38
- return new Field(name, json.id, json.type, json.rule, json.extend, json.options, json.comment);
39
- };
40
-
41
- /**
42
- * Not an actual constructor. Use {@link Field} instead.
43
- * @classdesc Base class of all reflected message fields. This is not an actual class but here for the sake of having consistent type definitions.
44
- * @exports FieldBase
45
- * @extends ReflectionObject
46
- * @constructor
47
- * @param {string} name Unique name within its namespace
48
- * @param {number} id Unique id within its namespace
49
- * @param {string} type Value type
50
- * @param {string|Object.<string,*>} [rule="optional"] Field rule
51
- * @param {string|Object.<string,*>} [extend] Extended type if different from parent
52
- * @param {Object.<string,*>} [options] Declared options
53
- * @param {string} [comment] Comment associated with this field
54
- */
55
- function Field(name, id, type, rule, extend, options, comment) {
56
-
57
- if (util.isObject(rule)) {
58
- comment = extend;
59
- options = rule;
60
- rule = extend = undefined;
61
- } else if (util.isObject(extend)) {
62
- comment = options;
63
- options = extend;
64
- extend = undefined;
65
- }
66
-
67
- ReflectionObject.call(this, name, options);
68
-
69
- if (!util.isInteger(id) || id < 0)
70
- throw TypeError("id must be a non-negative integer");
71
-
72
- if (!util.isString(type))
73
- throw TypeError("type must be a string");
74
-
75
- if (rule !== undefined && !ruleRe.test(rule = rule.toString().toLowerCase()))
76
- throw TypeError("rule must be a string rule");
77
-
78
- if (extend !== undefined && !util.isString(extend))
79
- throw TypeError("extend must be a string");
80
-
81
- /**
82
- * Field rule, if any.
83
- * @type {string|undefined}
84
- */
85
- if (rule === "proto3_optional") {
86
- rule = "optional";
87
- }
88
- this.rule = rule && rule !== "optional" ? rule : undefined; // toJSON
89
-
90
- /**
91
- * Field type.
92
- * @type {string}
93
- */
94
- this.type = type; // toJSON
95
-
96
- /**
97
- * Unique field id.
98
- * @type {number}
99
- */
100
- this.id = id; // toJSON, marker
101
-
102
- /**
103
- * Extended type if different from parent.
104
- * @type {string|undefined}
105
- */
106
- this.extend = extend || undefined; // toJSON
107
-
108
- /**
109
- * Whether this field is required.
110
- * @type {boolean}
111
- */
112
- this.required = rule === "required";
113
-
114
- /**
115
- * Whether this field is optional.
116
- * @type {boolean}
117
- */
118
- this.optional = !this.required;
119
-
120
- /**
121
- * Whether this field is repeated.
122
- * @type {boolean}
123
- */
124
- this.repeated = rule === "repeated";
125
-
126
- /**
127
- * Whether this field is a map or not.
128
- * @type {boolean}
129
- */
130
- this.map = false;
131
-
132
- /**
133
- * Message this field belongs to.
134
- * @type {Type|null}
135
- */
136
- this.message = null;
137
-
138
- /**
139
- * OneOf this field belongs to, if any,
140
- * @type {OneOf|null}
141
- */
142
- this.partOf = null;
143
-
144
- /**
145
- * The field type's default value.
146
- * @type {*}
147
- */
148
- this.typeDefault = null;
149
-
150
- /**
151
- * The field's default value on prototypes.
152
- * @type {*}
153
- */
154
- this.defaultValue = null;
155
-
156
- /**
157
- * Whether this field's value should be treated as a long.
158
- * @type {boolean}
159
- */
160
- this.long = util.Long ? types.long[type] !== undefined : /* istanbul ignore next */ false;
161
-
162
- /**
163
- * Whether this field's value is a buffer.
164
- * @type {boolean}
165
- */
166
- this.bytes = type === "bytes";
167
-
168
- /**
169
- * Resolved type if not a basic type.
170
- * @type {Type|Enum|null}
171
- */
172
- this.resolvedType = null;
173
-
174
- /**
175
- * Sister-field within the extended type if a declaring extension field.
176
- * @type {Field|null}
177
- */
178
- this.extensionField = null;
179
-
180
- /**
181
- * Sister-field within the declaring namespace if an extended field.
182
- * @type {Field|null}
183
- */
184
- this.declaringField = null;
185
-
186
- /**
187
- * Internally remembers whether this field is packed.
188
- * @type {boolean|null}
189
- * @private
190
- */
191
- this._packed = null;
192
-
193
- /**
194
- * Comment for this field.
195
- * @type {string|null}
196
- */
197
- this.comment = comment;
198
- }
199
-
200
- /**
201
- * Determines whether this field is packed. Only relevant when repeated and working with proto2.
202
- * @name Field#packed
203
- * @type {boolean}
204
- * @readonly
205
- */
206
- Object.defineProperty(Field.prototype, "packed", {
207
- get: function() {
208
- // defaults to packed=true if not explicity set to false
209
- if (this._packed === null)
210
- this._packed = this.getOption("packed") !== false;
211
- return this._packed;
212
- }
213
- });
214
-
215
- /**
216
- * @override
217
- */
218
- Field.prototype.setOption = function setOption(name, value, ifNotSet) {
219
- if (name === "packed") // clear cached before setting
220
- this._packed = null;
221
- return ReflectionObject.prototype.setOption.call(this, name, value, ifNotSet);
222
- };
223
-
224
- /**
225
- * Field descriptor.
226
- * @interface IField
227
- * @property {string} [rule="optional"] Field rule
228
- * @property {string} type Field type
229
- * @property {number} id Field id
230
- * @property {Object.<string,*>} [options] Field options
231
- */
232
-
233
- /**
234
- * Extension field descriptor.
235
- * @interface IExtensionField
236
- * @extends IField
237
- * @property {string} extend Extended type
238
- */
239
-
240
- /**
241
- * Converts this field to a field descriptor.
242
- * @param {IToJSONOptions} [toJSONOptions] JSON conversion options
243
- * @returns {IField} Field descriptor
244
- */
245
- Field.prototype.toJSON = function toJSON(toJSONOptions) {
246
- var keepComments = toJSONOptions ? Boolean(toJSONOptions.keepComments) : false;
247
- return util.toObject([
248
- "rule" , this.rule !== "optional" && this.rule || undefined,
249
- "type" , this.type,
250
- "id" , this.id,
251
- "extend" , this.extend,
252
- "options" , this.options,
253
- "comment" , keepComments ? this.comment : undefined
254
- ]);
255
- };
256
-
257
- /**
258
- * Resolves this field's type references.
259
- * @returns {Field} `this`
260
- * @throws {Error} If any reference cannot be resolved
261
- */
262
- Field.prototype.resolve = function resolve() {
263
-
264
- if (this.resolved)
265
- return this;
266
-
267
- if ((this.typeDefault = types.defaults[this.type]) === undefined) { // if not a basic type, resolve it
268
- this.resolvedType = (this.declaringField ? this.declaringField.parent : this.parent).lookupTypeOrEnum(this.type);
269
- if (this.resolvedType instanceof Type)
270
- this.typeDefault = null;
271
- else // instanceof Enum
272
- this.typeDefault = this.resolvedType.values[Object.keys(this.resolvedType.values)[0]]; // first defined
273
- } else if (this.options && this.options.proto3_optional) {
274
- // proto3 scalar value marked optional; should default to null
275
- this.typeDefault = null;
276
- }
277
-
278
- // use explicitly set default value if present
279
- if (this.options && this.options["default"] != null) {
280
- this.typeDefault = this.options["default"];
281
- if (this.resolvedType instanceof Enum && typeof this.typeDefault === "string")
282
- this.typeDefault = this.resolvedType.values[this.typeDefault];
283
- }
284
-
285
- // remove unnecessary options
286
- if (this.options) {
287
- if (this.options.packed === true || this.options.packed !== undefined && this.resolvedType && !(this.resolvedType instanceof Enum))
288
- delete this.options.packed;
289
- if (!Object.keys(this.options).length)
290
- this.options = undefined;
291
- }
292
-
293
- // convert to internal data type if necesssary
294
- if (this.long) {
295
- this.typeDefault = util.Long.fromNumber(this.typeDefault, this.type.charAt(0) === "u");
296
-
297
- /* istanbul ignore else */
298
- if (Object.freeze)
299
- Object.freeze(this.typeDefault); // long instances are meant to be immutable anyway (i.e. use small int cache that even requires it)
300
-
301
- } else if (this.bytes && typeof this.typeDefault === "string") {
302
- var buf;
303
- if (util.base64.test(this.typeDefault))
304
- util.base64.decode(this.typeDefault, buf = util.newBuffer(util.base64.length(this.typeDefault)), 0);
305
- else
306
- util.utf8.write(this.typeDefault, buf = util.newBuffer(util.utf8.length(this.typeDefault)), 0);
307
- this.typeDefault = buf;
308
- }
309
-
310
- // take special care of maps and repeated fields
311
- if (this.map)
312
- this.defaultValue = util.emptyObject;
313
- else if (this.repeated)
314
- this.defaultValue = util.emptyArray;
315
- else
316
- this.defaultValue = this.typeDefault;
317
-
318
- // ensure proper value on prototype
319
- if (this.parent instanceof Type)
320
- this.parent.ctor.prototype[this.name] = this.defaultValue;
321
-
322
- return ReflectionObject.prototype.resolve.call(this);
323
- };
324
-
325
- /**
326
- * Decorator function as returned by {@link Field.d} and {@link MapField.d} (TypeScript).
327
- * @typedef FieldDecorator
328
- * @type {function}
329
- * @param {Object} prototype Target prototype
330
- * @param {string} fieldName Field name
331
- * @returns {undefined}
332
- */
333
-
334
- /**
335
- * Field decorator (TypeScript).
336
- * @name Field.d
337
- * @function
338
- * @param {number} fieldId Field id
339
- * @param {"double"|"float"|"int32"|"uint32"|"sint32"|"fixed32"|"sfixed32"|"int64"|"uint64"|"sint64"|"fixed64"|"sfixed64"|"string"|"bool"|"bytes"|Object} fieldType Field type
340
- * @param {"optional"|"required"|"repeated"} [fieldRule="optional"] Field rule
341
- * @param {T} [defaultValue] Default value
342
- * @returns {FieldDecorator} Decorator function
343
- * @template T extends number | number[] | Long | Long[] | string | string[] | boolean | boolean[] | Uint8Array | Uint8Array[] | Buffer | Buffer[]
344
- */
345
- Field.d = function decorateField(fieldId, fieldType, fieldRule, defaultValue) {
346
-
347
- // submessage: decorate the submessage and use its name as the type
348
- if (typeof fieldType === "function")
349
- fieldType = util.decorateType(fieldType).name;
350
-
351
- // enum reference: create a reflected copy of the enum and keep reuseing it
352
- else if (fieldType && typeof fieldType === "object")
353
- fieldType = util.decorateEnum(fieldType).name;
354
-
355
- return function fieldDecorator(prototype, fieldName) {
356
- util.decorateType(prototype.constructor)
357
- .add(new Field(fieldName, fieldId, fieldType, fieldRule, { "default": defaultValue }));
358
- };
359
- };
360
-
361
- /**
362
- * Field decorator (TypeScript).
363
- * @name Field.d
364
- * @function
365
- * @param {number} fieldId Field id
366
- * @param {Constructor<T>|string} fieldType Field type
367
- * @param {"optional"|"required"|"repeated"} [fieldRule="optional"] Field rule
368
- * @returns {FieldDecorator} Decorator function
369
- * @template T extends Message<T>
370
- * @variation 2
371
- */
372
- // like Field.d but without a default value
373
-
374
- // Sets up cyclic dependencies (called in index-light)
375
- Field._configure = function configure(Type_) {
376
- Type = Type_;
377
- };
1
+ "use strict";
2
+ module.exports = Field;
3
+
4
+ // extends ReflectionObject
5
+ var ReflectionObject = require("./object");
6
+ ((Field.prototype = Object.create(ReflectionObject.prototype)).constructor = Field).className = "Field";
7
+
8
+ var Enum = require("./enum"),
9
+ types = require("./types"),
10
+ util = require("./util");
11
+
12
+ var Type; // cyclic
13
+
14
+ var ruleRe = /^required|optional|repeated$/;
15
+
16
+ /**
17
+ * Constructs a new message field instance. Note that {@link MapField|map fields} have their own class.
18
+ * @name Field
19
+ * @classdesc Reflected message field.
20
+ * @extends FieldBase
21
+ * @constructor
22
+ * @param {string} name Unique name within its namespace
23
+ * @param {number} id Unique id within its namespace
24
+ * @param {string} type Value type
25
+ * @param {string|Object.<string,*>} [rule="optional"] Field rule
26
+ * @param {string|Object.<string,*>} [extend] Extended type if different from parent
27
+ * @param {Object.<string,*>} [options] Declared options
28
+ */
29
+
30
+ /**
31
+ * Constructs a field from a field descriptor.
32
+ * @param {string} name Field name
33
+ * @param {IField} json Field descriptor
34
+ * @returns {Field} Created field
35
+ * @throws {TypeError} If arguments are invalid
36
+ */
37
+ Field.fromJSON = function fromJSON(name, json) {
38
+ return new Field(name, json.id, json.type, json.rule, json.extend, json.options, json.comment);
39
+ };
40
+
41
+ /**
42
+ * Not an actual constructor. Use {@link Field} instead.
43
+ * @classdesc Base class of all reflected message fields. This is not an actual class but here for the sake of having consistent type definitions.
44
+ * @exports FieldBase
45
+ * @extends ReflectionObject
46
+ * @constructor
47
+ * @param {string} name Unique name within its namespace
48
+ * @param {number} id Unique id within its namespace
49
+ * @param {string} type Value type
50
+ * @param {string|Object.<string,*>} [rule="optional"] Field rule
51
+ * @param {string|Object.<string,*>} [extend] Extended type if different from parent
52
+ * @param {Object.<string,*>} [options] Declared options
53
+ * @param {string} [comment] Comment associated with this field
54
+ */
55
+ function Field(name, id, type, rule, extend, options, comment) {
56
+
57
+ if (util.isObject(rule)) {
58
+ comment = extend;
59
+ options = rule;
60
+ rule = extend = undefined;
61
+ } else if (util.isObject(extend)) {
62
+ comment = options;
63
+ options = extend;
64
+ extend = undefined;
65
+ }
66
+
67
+ ReflectionObject.call(this, name, options);
68
+
69
+ if (!util.isInteger(id) || id < 0)
70
+ throw TypeError("id must be a non-negative integer");
71
+
72
+ if (!util.isString(type))
73
+ throw TypeError("type must be a string");
74
+
75
+ if (rule !== undefined && !ruleRe.test(rule = rule.toString().toLowerCase()))
76
+ throw TypeError("rule must be a string rule");
77
+
78
+ if (extend !== undefined && !util.isString(extend))
79
+ throw TypeError("extend must be a string");
80
+
81
+ /**
82
+ * Field rule, if any.
83
+ * @type {string|undefined}
84
+ */
85
+ if (rule === "proto3_optional") {
86
+ rule = "optional";
87
+ }
88
+ this.rule = rule && rule !== "optional" ? rule : undefined; // toJSON
89
+
90
+ /**
91
+ * Field type.
92
+ * @type {string}
93
+ */
94
+ this.type = type; // toJSON
95
+
96
+ /**
97
+ * Unique field id.
98
+ * @type {number}
99
+ */
100
+ this.id = id; // toJSON, marker
101
+
102
+ /**
103
+ * Extended type if different from parent.
104
+ * @type {string|undefined}
105
+ */
106
+ this.extend = extend || undefined; // toJSON
107
+
108
+ /**
109
+ * Whether this field is required.
110
+ * @type {boolean}
111
+ */
112
+ this.required = rule === "required";
113
+
114
+ /**
115
+ * Whether this field is optional.
116
+ * @type {boolean}
117
+ */
118
+ this.optional = !this.required;
119
+
120
+ /**
121
+ * Whether this field is repeated.
122
+ * @type {boolean}
123
+ */
124
+ this.repeated = rule === "repeated";
125
+
126
+ /**
127
+ * Whether this field is a map or not.
128
+ * @type {boolean}
129
+ */
130
+ this.map = false;
131
+
132
+ /**
133
+ * Message this field belongs to.
134
+ * @type {Type|null}
135
+ */
136
+ this.message = null;
137
+
138
+ /**
139
+ * OneOf this field belongs to, if any,
140
+ * @type {OneOf|null}
141
+ */
142
+ this.partOf = null;
143
+
144
+ /**
145
+ * The field type's default value.
146
+ * @type {*}
147
+ */
148
+ this.typeDefault = null;
149
+
150
+ /**
151
+ * The field's default value on prototypes.
152
+ * @type {*}
153
+ */
154
+ this.defaultValue = null;
155
+
156
+ /**
157
+ * Whether this field's value should be treated as a long.
158
+ * @type {boolean}
159
+ */
160
+ this.long = util.Long ? types.long[type] !== undefined : /* istanbul ignore next */ false;
161
+
162
+ /**
163
+ * Whether this field's value is a buffer.
164
+ * @type {boolean}
165
+ */
166
+ this.bytes = type === "bytes";
167
+
168
+ /**
169
+ * Resolved type if not a basic type.
170
+ * @type {Type|Enum|null}
171
+ */
172
+ this.resolvedType = null;
173
+
174
+ /**
175
+ * Sister-field within the extended type if a declaring extension field.
176
+ * @type {Field|null}
177
+ */
178
+ this.extensionField = null;
179
+
180
+ /**
181
+ * Sister-field within the declaring namespace if an extended field.
182
+ * @type {Field|null}
183
+ */
184
+ this.declaringField = null;
185
+
186
+ /**
187
+ * Internally remembers whether this field is packed.
188
+ * @type {boolean|null}
189
+ * @private
190
+ */
191
+ this._packed = null;
192
+
193
+ /**
194
+ * Comment for this field.
195
+ * @type {string|null}
196
+ */
197
+ this.comment = comment;
198
+ }
199
+
200
+ /**
201
+ * Determines whether this field is packed. Only relevant when repeated and working with proto2.
202
+ * @name Field#packed
203
+ * @type {boolean}
204
+ * @readonly
205
+ */
206
+ Object.defineProperty(Field.prototype, "packed", {
207
+ get: function() {
208
+ // defaults to packed=true if not explicity set to false
209
+ if (this._packed === null)
210
+ this._packed = this.getOption("packed") !== false;
211
+ return this._packed;
212
+ }
213
+ });
214
+
215
+ /**
216
+ * @override
217
+ */
218
+ Field.prototype.setOption = function setOption(name, value, ifNotSet) {
219
+ if (name === "packed") // clear cached before setting
220
+ this._packed = null;
221
+ return ReflectionObject.prototype.setOption.call(this, name, value, ifNotSet);
222
+ };
223
+
224
+ /**
225
+ * Field descriptor.
226
+ * @interface IField
227
+ * @property {string} [rule="optional"] Field rule
228
+ * @property {string} type Field type
229
+ * @property {number} id Field id
230
+ * @property {Object.<string,*>} [options] Field options
231
+ */
232
+
233
+ /**
234
+ * Extension field descriptor.
235
+ * @interface IExtensionField
236
+ * @extends IField
237
+ * @property {string} extend Extended type
238
+ */
239
+
240
+ /**
241
+ * Converts this field to a field descriptor.
242
+ * @param {IToJSONOptions} [toJSONOptions] JSON conversion options
243
+ * @returns {IField} Field descriptor
244
+ */
245
+ Field.prototype.toJSON = function toJSON(toJSONOptions) {
246
+ var keepComments = toJSONOptions ? Boolean(toJSONOptions.keepComments) : false;
247
+ return util.toObject([
248
+ "rule" , this.rule !== "optional" && this.rule || undefined,
249
+ "type" , this.type,
250
+ "id" , this.id,
251
+ "extend" , this.extend,
252
+ "options" , this.options,
253
+ "comment" , keepComments ? this.comment : undefined
254
+ ]);
255
+ };
256
+
257
+ /**
258
+ * Resolves this field's type references.
259
+ * @returns {Field} `this`
260
+ * @throws {Error} If any reference cannot be resolved
261
+ */
262
+ Field.prototype.resolve = function resolve() {
263
+
264
+ if (this.resolved)
265
+ return this;
266
+
267
+ if ((this.typeDefault = types.defaults[this.type]) === undefined) { // if not a basic type, resolve it
268
+ this.resolvedType = (this.declaringField ? this.declaringField.parent : this.parent).lookupTypeOrEnum(this.type);
269
+ if (this.resolvedType instanceof Type)
270
+ this.typeDefault = null;
271
+ else // instanceof Enum
272
+ this.typeDefault = this.resolvedType.values[Object.keys(this.resolvedType.values)[0]]; // first defined
273
+ } else if (this.options && this.options.proto3_optional) {
274
+ // proto3 scalar value marked optional; should default to null
275
+ this.typeDefault = null;
276
+ }
277
+
278
+ // use explicitly set default value if present
279
+ if (this.options && this.options["default"] != null) {
280
+ this.typeDefault = this.options["default"];
281
+ if (this.resolvedType instanceof Enum && typeof this.typeDefault === "string")
282
+ this.typeDefault = this.resolvedType.values[this.typeDefault];
283
+ }
284
+
285
+ // remove unnecessary options
286
+ if (this.options) {
287
+ if (this.options.packed === true || this.options.packed !== undefined && this.resolvedType && !(this.resolvedType instanceof Enum))
288
+ delete this.options.packed;
289
+ if (!Object.keys(this.options).length)
290
+ this.options = undefined;
291
+ }
292
+
293
+ // convert to internal data type if necesssary
294
+ if (this.long) {
295
+ this.typeDefault = util.Long.fromNumber(this.typeDefault, this.type.charAt(0) === "u");
296
+
297
+ /* istanbul ignore else */
298
+ if (Object.freeze)
299
+ Object.freeze(this.typeDefault); // long instances are meant to be immutable anyway (i.e. use small int cache that even requires it)
300
+
301
+ } else if (this.bytes && typeof this.typeDefault === "string") {
302
+ var buf;
303
+ if (util.base64.test(this.typeDefault))
304
+ util.base64.decode(this.typeDefault, buf = util.newBuffer(util.base64.length(this.typeDefault)), 0);
305
+ else
306
+ util.utf8.write(this.typeDefault, buf = util.newBuffer(util.utf8.length(this.typeDefault)), 0);
307
+ this.typeDefault = buf;
308
+ }
309
+
310
+ // take special care of maps and repeated fields
311
+ if (this.map)
312
+ this.defaultValue = util.emptyObject;
313
+ else if (this.repeated)
314
+ this.defaultValue = util.emptyArray;
315
+ else
316
+ this.defaultValue = this.typeDefault;
317
+
318
+ // ensure proper value on prototype
319
+ if (this.parent instanceof Type)
320
+ this.parent.ctor.prototype[this.name] = this.defaultValue;
321
+
322
+ return ReflectionObject.prototype.resolve.call(this);
323
+ };
324
+
325
+ /**
326
+ * Decorator function as returned by {@link Field.d} and {@link MapField.d} (TypeScript).
327
+ * @typedef FieldDecorator
328
+ * @type {function}
329
+ * @param {Object} prototype Target prototype
330
+ * @param {string} fieldName Field name
331
+ * @returns {undefined}
332
+ */
333
+
334
+ /**
335
+ * Field decorator (TypeScript).
336
+ * @name Field.d
337
+ * @function
338
+ * @param {number} fieldId Field id
339
+ * @param {"double"|"float"|"int32"|"uint32"|"sint32"|"fixed32"|"sfixed32"|"int64"|"uint64"|"sint64"|"fixed64"|"sfixed64"|"string"|"bool"|"bytes"|Object} fieldType Field type
340
+ * @param {"optional"|"required"|"repeated"} [fieldRule="optional"] Field rule
341
+ * @param {T} [defaultValue] Default value
342
+ * @returns {FieldDecorator} Decorator function
343
+ * @template T extends number | number[] | Long | Long[] | string | string[] | boolean | boolean[] | Uint8Array | Uint8Array[] | Buffer | Buffer[]
344
+ */
345
+ Field.d = function decorateField(fieldId, fieldType, fieldRule, defaultValue) {
346
+
347
+ // submessage: decorate the submessage and use its name as the type
348
+ if (typeof fieldType === "function")
349
+ fieldType = util.decorateType(fieldType).name;
350
+
351
+ // enum reference: create a reflected copy of the enum and keep reuseing it
352
+ else if (fieldType && typeof fieldType === "object")
353
+ fieldType = util.decorateEnum(fieldType).name;
354
+
355
+ return function fieldDecorator(prototype, fieldName) {
356
+ util.decorateType(prototype.constructor)
357
+ .add(new Field(fieldName, fieldId, fieldType, fieldRule, { "default": defaultValue }));
358
+ };
359
+ };
360
+
361
+ /**
362
+ * Field decorator (TypeScript).
363
+ * @name Field.d
364
+ * @function
365
+ * @param {number} fieldId Field id
366
+ * @param {Constructor<T>|string} fieldType Field type
367
+ * @param {"optional"|"required"|"repeated"} [fieldRule="optional"] Field rule
368
+ * @returns {FieldDecorator} Decorator function
369
+ * @template T extends Message<T>
370
+ * @variation 2
371
+ */
372
+ // like Field.d but without a default value
373
+
374
+ // Sets up cyclic dependencies (called in index-light)
375
+ Field._configure = function configure(Type_) {
376
+ Type = Type_;
377
+ };