1.5.0 • Published 4 years ago

@slaviczavik/stream-search v1.5.0

Weekly downloads
-
License
MIT
Repository
github
Last release
4 years ago

Build Status

Description

Node.js event based module for searching streams using the Boyer–Moore–Horspool algorithm.

Requirements

Node.js 6.14.3 or higher is required.

Installation

npm i @slaviczavik/stream-search

Example

Code

const StreamSearch = require('@slaviczavik/stream-search')
const search = StreamSearch('AQD')

search.on('part', function (obj) {
  const isMatch = obj['isMatch']
  const start = obj['start']
  const end = obj['end']
  const data = obj['data']

  if (isMatch) {
    console.log(`Found! [${start} - ${end}]`)
  }
  else {
    console.log(`Not found!`)
  }

  if (data) {
    console.log(data.toString('ascii'))
  }
})

search.add('--AQD-QDD-DQD--')
search.end()

Output

> Found! [2 - 4]
> --AQD
> Not found!
> -QDD-DQD--

API

Constructor

StreamSearch(needle, limit)

NameRequiredTypeDescriptionDefault
needletruestring, bufferThe needle what we are searching for.none
limitfalseintegerThe maximum number of matches.Infinity

Number of matches is reseted after the end method calling.

Methods

add(haystack)

Call this method every time you receive a new stream data. If there were some unprocessed data in the previous request, this data will be processed with this new data.

ParameterRequiredTypeDescription
haystacktruestring, bufferYour data you want to search.

end()

Calling this method you signals that no more data will be passed. If there are some trailing data (too few to run the algorithm), this data will be emitted back to user.

Events

part(object)

Emitted every time a match was or was not made. In both case, a processed chunk of data is available. If match was made, the needle is between start (inclusive) and end (inclusive).

The object contains following properties:

PropertyTypeDescription
isMatchbooleanBool value that data contains the needle.
databufferReturned data from the haystack.
startinteger, undefinedStart position of needle (if any) in the haystack (inclusive).
endinteger, undefinedEnd position of needle (if any) in the haystack (inclusive).

The property end also indicates the end of the data.

1.5.0

4 years ago

1.4.0

4 years ago

1.3.3

6 years ago

1.3.2

6 years ago

1.3.1

6 years ago

1.3.0

6 years ago

1.2.2

6 years ago

1.2.1

6 years ago

1.2.0

6 years ago

1.1.1

6 years ago

1.1.0

6 years ago

1.0.2

6 years ago

1.0.0

6 years ago

1.0.1

6 years ago