Skip to content

Commit

Permalink
Added support for buffer configuration.
Browse files Browse the repository at this point in the history
  • Loading branch information
tinchoz49 committed Jun 24, 2019
1 parent 7bacfc8 commit a87a83a
Show file tree
Hide file tree
Showing 6 changed files with 140 additions and 48 deletions.
4 changes: 2 additions & 2 deletions src/index-minimal.js
Original file line number Diff line number Diff line change
Expand Up @@ -27,10 +27,10 @@ protobuf.configure = configure;
* @returns {undefined}
*/
function configure() {
protobuf.Reader._configure(protobuf.BufferReader);
protobuf.util._configure();
protobuf.Writer._configure(protobuf.BufferWriter);
protobuf.Reader._configure(protobuf.BufferReader);
}

// Set up buffer utility according to the environment
protobuf.Writer._configure(protobuf.BufferWriter);
configure();
28 changes: 17 additions & 11 deletions src/reader.js
Original file line number Diff line number Diff line change
Expand Up @@ -53,24 +53,28 @@ var create_array = typeof Uint8Array !== "undefined"
throw Error("illegal buffer");
};

var create = function create() {
return util.Buffer
? function create_buffer_setup(buffer) {
return (Reader.create = function create_buffer(buffer) {
return util.Buffer.isBuffer(buffer)
? new BufferReader(buffer)
/* istanbul ignore next */
: create_array(buffer);
})(buffer);
}
/* istanbul ignore next */
: create_array;
};

/**
* Creates a new reader using the specified buffer.
* @function
* @param {Uint8Array|Buffer} buffer Buffer to read from
* @returns {Reader|BufferReader} A {@link BufferReader} if `buffer` is a Buffer, otherwise a {@link Reader}
* @throws {Error} If `buffer` is not a valid buffer
*/
Reader.create = util.Buffer
? function create_buffer_setup(buffer) {
return (Reader.create = function create_buffer(buffer) {
return util.Buffer.isBuffer(buffer)
? new BufferReader(buffer)
/* istanbul ignore next */
: create_array(buffer);
})(buffer);
}
/* istanbul ignore next */
: create_array;
Reader.create = create();

Reader.prototype._slice = util.Array.prototype.subarray || /* istanbul ignore next */ util.Array.prototype.slice;

