0.1.2 • Published 5 months ago

compactjson v0.1.2

Weekly downloads
3
License
ISC
Repository
github
Last release
5 months ago

compactjson

JSON.stringify(data) with fewer mostly-blank lines.

Mnemonic: compact-json has the -dash- in its name to remind you that it produces a -dash- bullet list, not JSON.

Usage

from usage.js:

var compactjson = require('compactjson'),
  data = { opts: compactjson.defaultOpts, '!': 1,
    tasks: [ 'wash cat', 'eat some vegetables', 'sort arrays (not)' ],
    dex: { kadabra: 64, abra: 63 },
    types: { num: -123.45, bool: false, Obj: {}, arr: [] },
    q1: [], q2: [], q3: [ true, true ], q4: [], q5: [],
    },
  jsonStr = compactjson(data, { width: 64 });
console.log(jsonStr);

Result:

{ "!": 1, "dex": { "abra": 63, "kadabra": 64 },
  "opts": { "breakAfterBroken": true,
    "breakAfterContainer": "unless-empty", "indent": 2,
    "maxItemsPerLine": 4, "serializer": null,
    "sortKeys": true, "width": 79 },
  "q1": [], "q2": [], "q3": [ true, true ],
  "q4": [], "q5": [],
  "tasks": [ "wash cat", "eat some vegetables", "sort arrays (not)" ],
  "types": { "Obj": {}, "arr": [], "bool": false, "num": -123.45 } }

CLI:

$ compactjson package.json | grep main
  "license": "ISC", "main": "cj.js", "name": "compactjson",

Options

For defaults, see "opts": { … } above. For edge cases, see the tests.

  • indent: A string, or the number of spaces, to be used for indentation.
  • breakAfterBroken: (bool) Whether to force a new line after any value whose JSON encoding contained a line break.
  • breakAfterContainer:
    • false: Data containers have no special effect on line wrap.
    • true: Force a new line after any container.
    • 'unless-empty': Empty containers have no special effect on line wrap, but force a new line after any that actually contain data.
  • maxItemsPerLine: Force a new line in front of the next value if the current line already contains this many values.
  • serializer: The 2nd argument for any call to native JSON.stringify.
  • sortKeys: (bool or func) Secret ninja option.
  • width: Try to keep lines at most this long.

Caveats

  • Line width for wrapping measures items in JavaScript native string length (= UCS-2 characters) and thus produces unexpectedly short lines if there are lots of high Unicode characters in them.

License

ISC

0.1.2

5 months ago

0.1.1

8 years ago

0.1.0

8 years ago