qb-json-align v1.1.4
qb-json-align
qb-json-align works with qb-json-next to provide seamless parsing across JSON buffers split at any arbitrary point.
While qb-json-next handles splits between values and key-values, align() goes one step further to provide seamless parsing across JSON buffers split at any point.
install
npm install qb-json-align
usage
Parsing with align() is like normal parsing with qb-json-next, but with an added align() step after ps.next_src is set.
var next = require('qb-json-next')
var align = require('qb-json-align')
var ps = {}
var src
while (ps.next_src = get_next_buffer_somehow()) {
    align(ps)  
    while (next(ps)) {
        // use ps information to process tokens (see qb-json-next for details)
    }
}align(ps, opt)
ps              -   the parse-state used by qb-json-next with token and offset information (see qb-json-next)
opt
    new_buf     -   function, if provided, new_buf(length) will be called to allocate new buffers, rather
                    than always creating Uint8Array.  To create a node Buffer(), for example, use:
                        { new_buf: function (len) { return new Buffer(len) } }Align does the following:
if ps ends with a partial state such as truncated key, truncated value, or key without value then align creates a new ps.src buffer and copies a single whole value or key/value to this mini-buffer. ps.next_src is sliced/reduced by the taken amount and ps offsets and position are rewound to point to the start of the value or key/value that was truncated so that next(ps) will operate on the recovered value or key/value. If the value cannot be completed with ps.next_src, then it will still be rewound to parse the new, longer, but still incomplete value when next(ps) is called.
why have a separate module for qb-json-align?
Why did we put this functionality in a separate module from qb-json-next? Mainly, it is separate because align() is only one of many possible strategies for handling split buffers. This particular approach isolates the handler from the complexity of split handling and makes it easy for the client to create whole strings or buffers from key and value offsets. This approach makes the assumption the client doesn't need to handle very high proportions of splits or very large split values (huge strings). For special cases where whole values are not needed (where source is simply being validated, for example), another strategy could be more effective.