Expand Down Expand Up @@ -377,6 +381,8 @@ Reader.prototype.skipType = function(wireType) {

Reader._configure = function(BufferReader_) {
BufferReader = BufferReader_;
Reader.create = create();
BufferReader._configure();

var fn = util.Long ? "toLong" : /* istanbul ignore next */ "toNumber";
util.merge(Reader.prototype, {
Expand Down
11 changes: 8 additions & 3 deletions src/reader_buffer.js
Original file line number Diff line number Diff line change
Expand Up @@ -24,9 +24,12 @@ function BufferReader(buffer) {
*/
}

/* istanbul ignore else */
if (util.Buffer)
BufferReader.prototype._slice = util.Buffer.prototype.slice;
BufferReader._configure = function () {
/* istanbul ignore else */
if (util.Buffer)
BufferReader.prototype._slice = util.Buffer.prototype.slice;
};


/**
* @override
Expand All @@ -42,3 +45,5 @@ BufferReader.prototype.string = function read_string_buffer() {
* @function
* @returns {Buffer} Value read
*/

BufferReader._configure();
26 changes: 16 additions & 10 deletions src/writer.js
Original file line number Diff line number Diff line change
Expand Up @@ -121,21 +121,25 @@ function Writer() {
// part is just a linked list walk calling operations with already prepared values.
}

var create = function create() {
return util.Buffer
? function create_buffer_setup() {
return (Writer.create = function create_buffer() {
return new BufferWriter();
})();
}
/* istanbul ignore next */
: function create_array() {
return new Writer();
};
};

/**
* Creates a new writer.
* @function
* @returns {BufferWriter|Writer} A {@link BufferWriter} when Buffers are supported, otherwise a {@link Writer}
*/
Writer.create = util.Buffer
? function create_buffer_setup() {
return (Writer.create = function create_buffer() {
return new BufferWriter();
})();
}
/* istanbul ignore next */
: function create_array() {
return new Writer();
};
Writer.create = create();

/**
* Allocates a buffer of the specified size.
Expand Down Expand Up @@ -456,4 +460,6 @@ Writer.prototype.finish = function finish() {

Writer._configure = function(BufferWriter_) {
BufferWriter = BufferWriter_;
Writer.create = create();
BufferWriter._configure();
};
45 changes: 23 additions & 22 deletions src/writer_buffer.js
Original file line number Diff line number Diff line change
Expand Up @@ -7,8 +7,6 @@ var Writer = require("./writer");

var util = require("./util/minimal");

var Buffer = util.Buffer;

/**
* Constructs a new buffer writer instance.
* @classdesc Wire format writer using node buffers.
Expand All @@ -19,27 +17,28 @@ function BufferWriter() {
Writer.call(this);
}

/**
* Allocates a buffer of the specified size.
* @param {number} size Buffer size
* @returns {Buffer} Buffer
*/
BufferWriter.alloc = function alloc_buffer(size) {
return (BufferWriter.alloc = util._Buffer_allocUnsafe)(size);
};
BufferWriter._configure = function () {
/**
* Allocates a buffer of the specified size.
* @param {number} size Buffer size
* @returns {Buffer} Buffer
*/
BufferWriter.alloc = util._Buffer_allocUnsafe;

var writeBytesBuffer = Buffer && Buffer.prototype instanceof Uint8Array && Buffer.prototype.set.name === "set"
? function writeBytesBuffer_set(val, buf, pos) {
buf.set(val, pos); // faster than copy (requires node >= 4 where Buffers extend Uint8Array and set is properly inherited)
// also works for plain array values
}
/* istanbul ignore next */
: function writeBytesBuffer_copy(val, buf, pos) {
if (val.copy) // Buffer values
BufferWriter.writeBytesBuffer = util.Buffer && util.Buffer.prototype instanceof Uint8Array && util.Buffer.prototype.set.name === "set"
? function writeBytesBuffer_set(val, buf, pos) {
buf.set(val, pos); // faster than copy (requires node >= 4 where Buffers extend Uint8Array and set is properly inherited)
// also works for plain array values
}
/* istanbul ignore next */
: function writeBytesBuffer_copy(val, buf, pos) {
if (val.copy) // Buffer values
val.copy(buf, pos, 0, val.length);
else for (var i = 0; i < val.length;) // plain array values
else for (var i = 0; i < val.length;) // plain array values
buf[pos++] = val[i++];
};
};
};


/**
* @override
Expand All @@ -50,7 +49,7 @@ BufferWriter.prototype.bytes = function write_bytes_buffer(value) {
var len = value.length >>> 0;
this.uint32(len);
if (len)
this._push(writeBytesBuffer, len, value);
this._push(BufferWriter.writeBytesBuffer, len, value);
return this;
};

Expand All @@ -65,7 +64,7 @@ function writeStringBuffer(val, buf, pos) {
* @override
*/
BufferWriter.prototype.string = function write_string_buffer(value) {
var len = Buffer.byteLength(value);
var len = util.Buffer.byteLength(value);
this.uint32(len);
if (len)
this._push(writeStringBuffer, len, value);
Expand All @@ -79,3 +78,5 @@ BufferWriter.prototype.string = function write_string_buffer(value) {
* @function
* @returns {Buffer} Finished buffer
*/

BufferWriter._configure();
74 changes: 74 additions & 0 deletions tests/comp_bytes.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,74 @@
var tape = require("tape");

class CustomBuffer extends Buffer {
static toCustom(b) {
b._isCustom = true;
return b;
}

static isCustom(b) {
return !!b._isCustom;
}

static from(...args) {
return CustomBuffer.toCustom(Buffer.from(...args));
}

static alloc(...args) {
return CustomBuffer.toCustom(Buffer.alloc(...args));
}

static allocUnsafe(...args) {
return CustomBuffer.toCustom(Buffer.allocUnsafe(...args));
}

static allocUnsafeSlow(...args) {
return CustomBuffer.toCustom(Buffer.allocUnsafeSlow(...args));
}

slice(...args) {
return CustomBuffer.toCustom(super.slice(...args));
}
}

tape.test("configure a custom encoder/decoder for bytes", function(test) {

var protobuf = require("..");
var oldBuffer = protobuf.util.Buffer;

protobuf.util.Buffer = CustomBuffer;
protobuf.configure();

var root = protobuf.Root.fromJSON({
nested: {
test: {
nested: {
Test: {
fields: {
data: {
type: "bytes",
id: 1
}
}
}
}
}
}
});

var Test = root.lookup("test.Test");

var buffer = Test.encode({
data: Buffer.from('some-data')
}).finish();
test.ok(CustomBuffer.isCustom(buffer), "should encode the message with a custom buffer");

var decoded = Test.decode(buffer);
test.ok(CustomBuffer.isCustom(decoded.data), "should decode `data` into a custom buffer");

protobuf.util.Buffer = oldBuffer;
protobuf.configure();

test.end();

});

0 comments on commit a87a83a

Please sign in to comment.