protobufjs 6.8.8 → 6.9.0

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 (108) hide show
  1. package/CHANGELOG.md +941 -921
  2. package/LICENSE +39 -39
  3. package/README.md +901 -879
  4. package/cli/LICENSE +33 -33
  5. package/cli/README.md +11 -11
  6. package/cli/index.d.ts +3 -3
  7. package/cli/index.js +3 -3
  8. package/cli/lib/tsd-jsdoc/LICENSE +20 -20
  9. package/cli/lib/tsd-jsdoc/README.md +23 -23
  10. package/cli/lib/tsd-jsdoc/plugin.js +21 -21
  11. package/cli/lib/tsd-jsdoc/publish.js +705 -693
  12. package/cli/lib/tsd-jsdoc.json +18 -18
  13. package/cli/package.json +1 -1
  14. package/cli/package.standalone.json +32 -32
  15. package/cli/pbjs.d.ts +9 -9
  16. package/cli/pbjs.js +329 -329
  17. package/cli/pbts.d.ts +9 -9
  18. package/cli/pbts.js +197 -197
  19. package/cli/targets/json-module.js +38 -38
  20. package/cli/targets/json.js +8 -8
  21. package/cli/targets/proto.js +326 -326
  22. package/cli/targets/proto2.js +10 -10
  23. package/cli/targets/proto3.js +10 -10
  24. package/cli/targets/static-module.js +29 -29
  25. package/cli/targets/static.js +702 -702
  26. package/cli/util.js +183 -183
  27. package/cli/wrappers/amd.js +7 -7
  28. package/cli/wrappers/closure.js +7 -7
  29. package/cli/wrappers/commonjs.js +7 -7
  30. package/cli/wrappers/default.js +15 -15
  31. package/cli/wrappers/es6.js +5 -5
  32. package/dist/README.md +31 -31
  33. package/dist/light/README.md +31 -31
  34. package/dist/light/protobuf.js +6058 -6032
  35. package/dist/light/protobuf.js.map +1 -1
  36. package/dist/light/protobuf.min.js +3 -3
  37. package/dist/light/protobuf.min.js.map +1 -1
  38. package/dist/minimal/README.md +31 -31
  39. package/dist/minimal/protobuf.js +1900 -1877
  40. package/dist/minimal/protobuf.js.map +1 -1
  41. package/dist/minimal/protobuf.min.js +3 -3
  42. package/dist/minimal/protobuf.min.js.map +1 -1
  43. package/dist/protobuf.js +7625 -7596
  44. package/dist/protobuf.js.map +1 -1
  45. package/dist/protobuf.min.js +3 -3
  46. package/dist/protobuf.min.js.map +1 -1
  47. package/ext/debug/README.md +4 -4
  48. package/ext/debug/index.js +71 -71
  49. package/ext/descriptor/README.md +72 -72
  50. package/ext/descriptor/index.js +1052 -1052
  51. package/ext/descriptor/test.js +54 -54
  52. package/google/LICENSE +27 -27
  53. package/google/README.md +1 -1
  54. package/google/api/annotations.proto +10 -10
  55. package/google/protobuf/descriptor.proto +286 -286
  56. package/google/protobuf/source_context.proto +7 -7
  57. package/index.d.ts +6 -6
  58. package/index.js +4 -4
  59. package/light.d.ts +2 -2
  60. package/light.js +3 -3
  61. package/minimal.d.ts +2 -2
  62. package/minimal.js +4 -4
  63. package/package-lock.json +4223 -3171
  64. package/package.json +122 -122
  65. package/scripts/changelog.js +150 -150
  66. package/scripts/postinstall.js +35 -35
  67. package/src/common.js +399 -399
  68. package/src/converter.js +293 -293
  69. package/src/decoder.js +106 -106
  70. package/src/encoder.js +100 -100
  71. package/src/enum.js +181 -181
  72. package/src/field.js +371 -371
  73. package/src/index-light.js +104 -104
  74. package/src/index-minimal.js +36 -36
  75. package/src/index.js +12 -12
  76. package/src/mapfield.js +126 -126
  77. package/src/message.js +138 -138
  78. package/src/method.js +151 -151
  79. package/src/namespace.js +433 -433
  80. package/src/object.js +200 -200
  81. package/src/oneof.js +203 -203
  82. package/src/parse.js +761 -758
  83. package/src/reader.js +411 -405
  84. package/src/reader_buffer.js +51 -44
  85. package/src/root.js +353 -351
  86. package/src/roots.js +18 -18
  87. package/src/rpc/service.js +142 -142
  88. package/src/rpc.js +36 -36
  89. package/src/service.js +167 -167
  90. package/src/tokenize.js +397 -397
  91. package/src/type.js +589 -589
  92. package/src/types.js +196 -196
  93. package/src/typescript.jsdoc +15 -15
  94. package/src/util/longbits.js +200 -200
  95. package/src/util/minimal.js +414 -414
  96. package/src/util.js +178 -178
  97. package/src/verifier.js +176 -176
  98. package/src/wrappers.js +83 -83
  99. package/src/writer.js +465 -459
  100. package/src/writer_buffer.js +85 -81
  101. package/tsconfig.json +6 -6
  102. package/cli/node_modules/os-tmpdir/index.js +0 -25
  103. package/cli/node_modules/os-tmpdir/license +0 -21
  104. package/cli/node_modules/os-tmpdir/readme.md +0 -32
  105. package/cli/node_modules/tmp/LICENSE +0 -21
  106. package/cli/node_modules/tmp/README.md +0 -314
  107. package/cli/node_modules/tmp/lib/tmp.js +0 -611
  108. package/cli/package-lock.json +0 -20
