- [Fix]
stringify
: encode comma values more consistently (#463) - [readme] add usage of
filter
option for injecting custom serialization, i.e. of custom types (#447) - [meta] remove extraneous code backticks (#457)
- [meta] fix changelog markdown
- [actions] update checkout action
- [actions] restrict action permissions
- [Dev Deps] update
@ljharb/eslint-config
,aud
,object-inspect
,tape
- [New] [Fix]
stringify
: revert 0e903c0; addcommaRoundTrip
option (#442) - [readme] fix version badge
- [Fix]
stringify
: witharrayFormat: comma
, properly include an explicit[]
on a single-item array (#434)
- [Fix]
stringify
: witharrayFormat: comma
, include an explicit[]
on a single-item array (#441) - [meta] use
npmignore
to autogenerate an npmignore file - [Dev Deps] update
eslint
,@ljharb/eslint-config
,aud
,has-symbol
,object-inspect
,tape
- [Fix]
parse
: ignore__proto__
keys (#428) - [Robustness]
stringify
: avoid relying on a globalundefined
(#427) - [actions] reuse common workflows
- [Dev Deps] update
eslint
,@ljharb/eslint-config
,object-inspect
,tape
- [Fix]
stringify
: actually fix cyclic references (#426) - [Fix]
stringify
: avoid encoding arrayformat comma whenencodeValuesOnly = true
(#424) - [readme] remove travis badge; add github actions/codecov badges; update URLs
- [Docs] add note and links for coercing primitive values (#408)
- [actions] update codecov uploader
- [actions] update workflows
- [Tests] clean up stringify tests slightly
- [Dev Deps] update
eslint
,@ljharb/eslint-config
,aud
,object-inspect
,safe-publish-latest
,tape
- [Fix]
stringify
: avoid exception on repeated object values (#402)
- [New]
stringify
: throw on cycles, instead of an infinite loop (#395, #394, #393) - [New]
parse
: addallowSparse
option for collapsing arrays with missing indices (#312) - [meta] fix README.md (#399)
- [meta] only run
npm run dist
in publish, not install - [Dev Deps] update
eslint
,@ljharb/eslint-config
,aud
,has-symbols
,tape
- [Tests] fix tests on node v0.6
- [Tests] use
ljharb/actions/node/install
instead ofljharb/actions/node/run
- [Tests] Revert "[meta] ignore eclint transitive audit warning"
- [Fix]
parse
: ignore__proto__
keys (#428) - [Fix]
stringify
: avoid encoding arrayformat comma whenencodeValuesOnly = true
(#424) - [Robustness]
stringify
: avoid relying on a globalundefined
(#427) - [readme] remove travis badge; add github actions/codecov badges; update URLs
- [Docs] add note and links for coercing primitive values (#408)
- [Tests] clean up stringify tests slightly
- [meta] fix README.md (#399)
- Revert "[meta] ignore eclint transitive audit warning"
- [actions] backport actions from main
- [Dev Deps] backport updates from main
- [Fix] restore
dist
dir; mistakenly removed in d4f6c32
- [Fix]
stringify
: do not encode parens for RFC1738 - [Fix]
stringify
: fix arrayFormat comma with empty array/objects (#350) - [Refactor]
format
: removeutil.assign
call - [meta] add "Allow Edits" workflow; update rebase workflow
- [actions] switch Automatic Rebase workflow to
pull_request_target
event - [Tests]
stringify
: add tests for #378 - [Tests] migrate tests to Github Actions
- [Tests] run
nyc
on all tests; usetape
runner - [Dev Deps] update
eslint
,@ljharb/eslint-config
,browserify
,mkdirp
,object-inspect
,tape
; addaud
- [Fix]
stringify
: whenarrayFormat
iscomma
, respectserializeDate
(#364) - [Refactor]
stringify
: reduce branching (part of #350) - [Refactor] move
maybeMap
toutils
- [Dev Deps] update
browserify
,tape
- [Fix] proper comma parsing of URL-encoded commas (#361)
- [Fix] parses comma delimited array while having percent-encoded comma treated as normal text (#336)
- [Fix]
parse
: Fix parsing array from object withcomma
true (#359) - [Fix]
parse
: throw a TypeError instead of an Error for bad charset (#349) - [meta] ignore eclint transitive audit warning
- [meta] fix indentation in package.json
- [meta] add tidelift marketing copy
- [Dev Deps] update
eslint
,@ljharb/eslint-config
,object-inspect
,has-symbols
,tape
,mkdirp
,iconv-lite
- [actions] add automatic rebasing / merge commit blocking
- [Fix]
parse
: with comma true, handle field that holds an array of arrays (#335) - [Fix]
parse
: with comma true, do not split non-string values (#334) - [meta] add
funding
field - [Dev Deps] update
eslint
,@ljharb/eslint-config
- [Tests] use shared travis-ci config
- [New]
parse
/stringify
: Pass extra key/value argument todecoder
(#333) - [Dev Deps] update
eslint
,@ljharb/eslint-config
,evalmd
- [Tests]
parse
: add passingarrayFormat
tests - [Tests] add
posttest
usingnpx aud
to runnpm audit
without a lockfile - [Tests] up to
node
v12.10
,v11.15
,v10.16
,v8.16
- [Tests]
Buffer.from
in node v5.0-v5.9 and v4.0-v4.4 requires a TypedArray
- [Fix]
parse
: ignore__proto__
keys (#428) - [Robustness]
stringify
: avoid relying on a globalundefined
(#427) - [Fix]
stringify
: avoid encoding arrayformat comma whenencodeValuesOnly = true
(#424) - [readme] remove travis badge; add github actions/codecov badges; update URLs
- [Tests] clean up stringify tests slightly
- [Docs] add note and links for coercing primitive values (#408)
- [meta] fix README.md (#399)
- [actions] backport actions from main
- [Dev Deps] backport updates from main
- [Refactor]
stringify
: reduce branching - [meta] do not publish workflow files
- [Fix] proper comma parsing of URL-encoded commas (#361)
- [Fix] parses comma delimited array while having percent-encoded comma treated as normal text (#336)
- [Fix]
parse
: Fix parsing array from object withcomma
true (#359) - [Fix]
parse
: throw a TypeError instead of an Error for bad charset (#349) - [Fix]
parse
: with comma true, handle field that holds an array of arrays (#335) - [fix]
parse
: with comma true, do not split non-string values (#334) - [meta] add tidelift marketing copy
- [meta] add
funding
field - [Dev Deps] update
eslint
,@ljharb/eslint-config
,tape
,safe-publish-latest
,evalmd
,has-symbols
,iconv-lite
,mkdirp
,object-inspect
- [Tests]
parse
: add passingarrayFormat
tests - [Tests] use shared travis-ci configs
- [Tests]
Buffer.from
in node v5.0-v5.9 and v4.0-v4.4 requires a TypedArray - [actions] add automatic rebasing / merge commit blocking
- [New] add
depth=false
to preserve the original key; [Fix]depth=0
should preserve the original key (#326) - [New] [Fix] stringify symbols and bigints
- [Fix] ensure node 0.12 can stringify Symbols
- [Fix] fix for an impossible situation: when the formatter is called with a non-string value
- [Refactor]
formats
: tiny bit of cleanup. - [Dev Deps] update
eslint
,@ljharb/eslint-config
,browserify
,safe-publish-latest
,iconv-lite
,tape
- [Tests] add tests for
depth=0
anddepth=false
behavior, both current and intuitive/intended (#326) - [Tests] use
eclint
instead ofeditorconfig-tools
- [docs] readme: add security note
- [meta] add github sponsorship
- [meta] add FUNDING.yml
- [meta] Clean up license text so it’s properly detected as BSD-3-Clause
- [Fix]
parse
: ignore__proto__
keys (#428) - [Fix]
stringify
: avoid encoding arrayformat comma whenencodeValuesOnly = true
(#424) - [Robustness]
stringify
: avoid relying on a globalundefined
(#427) - [readme] remove travis badge; add github actions/codecov badges; update URLs
- [Docs] add note and links for coercing primitive values (#408)
- [meta] fix README.md (#399)
- [meta] do not publish workflow files
- [actions] backport actions from main
- [Dev Deps] backport updates from main
- [Tests] use
nyc
for coverage - [Tests] clean up stringify tests slightly
- [Fix] proper comma parsing of URL-encoded commas (#361)
- [Fix] parses comma delimited array while having percent-encoded comma treated as normal text (#336)
- [Fix]
parse
: Fix parsing array from object withcomma
true (#359) - [Fix]
parse
: with comma true, handle field that holds an array of arrays (#335) - [fix]
parse
: with comma true, do not split non-string values (#334) - [Fix]
parse
: throw a TypeError instead of an Error for bad charset (#349) - [Fix] fix for an impossible situation: when the formatter is called with a non-string value
- [Refactor]
formats
: tiny bit of cleanup. - readme: add security note
- [meta] add tidelift marketing copy
- [meta] add
funding
field - [meta] add FUNDING.yml
- [meta] Clean up license text so it’s properly detected as BSD-3-Clause
- [Dev Deps] update
eslint
,@ljharb/eslint-config
,tape
,safe-publish-latest
,evalmd
,iconv-lite
,mkdirp
,object-inspect
,browserify
- [Tests]
parse
: add passingarrayFormat
tests - [Tests] use shared travis-ci configs
- [Tests]
Buffer.from
in node v5.0-v5.9 and v4.0-v4.4 requires a TypedArray - [Tests] add tests for
depth=0
anddepth=false
behavior, both current and intuitive/intended - [Tests] use
eclint
instead ofeditorconfig-tools
- [actions] add automatic rebasing / merge commit blocking
- [New]
stringify
/parse
: addcomma
as anarrayFormat
option (#276, #219) - [Fix] correctly parse nested arrays (#212)
- [Fix]
utils.merge
: avoid a crash with a null target and a truthy non-array source, also with an array source - [Robustness]
stringify
: cacheObject.prototype.hasOwnProperty
- [Refactor]
utils
:isBuffer
: small tweak; add tests - [Refactor] use cached
Array.isArray
- [Refactor]
parse
/stringify
: make a function to normalize the options - [Refactor]
utils
: reduce observable [[Get]]s - [Refactor]
stringify
/utils
: cacheArray.isArray
- [Tests] always use
String(x)
overx.toString()
- [Tests] fix Buffer tests to work in node < 4.5 and node < 5.10
- [Tests] temporarily allow coverage to fail
- [Fix]
parse
: ignore__proto__
keys (#428) - [Fix] fix for an impossible situation: when the formatter is called with a non-string value
- [Fix]
utils.merge
: avoid a crash with a null target and an array source - [Fix]
utils.merge
: avoid a crash with a null target and a truthy non-array source - [Fix] correctly parse nested arrays
- [Robustness]
stringify
: avoid relying on a globalundefined
(#427) - [Robustness]
stringify
: cacheObject.prototype.hasOwnProperty
- [Refactor]
formats
: tiny bit of cleanup. - [Refactor]
utils
:isBuffer
: small tweak; add tests - [Refactor]:
stringify
/utils
: cacheArray.isArray
- [Refactor]
utils
: reduce observable [[Get]]s - [Refactor] use cached
Array.isArray
- [Refactor]
parse
/stringify
: make a function to normalize the options - [readme] remove travis badge; add github actions/codecov badges; update URLs
- [Docs] Clarify the need for "arrayLimit" option
- [meta] fix README.md (#399)
- [meta] do not publish workflow files
- [meta] Clean up license text so it’s properly detected as BSD-3-Clause
- [meta] add FUNDING.yml
- [meta] Fixes typo in CHANGELOG.md
- [actions] backport actions from main
- [Tests] fix Buffer tests to work in node < 4.5 and node < 5.10
- [Tests] always use
String(x)
overx.toString()
- [Dev Deps] backport from main
- [New] Add support for iso-8859-1, utf8 "sentinel" and numeric entities (#268)
- [New] move two-value combine to a
utils
function (#189) - [Fix]
stringify
: fix a crash withstrictNullHandling
and a customfilter
/serializeDate
(#279) - [Fix] when
parseArrays
is false, properly handle keys ending in[]
(#260) - [Fix]
stringify
: do not crash in an obscure combo ofinterpretNumericEntities
, a bad customdecoder
, &iso-8859-1
- [Fix]
utils
:merge
: fix crash whensource
is a truthy primitive & no options are provided - [refactor]
stringify
: Avoid arr = arr.concat(...), push to the existing instance (#269) - [Refactor]
parse
: only need to reassign the var once - [Refactor]
parse
/stringify
: clean upcharset
options checking; fix defaults - [Refactor] add missing defaults
- [Refactor]
parse
: one lessconcat
call - [Refactor]
utils
:compactQueue
: make it explicitly side-effecting - [Dev Deps] update
browserify
,eslint
,@ljharb/eslint-config
,iconv-lite
,safe-publish-latest
,tape
- [Tests] up to
node
v10.10
,v9.11
,v8.12
,v6.14
,v4.9
; pin included builds to LTS
- [Fix]
parse
: ignore__proto__
keys (#428) - [Fix]
utils.merge
: avoid a crash with a null target and a truthy non-array source - [Fix] correctly parse nested arrays
- [Fix]
stringify
: fix a crash withstrictNullHandling
and a customfilter
/serializeDate
(#279) - [Fix]
utils
:merge
: fix crash whensource
is a truthy primitive & no options are provided - [Fix] when
parseArrays
is false, properly handle keys ending in[]
- [Fix] fix for an impossible situation: when the formatter is called with a non-string value
- [Fix]
utils.merge
: avoid a crash with a null target and an array source - [Refactor]
utils
: reduce observable [[Get]]s - [Refactor] use cached
Array.isArray
- [Refactor]
stringify
: Avoid arr = arr.concat(...), push to the existing instance (#269) - [Refactor]
parse
: only need to reassign the var once - [Robustness]
stringify
: avoid relying on a globalundefined
(#427) - [readme] remove travis badge; add github actions/codecov badges; update URLs
- [Docs] Clean up license text so it’s properly detected as BSD-3-Clause
- [Docs] Clarify the need for "arrayLimit" option
- [meta] fix README.md (#399)
- [meta] add FUNDING.yml
- [actions] backport actions from main
- [Tests] always use
String(x)
overx.toString()
- [Tests] remove nonexistent tape option
- [Dev Deps] backport from main
- [Fix] use
safer-buffer
instead ofBuffer
constructor - [Refactor] utils:
module.exports
one thing, instead of mutatingexports
(#230) - [Dev Deps] update
browserify
,eslint
,iconv-lite
,safer-buffer
,tape
,browserify
- [Fix] Fix parsing & compacting very deep objects (#224)
- [Refactor] name utils functions
- [Dev Deps] update
eslint
,@ljharb/eslint-config
,tape
- [Tests] up to
node
v8.4
; usenvm install-latest-npm
so newer npm doesn’t break older node - [Tests] Use precise dist for Node.js 0.6 runtime (#225)
- [Tests] make 0.6 required, now that it’s passing
- [Tests] on
node
v8.2
; fix npm on node 0.6
- [New] add
utils.assign
- [New] pass default encoder/decoder to custom encoder/decoder functions (#206)
- [New]
parse
/stringify
: addignoreQueryPrefix
/addQueryPrefix
options, respectively (#213) - [Fix] Handle stringifying empty objects with addQueryPrefix (#217)
- [Fix] do not mutate
options
argument (#207) - [Refactor]
parse
: cache index to reuse in else statement (#182) - [Docs] add various badges to readme (#208)
- [Dev Deps] update
eslint
,browserify
,iconv-lite
,tape
- [Tests] up to
node
v8.1
,v7.10
,v6.11
; npm v4.6 breaks on node < v1; npm v5+ breaks on node < v4 - [Tests] add
editorconfig-tools
- [Fix]
parse
: ignore__proto__
keys (#428) - [Fix] fix for an impossible situation: when the formatter is called with a non-string value
- [Fix] use
safer-buffer
instead ofBuffer
constructor - [Fix]
utils.merge
: avoid a crash with a null target and an array source - [Fix]
utils.merge
: avoid a crash with a null target and a truthy non-array source - [Fix]
stringify
: fix a crash withstrictNullHandling
and a customfilter
/serializeDate
(#279) - [Fix]
utils
:merge
: fix crash whensource
is a truthy primitive & no options are provided - [Fix] when
parseArrays
is false, properly handle keys ending in[]
- [Robustness]
stringify
: avoid relying on a globalundefined
(#427) - [Refactor] use cached
Array.isArray
- [Refactor]
stringify
: Avoid arr = arr.concat(...), push to the existing instance (#269) - [readme] remove travis badge; add github actions/codecov badges; update URLs
- [Docs] Clarify the need for "arrayLimit" option
- [meta] fix README.md (#399)
- [meta] Clean up license text so it’s properly detected as BSD-3-Clause
- [meta] add FUNDING.yml
- [actions] backport actions from main
- [Tests] remove nonexistent tape option
- [Dev Deps] backport from main
- [New]
qs.stringify
: addencodeValuesOnly
option - [Fix] follow
allowPrototypes
option during merge (#201, #201) - [Fix] support keys starting with brackets (#202, #200)
- [Fix] chmod a-x
- [Dev Deps] update
eslint
- [Tests] up to
node
v7.7
,v6.10
,v4.8
; disable osx builds since they block linux builds - [eslint] reduce warnings
- [Fix]
parse
: ignore__proto__
keys (#428) - [Fix] fix for an impossible situation: when the formatter is called with a non-string value
- [Fix]
utils.merge
: avoid a crash with a null target and an array source - [Fix]
utils.merge
: avoid a crash with a null target and a truthy non-array source - [Fix]
stringify
: fix a crash withstrictNullHandling
and a customfilter
/serializeDate
(#279) - [Fix]
utils
:merge
: fix crash whensource
is a truthy primitive & no options are provided - [Fix] when
parseArrays
is false, properly handle keys ending in[]
- [Robustness]
stringify
: avoid relying on a globalundefined
(#427) - [Refactor] use cached
Array.isArray
- [Refactor]
stringify
: Avoid arr = arr.concat(...), push to the existing instance (#269) - [Docs] Clarify the need for "arrayLimit" option
- [meta] fix README.md (#399)
- [meta] Clean up license text so it’s properly detected as BSD-3-Clause
- [meta] add FUNDING.yml
- [actions] backport actions from main
- [Tests] use
safer-buffer
instead ofBuffer
constructor - [Tests] remove nonexistent tape option
- [Dev Deps] backport from main
- [Fix] follow
allowPrototypes
option during merge (#201, #200) - [Dev Deps] update
eslint
- [Fix] chmod a-x
- [Fix] support keys starting with brackets (#202, #200)
- [Tests] up to
node
v7.7
,v6.10
,v4.8
; disable osx builds since they block linux builds
- [Fix] ensure that
allowPrototypes: false
does not ever shadow Object.prototype properties (thanks, @snyk!) - [Dev Deps] update
eslint
,@ljharb/eslint-config
,browserify
,iconv-lite
,qs-iconv
,tape
- [Tests] on all node minors; improve test matrix
- [Docs] document stringify option
allowDots
(#195) - [Docs] add empty object and array values example (#195)
- [Docs] Fix minor inconsistency/typo (#192)
- [Docs] document stringify option
sort
(#191) - [Refactor]
stringify
: throw faster with an invalid encoder - [Refactor] remove unnecessary escapes (#184)
- Remove contributing.md, since
qs
is no longer part ofhapi
(#183)
- [New] Add support for RFC 1738 (#174, #173)
- [New]
stringify
: AddserializeDate
option to customize Date serialization (#159) - [Fix] ensure
utils.merge
handles merging two arrays - [Refactor] only constructors should be capitalized
- [Refactor] capitalized var names are for constructors only
- [Refactor] avoid using a sparse array
- [Robustness]
formats
: cacheString#replace
- [Dev Deps] update
browserify
,eslint
,@ljharb/eslint-config
; addsafe-publish-latest
- [Tests] up to
node
v6.8
,v4.6
; improve test matrix - [Tests] flesh out arrayLimit/arrayFormat tests (#107)
- [Tests] skip Object.create tests when null objects are not available
- [Tests] Turn on eslint for test files (#175)
- [Fix]
parse
: ignore__proto__
keys (#428) - [Fix]
utils.merge
: avoid a crash with a null target and an array source - [Fix]
utils.merge
: avoid a crash with a null target and a truthy non-array source - [Fix]
utils
:merge
: fix crash whensource
is a truthy primitive & no options are provided - [Fix] when
parseArrays
is false, properly handle keys ending in[]
- [Robustness]
stringify
: avoid relying on a globalundefined
(#427) - [Refactor] use cached
Array.isArray
- [Docs] Clarify the need for "arrayLimit" option
- [meta] fix README.md (#399)
- [meta] Clean up license text so it’s properly detected as BSD-3-Clause
- [meta] add FUNDING.yml
- [actions] backport actions from main
- [Tests] use
safer-buffer
instead ofBuffer
constructor - [Tests] remove nonexistent tape option
- [Dev Deps] backport from main
- [Fix] follow
allowPrototypes
option during merge (#201, #200) - [Fix] chmod a-x
- [Fix] support keys starting with brackets (#202, #200)
- [Tests] up to
node
v7.7
,v6.10
,v4.8
; disable osx builds since they block linux builds
- [Fix] ensure that
allowPrototypes: false
does not ever shadow Object.prototype properties
- [Fix] ensure
key[]=x&key[]&key[]=y
results in 3, not 2, values - [Refactor] Be explicit and use
Object.prototype.hasOwnProperty.call
- [Tests] remove
parallelshell
since it does not reliably report failures - [Tests] up to
node
v6.3
,v5.12
- [Dev Deps] update
tape
,eslint
,@ljharb/eslint-config
,qs-iconv
- [New] pass Buffers to the encoder/decoder directly (#161)
- [New] add "encoder" and "decoder" options, for custom param encoding/decoding (#160)
- [Fix] fix compacting of nested sparse arrays (#150)
- [Fix] follow
allowPrototypes
option during merge (#201, #200) - [Fix] chmod a-x
- [Fix] support keys starting with brackets (#202, #200)
- [Tests] up to
node
v7.7
,v6.10
,v4.8
; disable osx builds since they block linux builds
- [Fix] ensure that
allowPrototypes: false
does not ever shadow Object.prototype properties
- [New] allowDots option for
stringify
(#151) - [Fix] "sort" option should work at a depth of 3 or more (#151)
- [Fix] Restore
dist
directory; will be removed in v7 (#148)
- [Fix] follow
allowPrototypes
option during merge (#201, #200) - [Fix] chmod a-x
- [Fix] support keys starting with brackets (#202, #200)
- [Tests] up to
node
v7.7
,v6.10
,v4.8
; disable osx builds since they block linux builds
- [Fix] ensure that
allowPrototypes: false
does not ever shadow Object.prototype properties - [Fix] Restore
dist
directory; will be removed in v7 (#148)
- Revert ES6 requirement and restore support for node down to v0.8.
- #127 Fix engines definition in package.json
- #124 Use ES6 and drop support for node < v4
- [Fix] ensure
key[]=x&key[]&key[]=y
results in 3, not 2, values
- #64 Add option to sort object keys in the query string
- #117 make URI encoding stringified results optional
- #106 Add flag
skipNulls
to optionally skip null values in stringify
- #98 make returning plain objects and allowing prototype overwriting properties optional
- #89 Add option to disable "Transform dot notation to bracket notation"
- #80 qs.parse silently drops properties
- #77 Perf boost
- #60 Add explicit option to disable array parsing
- #74 Bad parse when turning array into object
- #81 Add a
filter
option - #68 Fixed issue with recursion and passing strings into objects.
- #66 Add mixed array and object dot notation support Closes: #47
- #76 RFC 3986
- #85 No equal sign
- #84 update license attribute
- #73 Property 'hasOwnProperty' of object # is not a function
- #70 Add arrayFormat option
- #55 allow merging a string into an object
- #52 Return "undefined" and "false" instead of throwing "TypeError".
- #50 add option to omit array indices, closes #46
- #39 Is there an alternative to Buffer.isBuffer?
- #49 refactor utils.merge, fixes #45
- #41 avoid browserifying Buffer, for #39
- #38 how to handle object keys beginning with a number
- #33 Error when plain object in a value
- #34 use Object.prototype.hasOwnProperty.call instead of obj.hasOwnProperty
- #24 Changelog? Semver?
- #32 account for circular references properly, closes #31
- #31 qs.parse stackoverflow on circular objects
- #26 Don't use Buffer global if it's not present
- #30 Bug when merging non-object values into arrays
- #29 Don't call Utils.clone at the top of Utils.merge
- #23 Ability to not limit parameters?
- #22 Enable using a RegExp as delimiter
- #18 Why is there arrayLimit?
- #20 Configurable parametersLimit
- #21 make all limits optional, for #18, for #20
- #19 Don't overwrite null values
- #7 Empty values of a POST array disappear after being submitted
- #9 Should not omit equals signs (=) when value is null
- #6 Minor grammar fix in README
- #5 array holes incorrectly copied into object on large index