Skip to content

Commit

Permalink
fix: residual space after section causes bad parsing
Browse files Browse the repository at this point in the history
Any character left on a line after a section should be ignored.
  • Loading branch information
Nautigsam committed Jan 18, 2022
1 parent 4f28994 commit 12d7693
Show file tree
Hide file tree
Showing 3 changed files with 6 additions and 2 deletions.
4 changes: 2 additions & 2 deletions lib/ini.js
Original file line number Diff line number Diff line change
Expand Up @@ -63,8 +63,8 @@ const decode = str => {
const out = Object.create(null)
let p = out
let section = null
// section |key = value
const re = /^\[([^\]]*)\]$|^([^=]+)(=(.*))?$/i
// section |key = value
const re = /^\[([^\]]*)\].*$|^([^=]+)(=(.*))?$/i
const lines = str.split(/[\r\n]+/g)

for (const line of lines) {
Expand Down
1 change: 1 addition & 0 deletions tap-snapshots/test/foo.js.test.cjs
Original file line number Diff line number Diff line change
Expand Up @@ -35,6 +35,7 @@ Null Object {
"three",
"this is included",
],
"b": Null Object {},
"br": "warm",
"eq": "eq=eq",
"false": false,
Expand Down
3 changes: 3 additions & 0 deletions test/fixtures/foo.ini
Original file line number Diff line number Diff line change
Expand Up @@ -69,6 +69,9 @@ j = "{ o: "p", a: { av: "a val", b: { c: { e: "this [value]" } } } }"
cr[] = four
cr[] = eight
; b section with a space after its title
[b]
; nested child without middle parent
; should create otherwise-empty a.b
[a.b.c]
Expand Down

0 comments on commit 12d7693

Please sign in to comment.