package/src/oneof.js CHANGED
@@ -1,203 +1,203 @@
1
- "use strict";
2
- module.exports = OneOf;
3
-
4
- // extends ReflectionObject
5
- var ReflectionObject = require("./object");
6
- ((OneOf.prototype = Object.create(ReflectionObject.prototype)).constructor = OneOf).className = "OneOf";
7
-
8
- var Field = require("./field"),
9
- util = require("./util");
10
-
11
- /**
12
- * Constructs a new oneof instance.
13
- * @classdesc Reflected oneof.
14
- * @extends ReflectionObject
15
- * @constructor
16
- * @param {string} name Oneof name
17
- * @param {string[]|Object.<string,*>} [fieldNames] Field names
18
- * @param {Object.<string,*>} [options] Declared options
19
- * @param {string} [comment] Comment associated with this field
20
- */
21
- function OneOf(name, fieldNames, options, comment) {
22
- if (!Array.isArray(fieldNames)) {
23
- options = fieldNames;
24
- fieldNames = undefined;
25
- }
26
- ReflectionObject.call(this, name, options);
27
-
28
- /* istanbul ignore if */
29
- if (!(fieldNames === undefined || Array.isArray(fieldNames)))
30
- throw TypeError("fieldNames must be an Array");
31
-
32
- /**
33
- * Field names that belong to this oneof.
34
- * @type {string[]}
35
- */
36
- this.oneof = fieldNames || []; // toJSON, marker
37
-
38
- /**
39
- * Fields that belong to this oneof as an array for iteration.
40
- * @type {Field[]}
41
- * @readonly
42
- */
43
- this.fieldsArray = []; // declared readonly for conformance, possibly not yet added to parent
44
-
45
- /**
46
- * Comment for this field.
47
- * @type {string|null}
48
- */
49
- this.comment = comment;
50
- }
51
-
52
- /**
53
- * Oneof descriptor.
54
- * @interface IOneOf
55
- * @property {Array.<string>} oneof Oneof field names
56
- * @property {Object.<string,*>} [options] Oneof options
57
- */
58
-
59
- /**
60
- * Constructs a oneof from a oneof descriptor.
61
- * @param {string} name Oneof name
62
- * @param {IOneOf} json Oneof descriptor
63
- * @returns {OneOf} Created oneof
64
- * @throws {TypeError} If arguments are invalid
65
- */
66
- OneOf.fromJSON = function fromJSON(name, json) {
67
- return new OneOf(name, json.oneof, json.options, json.comment);
68
- };
69
-
70
- /**
71
- * Converts this oneof to a oneof descriptor.
72
- * @param {IToJSONOptions} [toJSONOptions] JSON conversion options
73
- * @returns {IOneOf} Oneof descriptor
74
- */
75
- OneOf.prototype.toJSON = function toJSON(toJSONOptions) {
76
- var keepComments = toJSONOptions ? Boolean(toJSONOptions.keepComments) : false;
77
- return util.toObject([
78
- "options" , this.options,
79
- "oneof" , this.oneof,
80
- "comment" , keepComments ? this.comment : undefined
81
- ]);
82
- };
83
-
84
- /**
85
- * Adds the fields of the specified oneof to the parent if not already done so.
86
- * @param {OneOf} oneof The oneof
87
- * @returns {undefined}
88
- * @inner
89
- * @ignore
90
- */
91
- function addFieldsToParent(oneof) {
92
- if (oneof.parent)
93
- for (var i = 0; i < oneof.fieldsArray.length; ++i)
94
- if (!oneof.fieldsArray[i].parent)
95
- oneof.parent.add(oneof.fieldsArray[i]);
96
- }
97
-
98
- /**
99
- * Adds a field to this oneof and removes it from its current parent, if any.
100
- * @param {Field} field Field to add
101
- * @returns {OneOf} `this`
102
- */
103
- OneOf.prototype.add = function add(field) {
104
-
105
- /* istanbul ignore if */
106
- if (!(field instanceof Field))
107
- throw TypeError("field must be a Field");
108
-
109
- if (field.parent && field.parent !== this.parent)
110
- field.parent.remove(field);
111
- this.oneof.push(field.name);
112
- this.fieldsArray.push(field);
113
- field.partOf = this; // field.parent remains null
114
- addFieldsToParent(this);
115
- return this;
116
- };
117
-
118
- /**
119
- * Removes a field from this oneof and puts it back to the oneof's parent.
120
- * @param {Field} field Field to remove
121
- * @returns {OneOf} `this`
122
- */
123
- OneOf.prototype.remove = function remove(field) {
124
-
125
- /* istanbul ignore if */
126
- if (!(field instanceof Field))
127
- throw TypeError("field must be a Field");
128
-
129
- var index = this.fieldsArray.indexOf(field);
130
-
131
- /* istanbul ignore if */
132
- if (index < 0)
133
- throw Error(field + " is not a member of " + this);
134
-
135
- this.fieldsArray.splice(index, 1);
136
- index = this.oneof.indexOf(field.name);
137
-
138
- /* istanbul ignore else */
139
- if (index > -1) // theoretical
140
- this.oneof.splice(index, 1);
141
-
142
- field.partOf = null;
143
- return this;
144
- };
145
-
146
- /**
147
- * @override
148
- */
149
- OneOf.prototype.onAdd = function onAdd(parent) {
150
- ReflectionObject.prototype.onAdd.call(this, parent);
151
- var self = this;
152
- // Collect present fields
153
- for (var i = 0; i < this.oneof.length; ++i) {
154
- var field = parent.get(this.oneof[i]);
155
- if (field && !field.partOf) {
156
- field.partOf = self;
157
- self.fieldsArray.push(field);
158
- }
159
- }
160
- // Add not yet present fields
161
- addFieldsToParent(this);
162
- };
163
-
164
- /**
165
- * @override
166
- */
167
- OneOf.prototype.onRemove = function onRemove(parent) {
168
- for (var i = 0, field; i < this.fieldsArray.length; ++i)
169
- if ((field = this.fieldsArray[i]).parent)
170
- field.parent.remove(field);
171
- ReflectionObject.prototype.onRemove.call(this, parent);
172
- };
173
-
174
- /**
175
- * Decorator function as returned by {@link OneOf.d} (TypeScript).
176
- * @typedef OneOfDecorator
177
- * @type {function}
178
- * @param {Object} prototype Target prototype
179
- * @param {string} oneofName OneOf name
180
- * @returns {undefined}
181
- */
182
-
183
- /**
184
- * OneOf decorator (TypeScript).
185
- * @function
186
- * @param {...string} fieldNames Field names
187
- * @returns {OneOfDecorator} Decorator function
188
- * @template T extends string
189
- */
190
- OneOf.d = function decorateOneOf() {
191
- var fieldNames = new Array(arguments.length),
192
- index = 0;
193
- while (index < arguments.length)
194
- fieldNames[index] = arguments[index++];
195
- return function oneOfDecorator(prototype, oneofName) {
196
- util.decorateType(prototype.constructor)
197
- .add(new OneOf(oneofName, fieldNames));
198
- Object.defineProperty(prototype, oneofName, {
199
- get: util.oneOfGetter(fieldNames),
200
- set: util.oneOfSetter(fieldNames)
201
- });
202
- };
203
- };
1
+ "use strict";
2
+ module.exports = OneOf;
3
+
4
+ // extends ReflectionObject
5
+ var ReflectionObject = require("./object");
6
+ ((OneOf.prototype = Object.create(ReflectionObject.prototype)).constructor = OneOf).className = "OneOf";
7
+
8
+ var Field = require("./field"),
9
+ util = require("./util");
10
+
11
+ /**
12
+ * Constructs a new oneof instance.
13
+ * @classdesc Reflected oneof.
14
+ * @extends ReflectionObject
15
+ * @constructor
16
+ * @param {string} name Oneof name
17
+ * @param {string[]|Object.<string,*>} [fieldNames] Field names
18
+ * @param {Object.<string,*>} [options] Declared options
19
+ * @param {string} [comment] Comment associated with this field
20
+ */
21
+ function OneOf(name, fieldNames, options, comment) {
22
+ if (!Array.isArray(fieldNames)) {
23
+ options = fieldNames;
24
+ fieldNames = undefined;
25
+ }
26
+ ReflectionObject.call(this, name, options);
27
+
28
+ /* istanbul ignore if */
29
+ if (!(fieldNames === undefined || Array.isArray(fieldNames)))
30
+ throw TypeError("fieldNames must be an Array");
31
+
32
+ /**
33
+ * Field names that belong to this oneof.
34
+ * @type {string[]}
35
+ */
36
+ this.oneof = fieldNames || []; // toJSON, marker
37
+
38
+ /**
39
+ * Fields that belong to this oneof as an array for iteration.
40
+ * @type {Field[]}
41
+ * @readonly
42
+ */
43
+ this.fieldsArray = []; // declared readonly for conformance, possibly not yet added to parent
44
+
45
+ /**
46
+ * Comment for this field.
47
+ * @type {string|null}
48
+ */
49
+ this.comment = comment;
50
+ }
51
+
52
+ /**
53
+ * Oneof descriptor.
54
+ * @interface IOneOf
55
+ * @property {Array.<string>} oneof Oneof field names
56
+ * @property {Object.<string,*>} [options] Oneof options
57
+ */
58
+
59
+ /**
60
+ * Constructs a oneof from a oneof descriptor.
61
+ * @param {string} name Oneof name
62
+ * @param {IOneOf} json Oneof descriptor
63
+ * @returns {OneOf} Created oneof
64
+ * @throws {TypeError} If arguments are invalid
65
+ */
66
+ OneOf.fromJSON = function fromJSON(name, json) {
67
+ return new OneOf(name, json.oneof, json.options, json.comment);
68
+ };
69
+
70
+ /**
71
+ * Converts this oneof to a oneof descriptor.
72
+ * @param {IToJSONOptions} [toJSONOptions] JSON conversion options
73
+ * @returns {IOneOf} Oneof descriptor
74
+ */
75
+ OneOf.prototype.toJSON = function toJSON(toJSONOptions) {
76
+ var keepComments = toJSONOptions ? Boolean(toJSONOptions.keepComments) : false;
77
+ return util.toObject([
78
+ "options" , this.options,
79
+ "oneof" , this.oneof,
80
+ "comment" , keepComments ? this.comment : undefined
81
+ ]);
82
+ };
83
+
84
+ /**
85
+ * Adds the fields of the specified oneof to the parent if not already done so.
86
+ * @param {OneOf} oneof The oneof
87
+ * @returns {undefined}
88
+ * @inner
89
+ * @ignore
90
+ */
91
+ function addFieldsToParent(oneof) {
92
+ if (oneof.parent)
93
+ for (var i = 0; i < oneof.fieldsArray.length; ++i)
94
+ if (!oneof.fieldsArray[i].parent)
95
+ oneof.parent.add(oneof.fieldsArray[i]);
96
+ }
97
+
98
+ /**
99
+ * Adds a field to this oneof and removes it from its current parent, if any.
100
+ * @param {Field} field Field to add
101
+ * @returns {OneOf} `this`
102
+ */
103
+ OneOf.prototype.add = function add(field) {
104
+
105
+ /* istanbul ignore if */
106
+ if (!(field instanceof Field))
107
+ throw TypeError("field must be a Field");
108
+
109
+ if (field.parent && field.parent !== this.parent)
110
+ field.parent.remove(field);
111
+ this.oneof.push(field.name);
112
+ this.fieldsArray.push(field);
113
+ field.partOf = this; // field.parent remains null
114
+ addFieldsToParent(this);
115
+ return this;
116
+ };
117
+
118
+ /**
119
+ * Removes a field from this oneof and puts it back to the oneof's parent.
120
+ * @param {Field} field Field to remove
121
+ * @returns {OneOf} `this`
122
+ */
123
+ OneOf.prototype.remove = function remove(field) {
124
+
125
+ /* istanbul ignore if */
126
+ if (!(field instanceof Field))
127
+ throw TypeError("field must be a Field");
128
+
129
+ var index = this.fieldsArray.indexOf(field);
130
+
131
+ /* istanbul ignore if */
132
+ if (index < 0)
133
+ throw Error(field + " is not a member of " + this);
134
+
135
+ this.fieldsArray.splice(index, 1);
136
+ index = this.oneof.indexOf(field.name);
137
+
138
+ /* istanbul ignore else */
139
+ if (index > -1) // theoretical
140
+ this.oneof.splice(index, 1);
141
+
142
+ field.partOf = null;
143
+ return this;
144
+ };
145
+
146
+ /**
147
+ * @override
148
+ */
149
+ OneOf.prototype.onAdd = function onAdd(parent) {
150
+ ReflectionObject.prototype.onAdd.call(this, parent);
151
+ var self = this;
152
+ // Collect present fields
153
+ for (var i = 0; i < this.oneof.length; ++i) {
154
+ var field = parent.get(this.oneof[i]);
155
+ if (field && !field.partOf) {
156
+ field.partOf = self;
157
+ self.fieldsArray.push(field);
158
+ }
159
+ }
160
+ // Add not yet present fields
161
+ addFieldsToParent(this);
162
+ };
163
+
164
+ /**
165
+ * @override
166
+ */
167
+ OneOf.prototype.onRemove = function onRemove(parent) {
168
+ for (var i = 0, field; i < this.fieldsArray.length; ++i)
169
+ if ((field = this.fieldsArray[i]).parent)
170
+ field.parent.remove(field);
171
+ ReflectionObject.prototype.onRemove.call(this, parent);
172
+ };
173
+
174
+ /**
175
+ * Decorator function as returned by {@link OneOf.d} (TypeScript).
176
+ * @typedef OneOfDecorator
177
+ * @type {function}
178
+ * @param {Object} prototype Target prototype
179
+ * @param {string} oneofName OneOf name
180
+ * @returns {undefined}
181
+ */
182
+
183
+ /**
184
+ * OneOf decorator (TypeScript).
185
+ * @function
186
+ * @param {...string} fieldNames Field names
187
+ * @returns {OneOfDecorator} Decorator function
188
+ * @template T extends string
189
+ */
190
+ OneOf.d = function decorateOneOf() {
191
+ var fieldNames = new Array(arguments.length),
192
+ index = 0;
193
+ while (index < arguments.length)
194
+ fieldNames[index] = arguments[index++];
195
+ return function oneOfDecorator(prototype, oneofName) {
196
+ util.decorateType(prototype.constructor)
197
+ .add(new OneOf(oneofName, fieldNames));
198
+ Object.defineProperty(prototype, oneofName, {
199
+ get: util.oneOfGetter(fieldNames),
200
+ set: util.oneOfSetter(fieldNames)
201
+ });
202
+ };
203
+ };