Comparing version 0.0.0 to 0.0.1
@@ -109,2 +109,11 @@ (function() { | ||
NoFilter.prototype.read = function(size) { | ||
var buf; | ||
buf = NoFilter.__super__.read.call(this, size); | ||
if (buf != null) { | ||
this.emit('read', buf); | ||
} | ||
return buf; | ||
}; | ||
NoFilter.prototype.compare = function(other) { | ||
@@ -278,2 +287,2 @@ if (!(other instanceof NoFilter)) { | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["index.coffee"],"names":[],"mappings":"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","file":"index.js","sourceRoot":"/source/","sourcesContent":["stream = require 'stream'\nutil = require 'util'\n\n# NoFilter stream.  Can be used to sink or source data to and from other\n# node streams.  Implemented as the \"identity\" Transform stream (hence the\n# name), but allows for inspecting data that is in-flight.\n#\n# @example source\n#   var n = new NoFilter('Zm9v', 'base64');\n#   n.pipe(process.stdout);\n#\n# @example sink\n#   var n = new Nofilter();\n#   # NOTE: 'finish' fires when the input is done writing\n#   n.on('finish', function() { console.log(n.toString('base64')); });\n#   process.stdin.pipe(n);\n#\n# @method #writeUInt8(value)\n#   Write an 8-bit unsigned integer to the stream.  Adds 1 byte.\n#   @param value [Number]\n# @method #writeUInt16LE(value)\n#   Write a little-endian 16-bit unsigned integer to the stream.  Adds\n#   2 bytes.\n#   @param value [Number]\n# @method #writeUInt16BE(value)\n#   Write a big-endian 16-bit unsigned integer to the stream.  Adds\n#   2 bytes.\n#   @param value [Number]\n# @method #writeUInt32LE(value)\n#   Write a little-endian 32-bit unsigned integer to the stream.  Adds\n#   4 bytes.\n#   @param value [Number]\n# @method #writeUInt32BE(value)\n#   Write a big-endian 32-bit unsigned integer to the stream.  Adds\n#   4 bytes.\n#   @param value [Number]\n# @method #writeInt8(value)\n#   Write an 8-bit signed integer to the stream.  Adds\n#   1 byte.\n#   @param value [Number]\n# @method #writeInt16LE(value)\n#   Write a little-endian 16-bit signed integer to the stream.  Adds\n#   2 bytes.\n#   @param value [Number]\n# @method #writeInt16BE(value)\n#   Write a big-endian 16-bit signed integer to the stream.  Adds\n#   2 bytes.\n#   @param value [Number]\n# @method #writeInt32LE(value)\n#   Write a little-endian 32-bit signed integer to the stream.  Adds\n#   4 bytes.\n#   @param value [Number]\n# @method #writeInt32BE(value)\n#   Write a big-endian 32-bit signed integer to the stream.  Adds\n#   4 bytes.\n#   @param value [Number]\n# @method #writeFloatLE(value)\n#   Write a little-endian 32-bit float to the stream.  Adds\n#   4 bytes.\n#   @param value [Number]\n# @method #writeFloatBE(value)\n#   Write a big-endian 32-bit float to the stream.  Adds\n#   4 bytes.\n#   @param value [Number]\n# @method #writeDoubleLE(value)\n#   Write a little-endian 64-bit double precision number to the stream.  Adds\n#   8 bytes.\n#   @param value [Number]\n# @method #writeDoubleBE(value)\n#   Write a big-endian 64-bit double precision number to the stream.  Adds\n#   8 bytes.\n#   @param value [Number]\n# @method #readUInt8()\n#   Read an unsigned 8-bit integer from the stream.  Consumes\n#   1 byte.\n#   @return [Number]\n# @method #readUInt16LE()\n#   Read a little-endian unsigned 16-bit integer from the stream.  Consumes\n#   2 bytes.\n#   @return [Number]\n# @method #readUInt16BE()\n#   Read a big-endian unsigned 16-bit integer from the stream.  Consumes\n#   2 bytes.\n#   @return [Number]\n# @method #readUInt32LE()\n#   Read a little-endian unsigned 32-bit integer from the stream.  Consumes\n#   4 bytes.\n#   @return [Number]\n# @method #readUInt32BE()\n#   Read a -bigendian unsigned 32-bit integer from the stream.  Consumes\n#   4 bytes.\n#   @return [Number]\n# @method #readInt8()\n#   Read a signed 8-bit integer from the stream.  Consumes\n#   1 byte.\n#   @return [Number]\n# @method #readInt16LE()\n#   Read a little-endian signed 16-bit integer from the stream.  Consumes\n#   2 bytes.\n#   @return [Number]\n# @method #readInt16BE()\n#   Read a big-endian signed 16-bit integer from the stream.  Consumes\n#   2 bytes.\n#   @return [Number]\n# @method #readInt32LE()\n#   Read a little-endian signed 32-bit integer from the stream.  Consumes\n#   4 bytes.\n#   @return [Number]\n# @method #readInt32BE()\n#   Read a big-endian signed 32-bit integer from the stream.  Consumes\n#   4 bytes.\n#   @return [Number]\n# @method #readFloatLE()\n#   Read a little-endian floating point number from the stream.  Consumes\n#   4 bytes.\n#   @return [Number]\n# @method #readFloatBE()\n#   Read a big-endian floating point number from the stream.  Consumes\n#   4 bytes.\n#   @return [Number]\n# @method #readDoubleLE()\n#   Read a little-endian double-precision number from the stream.  Consumes\n#   8 bytes.\n#   @return [Number]\n# @method #readDoubleBE()\n#   Read a big-endian double-precision number from the stream.  Consumes\n#   8 bytes.\n#   @return [Number]\nmodule.exports = class NoFilter extends stream.Transform\n  # Create a NoFilter.  Allow passing in source data (input, inputEncoding)\n  # at creation time.  Source data can also be passed in the options object.\n  #\n  # @param input [String, Buffer] Optional source data\n  # @param inputEncoding [String] Optional encoding name for input, ignored\n  #   if input is not a String\n  # @param options [Object] Other options\n  # @option options [String, Buffer] Input source data\n  # @option options [String] inputEncoding Encoding name for input, ignored\n  #   if input is not a String\n  # @option options [Number] highWaterMark The maximum number of bytes to store\n  #   in the internal buffer before ceasing to read from the underlying\n  #   resource. Default=16kb, or 16 for objectMode streams.\n  # @option options [String] encoding  If specified, then buffers will be\n  #   decoded to strings using the specified encoding. Default=null\n  # @option options [Boolean] objectMode Whether this stream should behave as a\n  #   stream of objects. Meaning that stream.read(n) returns a single value\n  #   instead of a Buffer of size n. Default=false\n  # @option options [Boolean] decodeStrings Whether or not to decode strings\n  #   into Buffers before passing them to _write(). Default=true\n  constructor: (input, inputEncoding, options = {}) ->\n    inp = undefined\n    inpE = undefined\n    switch typeof(input)\n      when 'object'\n        if Buffer.isBuffer(input)\n          inp = input\n          if inputEncoding? and (typeof(inputEncoding) == 'object')\n            options = inputEncoding\n        else\n          options = input\n      when 'string'\n        inp = input\n        if inputEncoding? and (typeof(inputEncoding) == 'object')\n          options = inputEncoding\n        else\n          inpE = inputEncoding\n\n    if !options?\n      options = {}\n    inp ?= options.input\n    inpE ?= options.inputEncoding\n    delete options.input\n    delete options.inputEncoding\n    super(options)\n\n    if inp?\n      @end inp, inpE\n\n  # Is the given object a {NoFilter}?\n  # @param obj [Object] The object to test.\n  # @return [Boolean]\n  @isNoFilter: (obj) ->\n    obj instanceof @\n\n  # The same as nf1.compare(nf2). Useful for sorting an Array of NoFilters:\n  # @example compare\n  #  var arr = [new NoFilter('1234'), new NoFilter('0123')];\n  #  arr.sort(Buffer.compare);\n  # @param nf1 [NoFilter] The first object to compare\n  # @param nf2 [NoFilter] The second object to compare\n  # @return [Number] -1, 0, 1 for less, equal, greater\n  @compare: (nf1, nf2) ->\n    if !(nf1 instanceof @)\n      throw new TypeError 'Arguments must be NoFilters'\n    if nf1 == nf2\n      0\n    else\n      nf1.compare nf2\n\n  # Returns a buffer which is the result of concatenating all the NoFilters in\n  # the list together. If the list has no items, or if the totalLength is 0,\n  # then it returns a zero-length buffer.\n  #\n  # If length is not provided, it is read from the buffers in the list. However,\n  # this adds an additional loop to the function, so it is faster to provide the\n  # length explicitly.\n  #\n  # @param list [Array of NoFilter] Inputs.  Must not be in object mode.\n  # @param length [Number] Optional.\n  # @return [Buffer] The concatenated values\n  @concat: (list, length) ->\n    if !Array.isArray list\n      throw new TypeError 'list argument must be an Array of NoFilters'\n    if (list.length == 0) or (length == 0)\n      return new Buffer 0\n    if !length?\n      length = list.reduce (tot, nf) ->\n        if !(nf instanceof NoFilter)\n          throw new TypeError 'list argument must be an Array of NoFilters'\n        tot + nf.length\n      , 0\n    bufs = list.map (nf) ->\n      if !(nf instanceof NoFilter)\n        throw new TypeError 'list argument must be an Array of NoFilters'\n      if nf._readableState.objectMode\n        # TODO: if any of them are in object mode, then return an array?\n        throw new Error 'NoFilter may not be in object mode for concat'\n      nf.slice()\n    Buffer.concat bufs, length\n\n  # @nodoc\n  _transform: (chunk, encoding, callback) ->\n    if !@_readableState.objectMode and !Buffer.isBuffer(chunk)\n      chunk = new Buffer chunk, encoding\n    @push chunk\n    callback()\n\n  # Returns a number indicating whether this comes before or after or is the\n  # same as the other NoFilter in sort order.\n  #\n  # @param other [NoFilter] The other object to compare\n  # @return [Number] -1, 0, 1 for less, equal, greater\n  compare: (other) ->\n    if !(other instanceof NoFilter)\n      throw new TypeError 'Arguments must be NoFilters'\n    if @_readableState.objectMode or other._readableState.objectMode\n      throw new Error 'Must not be in object mode to compare'\n    if @ == other\n      0\n    else\n      @slice().compare other.slice()\n\n  # Do these NoFilter's contain the same bytes?  Doesn't work if either is\n  # in object mode.\n  # @param other [NoFilter]\n  # @return [Boolean] Equal?\n  equals: (other) ->\n    @compare(other) == 0\n\n  # Read bytes or objects without consuming them.  Useful for diagnostics.\n  # Note: as a side-effect, concatenates multiple writes together into what\n  # looks like a single write, so that this concat doesn't have to happen\n  # multiple times when you're futzing with the same NoFilter.\n  #\n  # @param start [Number] Optional, Default: 0\n  # @param end [Number], Optional, Default: NoFilter.length\n  # @return [Buffer,Array] if in object mode, an array of objects.  Otherwize,\n  #   concatenated array of contents.\n  slice: (start, end) ->\n    if @_readableState.objectMode\n      @_readableState.buffer.slice start, end\n    else\n      switch @_readableState.buffer.length\n        when 0 then new Buffer(0)\n        when 1 then @_readableState.buffer[0].slice(start, end)\n        else\n          b = Buffer.concat @_readableState.buffer\n          @_readableState.buffer = [b]\n          b.slice start, end\n\n  # Get a byte by offset.  I didn't want to get into metaprogramming\n  # to give you the `NoFilter[0]` syntax.\n  # @param index [Number] The byte to retrieve\n  # @return [Number] 0-255\n  get: (index) ->\n    @slice()[index]\n\n  # Return an object compatible with Buffer's toJSON implementation, so\n  # that round-tripping will produce a Buffer.\n  # @return [Object]\n  #\n  # @example output for 'foo'\n  #   { type: 'Buffer', data: [ 102, 111, 111 ] }\n  toJSON: ->\n    b = @slice()\n    if Buffer.isBuffer(b)\n      b.toJSON()\n    else\n      b\n\n  # Decodes and returns a string from buffer data encoded using the specified\n  # character set encoding. If encoding is undefined or null, then encoding\n  # defaults to 'utf8'. The start and end parameters default to 0 and\n  # NoFilter.length when undefined.\n  #\n  # @param encoding [String] Optional, Default: 'utf8'\n  # @param start [Number] Optional, Default: 0\n  # @param end [Number] Optional, Default: NoFilter.length\n  # @return [String]\n  toString: (encoding, start, end) ->\n    @slice().toString(encoding, start, end)\n\n  # @nodoc\n  inspect: (depth, options) ->\n    hex = @_readableState.buffer.map (b) ->\n      if Buffer.isBuffer(b)\n        if options?.stylize\n          options.stylize b.toString('hex'), 'string'\n        else\n          b.toString('hex')\n      else\n        util.inspect(b, options)\n    .join ', '\n    \"#{@constructor.name} [#{hex}]\"\n\n  # @nodoc\n  _read_gen = (meth, len) ->\n    (val) ->\n      b = @read len\n      if !Buffer.isBuffer(b)\n        return null\n      b[meth].call b, 0, true\n\n  # @nodoc\n  _write_gen = (meth, len) ->\n    (val) ->\n      b = new Buffer len\n      b[meth].call b, val, 0, true\n      @push b\n\n  # unsigned\n  writeUInt8:    _write_gen 'writeUInt8',    1\n  writeUInt16LE: _write_gen 'writeUInt16LE', 2\n  writeUInt16BE: _write_gen 'writeUInt16BE', 2\n  writeUInt32LE: _write_gen 'writeUInt32LE', 4\n  writeUInt32BE: _write_gen 'writeUInt32BE', 4\n\n  # signed\n  writeInt8:     _write_gen 'writeInt8',     1\n  writeInt16LE:  _write_gen 'writeInt16LE',  2\n  writeInt16BE:  _write_gen 'writeInt16BE',  2\n  writeInt32LE:  _write_gen 'writeInt32LE',  4\n  writeInt32BE:  _write_gen 'writeInt32BE',  4\n\n  # float\n  writeFloatLE:  _write_gen 'writeFloatLE',  4\n  writeFloatBE:  _write_gen 'writeFloatBE',  4\n  writeDoubleLE: _write_gen 'writeDoubleLE', 8\n  writeDoubleBE: _write_gen 'writeDoubleBE', 8\n\n  # unsigned\n  readUInt8:    _read_gen 'readUInt8',    1\n  readUInt16LE: _read_gen 'readUInt16LE', 2\n  readUInt16BE: _read_gen 'readUInt16BE', 2\n  readUInt32LE: _read_gen 'readUInt32LE', 4\n  readUInt32BE: _read_gen 'readUInt32BE', 4\n\n  # signed\n  readInt8:     _read_gen 'readInt8',     1\n  readInt16LE:  _read_gen 'readInt16LE',  2\n  readInt16BE:  _read_gen 'readInt16BE',  2\n  readInt32LE:  _read_gen 'readInt32LE',  4\n  readInt32BE:  _read_gen 'readInt32BE',  4\n\n  # float\n  readFloatLE:  _read_gen 'readFloatLE',  4\n  readFloatBE:  _read_gen 'readFloatBE',  4\n  readDoubleLE: _read_gen 'readDoubleLE', 8\n  readDoubleBE: _read_gen 'readDoubleBE', 8\n\n  # @nodoc\n  get = (props) ->\n    NoFilter::__defineGetter__(name, getter) for name, getter of props\n\n  # @property [Number] The number of bytes currently available to read\n  get length: -> @_readableState.length\n"]} | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["index.coffee"],"names":[],"mappings":"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","file":"index.js","sourceRoot":"/source/","sourcesContent":["stream = require 'stream'\nutil = require 'util'\n\n# NoFilter stream.  Can be used to sink or source data to and from other\n# node streams.  Implemented as the \"identity\" Transform stream (hence the\n# name), but allows for inspecting data that is in-flight.\n#\n# @example source\n#   var n = new NoFilter('Zm9v', 'base64');\n#   n.pipe(process.stdout);\n#\n# @example sink\n#   var n = new Nofilter();\n#   # NOTE: 'finish' fires when the input is done writing\n#   n.on('finish', function() { console.log(n.toString('base64')); });\n#   process.stdin.pipe(n);\n#\n# @event read(Buffer|String|Object) fired whenever anything is read from the\n#   stream.\n#\n# @method #writeUInt8(value)\n#   Write an 8-bit unsigned integer to the stream.  Adds 1 byte.\n#   @param value [Number]\n# @method #writeUInt16LE(value)\n#   Write a little-endian 16-bit unsigned integer to the stream.  Adds\n#   2 bytes.\n#   @param value [Number]\n# @method #writeUInt16BE(value)\n#   Write a big-endian 16-bit unsigned integer to the stream.  Adds\n#   2 bytes.\n#   @param value [Number]\n# @method #writeUInt32LE(value)\n#   Write a little-endian 32-bit unsigned integer to the stream.  Adds\n#   4 bytes.\n#   @param value [Number]\n# @method #writeUInt32BE(value)\n#   Write a big-endian 32-bit unsigned integer to the stream.  Adds\n#   4 bytes.\n#   @param value [Number]\n# @method #writeInt8(value)\n#   Write an 8-bit signed integer to the stream.  Adds\n#   1 byte.\n#   @param value [Number]\n# @method #writeInt16LE(value)\n#   Write a little-endian 16-bit signed integer to the stream.  Adds\n#   2 bytes.\n#   @param value [Number]\n# @method #writeInt16BE(value)\n#   Write a big-endian 16-bit signed integer to the stream.  Adds\n#   2 bytes.\n#   @param value [Number]\n# @method #writeInt32LE(value)\n#   Write a little-endian 32-bit signed integer to the stream.  Adds\n#   4 bytes.\n#   @param value [Number]\n# @method #writeInt32BE(value)\n#   Write a big-endian 32-bit signed integer to the stream.  Adds\n#   4 bytes.\n#   @param value [Number]\n# @method #writeFloatLE(value)\n#   Write a little-endian 32-bit float to the stream.  Adds\n#   4 bytes.\n#   @param value [Number]\n# @method #writeFloatBE(value)\n#   Write a big-endian 32-bit float to the stream.  Adds\n#   4 bytes.\n#   @param value [Number]\n# @method #writeDoubleLE(value)\n#   Write a little-endian 64-bit double precision number to the stream.  Adds\n#   8 bytes.\n#   @param value [Number]\n# @method #writeDoubleBE(value)\n#   Write a big-endian 64-bit double precision number to the stream.  Adds\n#   8 bytes.\n#   @param value [Number]\n# @method #readUInt8()\n#   Read an unsigned 8-bit integer from the stream.  Consumes\n#   1 byte.\n#   @return [Number]\n# @method #readUInt16LE()\n#   Read a little-endian unsigned 16-bit integer from the stream.  Consumes\n#   2 bytes.\n#   @return [Number]\n# @method #readUInt16BE()\n#   Read a big-endian unsigned 16-bit integer from the stream.  Consumes\n#   2 bytes.\n#   @return [Number]\n# @method #readUInt32LE()\n#   Read a little-endian unsigned 32-bit integer from the stream.  Consumes\n#   4 bytes.\n#   @return [Number]\n# @method #readUInt32BE()\n#   Read a -bigendian unsigned 32-bit integer from the stream.  Consumes\n#   4 bytes.\n#   @return [Number]\n# @method #readInt8()\n#   Read a signed 8-bit integer from the stream.  Consumes\n#   1 byte.\n#   @return [Number]\n# @method #readInt16LE()\n#   Read a little-endian signed 16-bit integer from the stream.  Consumes\n#   2 bytes.\n#   @return [Number]\n# @method #readInt16BE()\n#   Read a big-endian signed 16-bit integer from the stream.  Consumes\n#   2 bytes.\n#   @return [Number]\n# @method #readInt32LE()\n#   Read a little-endian signed 32-bit integer from the stream.  Consumes\n#   4 bytes.\n#   @return [Number]\n# @method #readInt32BE()\n#   Read a big-endian signed 32-bit integer from the stream.  Consumes\n#   4 bytes.\n#   @return [Number]\n# @method #readFloatLE()\n#   Read a little-endian floating point number from the stream.  Consumes\n#   4 bytes.\n#   @return [Number]\n# @method #readFloatBE()\n#   Read a big-endian floating point number from the stream.  Consumes\n#   4 bytes.\n#   @return [Number]\n# @method #readDoubleLE()\n#   Read a little-endian double-precision number from the stream.  Consumes\n#   8 bytes.\n#   @return [Number]\n# @method #readDoubleBE()\n#   Read a big-endian double-precision number from the stream.  Consumes\n#   8 bytes.\n#   @return [Number]\nmodule.exports = class NoFilter extends stream.Transform\n  # Create a NoFilter.  Allow passing in source data (input, inputEncoding)\n  # at creation time.  Source data can also be passed in the options object.\n  #\n  # @param input [String, Buffer] Optional source data\n  # @param inputEncoding [String] Optional encoding name for input, ignored\n  #   if input is not a String\n  # @param options [Object] Other options\n  # @option options [String, Buffer] Input source data\n  # @option options [String] inputEncoding Encoding name for input, ignored\n  #   if input is not a String\n  # @option options [Number] highWaterMark The maximum number of bytes to store\n  #   in the internal buffer before ceasing to read from the underlying\n  #   resource. Default=16kb, or 16 for objectMode streams.\n  # @option options [String] encoding  If specified, then buffers will be\n  #   decoded to strings using the specified encoding. Default=null\n  # @option options [Boolean] objectMode Whether this stream should behave as a\n  #   stream of objects. Meaning that stream.read(n) returns a single value\n  #   instead of a Buffer of size n. Default=false\n  # @option options [Boolean] decodeStrings Whether or not to decode strings\n  #   into Buffers before passing them to _write(). Default=true\n  constructor: (input, inputEncoding, options = {}) ->\n    inp = undefined\n    inpE = undefined\n    switch typeof(input)\n      when 'object'\n        if Buffer.isBuffer(input)\n          inp = input\n          if inputEncoding? and (typeof(inputEncoding) == 'object')\n            options = inputEncoding\n        else\n          options = input\n      when 'string'\n        inp = input\n        if inputEncoding? and (typeof(inputEncoding) == 'object')\n          options = inputEncoding\n        else\n          inpE = inputEncoding\n\n    if !options?\n      options = {}\n    inp ?= options.input\n    inpE ?= options.inputEncoding\n    delete options.input\n    delete options.inputEncoding\n    super(options)\n\n    if inp?\n      @end inp, inpE\n\n  # Is the given object a {NoFilter}?\n  # @param obj [Object] The object to test.\n  # @return [Boolean]\n  @isNoFilter: (obj) ->\n    obj instanceof @\n\n  # The same as nf1.compare(nf2). Useful for sorting an Array of NoFilters:\n  # @example compare\n  #  var arr = [new NoFilter('1234'), new NoFilter('0123')];\n  #  arr.sort(Buffer.compare);\n  # @param nf1 [NoFilter] The first object to compare\n  # @param nf2 [NoFilter] The second object to compare\n  # @return [Number] -1, 0, 1 for less, equal, greater\n  @compare: (nf1, nf2) ->\n    if !(nf1 instanceof @)\n      throw new TypeError 'Arguments must be NoFilters'\n    if nf1 == nf2\n      0\n    else\n      nf1.compare nf2\n\n  # Returns a buffer which is the result of concatenating all the NoFilters in\n  # the list together. If the list has no items, or if the totalLength is 0,\n  # then it returns a zero-length buffer.\n  #\n  # If length is not provided, it is read from the buffers in the list. However,\n  # this adds an additional loop to the function, so it is faster to provide the\n  # length explicitly.\n  #\n  # @param list [Array of NoFilter] Inputs.  Must not be in object mode.\n  # @param length [Number] Optional.\n  # @return [Buffer] The concatenated values\n  @concat: (list, length) ->\n    if !Array.isArray list\n      throw new TypeError 'list argument must be an Array of NoFilters'\n    if (list.length == 0) or (length == 0)\n      return new Buffer 0\n    if !length?\n      length = list.reduce (tot, nf) ->\n        if !(nf instanceof NoFilter)\n          throw new TypeError 'list argument must be an Array of NoFilters'\n        tot + nf.length\n      , 0\n    bufs = list.map (nf) ->\n      if !(nf instanceof NoFilter)\n        throw new TypeError 'list argument must be an Array of NoFilters'\n      if nf._readableState.objectMode\n        # TODO: if any of them are in object mode, then return an array?\n        throw new Error 'NoFilter may not be in object mode for concat'\n      nf.slice()\n    Buffer.concat bufs, length\n\n  # @nodoc\n  _transform: (chunk, encoding, callback) ->\n    if !@_readableState.objectMode and !Buffer.isBuffer(chunk)\n      chunk = new Buffer chunk, encoding\n    @push chunk\n    callback()\n\n  # The read() method pulls some data out of the internal buffer and returns it.\n  # If there is no data available, then it will return null.\n  #\n  # If you pass in a size argument, then it will return that many bytes. If size\n  # bytes are not available, then it will return null, unless we've ended, in\n  # which case it will return the data remaining in the buffer.\n  #\n  # If you do not specify a size argument, then it will return all the data in\n  # the internal buffer.\n  #\n  # This version also fires the 'read' event upon a successful read.\n  #\n  # @param size [Number] Optional. Number of bytes to read.\n  # @return [String, Buffer, null]\n  read: (size) ->\n    buf = super size\n    if buf?\n      @emit 'read', buf\n    buf\n\n  # Returns a number indicating whether this comes before or after or is the\n  # same as the other NoFilter in sort order.\n  #\n  # @param other [NoFilter] The other object to compare\n  # @return [Number] -1, 0, 1 for less, equal, greater\n  compare: (other) ->\n    if !(other instanceof NoFilter)\n      throw new TypeError 'Arguments must be NoFilters'\n    if @_readableState.objectMode or other._readableState.objectMode\n      throw new Error 'Must not be in object mode to compare'\n    if @ == other\n      0\n    else\n      @slice().compare other.slice()\n\n  # Do these NoFilter's contain the same bytes?  Doesn't work if either is\n  # in object mode.\n  # @param other [NoFilter]\n  # @return [Boolean] Equal?\n  equals: (other) ->\n    @compare(other) == 0\n\n  # Read bytes or objects without consuming them.  Useful for diagnostics.\n  # Note: as a side-effect, concatenates multiple writes together into what\n  # looks like a single write, so that this concat doesn't have to happen\n  # multiple times when you're futzing with the same NoFilter.\n  #\n  # @param start [Number] Optional, Default: 0\n  # @param end [Number], Optional, Default: NoFilter.length\n  # @return [Buffer,Array] if in object mode, an array of objects.  Otherwize,\n  #   concatenated array of contents.\n  slice: (start, end) ->\n    if @_readableState.objectMode\n      @_readableState.buffer.slice start, end\n    else\n      switch @_readableState.buffer.length\n        when 0 then new Buffer(0)\n        when 1 then @_readableState.buffer[0].slice(start, end)\n        else\n          b = Buffer.concat @_readableState.buffer\n          @_readableState.buffer = [b]\n          b.slice start, end\n\n  # Get a byte by offset.  I didn't want to get into metaprogramming\n  # to give you the `NoFilter[0]` syntax.\n  # @param index [Number] The byte to retrieve\n  # @return [Number] 0-255\n  get: (index) ->\n    @slice()[index]\n\n  # Return an object compatible with Buffer's toJSON implementation, so\n  # that round-tripping will produce a Buffer.\n  # @return [Object]\n  #\n  # @example output for 'foo'\n  #   { type: 'Buffer', data: [ 102, 111, 111 ] }\n  toJSON: ->\n    b = @slice()\n    if Buffer.isBuffer(b)\n      b.toJSON()\n    else\n      b\n\n  # Decodes and returns a string from buffer data encoded using the specified\n  # character set encoding. If encoding is undefined or null, then encoding\n  # defaults to 'utf8'. The start and end parameters default to 0 and\n  # NoFilter.length when undefined.\n  #\n  # @param encoding [String] Optional, Default: 'utf8'\n  # @param start [Number] Optional, Default: 0\n  # @param end [Number] Optional, Default: NoFilter.length\n  # @return [String]\n  toString: (encoding, start, end) ->\n    @slice().toString(encoding, start, end)\n\n  # @nodoc\n  inspect: (depth, options) ->\n    hex = @_readableState.buffer.map (b) ->\n      if Buffer.isBuffer(b)\n        if options?.stylize\n          options.stylize b.toString('hex'), 'string'\n        else\n          b.toString('hex')\n      else\n        util.inspect(b, options)\n    .join ', '\n    \"#{@constructor.name} [#{hex}]\"\n\n  # @nodoc\n  _read_gen = (meth, len) ->\n    (val) ->\n      b = @read len\n      if !Buffer.isBuffer(b)\n        return null\n      b[meth].call b, 0, true\n\n  # @nodoc\n  _write_gen = (meth, len) ->\n    (val) ->\n      b = new Buffer len\n      b[meth].call b, val, 0, true\n      @push b\n\n  # unsigned\n  writeUInt8:    _write_gen 'writeUInt8',    1\n  writeUInt16LE: _write_gen 'writeUInt16LE', 2\n  writeUInt16BE: _write_gen 'writeUInt16BE', 2\n  writeUInt32LE: _write_gen 'writeUInt32LE', 4\n  writeUInt32BE: _write_gen 'writeUInt32BE', 4\n\n  # signed\n  writeInt8:     _write_gen 'writeInt8',     1\n  writeInt16LE:  _write_gen 'writeInt16LE',  2\n  writeInt16BE:  _write_gen 'writeInt16BE',  2\n  writeInt32LE:  _write_gen 'writeInt32LE',  4\n  writeInt32BE:  _write_gen 'writeInt32BE',  4\n\n  # float\n  writeFloatLE:  _write_gen 'writeFloatLE',  4\n  writeFloatBE:  _write_gen 'writeFloatBE',  4\n  writeDoubleLE: _write_gen 'writeDoubleLE', 8\n  writeDoubleBE: _write_gen 'writeDoubleBE', 8\n\n  # unsigned\n  readUInt8:    _read_gen 'readUInt8',    1\n  readUInt16LE: _read_gen 'readUInt16LE', 2\n  readUInt16BE: _read_gen 'readUInt16BE', 2\n  readUInt32LE: _read_gen 'readUInt32LE', 4\n  readUInt32BE: _read_gen 'readUInt32BE', 4\n\n  # signed\n  readInt8:     _read_gen 'readInt8',     1\n  readInt16LE:  _read_gen 'readInt16LE',  2\n  readInt16BE:  _read_gen 'readInt16BE',  2\n  readInt32LE:  _read_gen 'readInt32LE',  4\n  readInt32BE:  _read_gen 'readInt32BE',  4\n\n  # float\n  readFloatLE:  _read_gen 'readFloatLE',  4\n  readFloatBE:  _read_gen 'readFloatBE',  4\n  readDoubleLE: _read_gen 'readDoubleLE', 8\n  readDoubleBE: _read_gen 'readDoubleBE', 8\n\n  # @nodoc\n  get = (props) ->\n    NoFilter::__defineGetter__(name, getter) for name, getter of props\n\n  # @property [Number] The number of bytes currently available to read\n  get length: -> @_readableState.length\n"]} |
{ | ||
"name": "nofilter", | ||
"version": "0.0.0", | ||
"version": "0.0.1", | ||
"description": "Read and write a growable buffer as a stream", | ||
@@ -5,0 +5,0 @@ "main": "lib/index.js", |
@@ -30,1 +30,3 @@ [![Build Status](https://travis-ci.org/hildjj/nofilter.svg?branch=master)](https://travis-ci.org/hildjj/nofilter) | ||
``` | ||
Read the [API Docs](http://hildjj.github.io/nofilter/). |
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is not supported yet
License Policy Violation
LicenseThis package is not allowed per your license policy. Review the package's license to ensure compliance.
Found 1 instance in 1 package
License Policy Violation
LicenseThis package is not allowed per your license policy. Review the package's license to ensure compliance.
Found 1 instance in 1 package
63970
454
32