jst

package module
v0.0.0-...-e89fcc2 Latest Latest
Warning

This package is not in the latest version of its module.

Go to latest
Published: Sep 30, 2021 License: Apache-2.0, MIT, Apache-2.0, + 1 more Imports: 7 Imported by: 0

README

go-jst

JST -- short for JSON Tables -- is a json formatter that produces tabular data, aligned for pretty printing and pleasant reading.

JST is plain ol' json, and leans in on the non-semantic whitespace to produce aligned, columnar output. These table-like views of data are human-friendly, and easy to skim. (If you've used column -t before in the shell: it's like that, but structurally aware of JSON.)

JST output still parses as completely regular json, with any unmodified off-the-shelf json parser.

JST can be fed any json data as input, and will use heuristics to "do the right thing" and present it well.

Let's see it!

This picture is a side-by-side comparison with jq output:

A table-like format means much more information can fit into the same two-dimensional space. The columnar layout makes it easier to compare the same field across multiple objects.

(jq is of course freakin awesome. I consider it an inspiration. But this visualization shows nicely how prioritizing compactness and alignment can produce a very different feel.)

How does it work?

By default, JST is based entirely on shameless (but effective) heuristics. It's also configurable.

(Okay, it will be configurable. This is a hobby project -- it does what I need it to do, when I need it. "PRs welcome.")

You can read more about the heuristics in docs/structure-detection.

You can read more about the configuration mechanisms in docs/configuration.

It's really just JSON.

You can pipe JST output straight to any other program that processes JSON data. You can pipe JST output into jq, for example!

(If using JST in colorized mode, you might need to filter the color codes back out.)

Are there caveats?

Of course!

Given that JST is "it's just json", we have limits: we can't be like a spreedsheet that truncates the rendering of a cell, but expands on click, etc; we just don't have those options. In general the JST formatter is making a best effort, and is designed to play nice if it's fed data that's playing (reasonably) nice. It's definitely not guaranteed to do a perfect thing for all data with zero configuration; I don't think that's even possible.

JST doesn't try to format things nicely in the face of arbitrary input. At some point you'll have to configure things if the heuristics don't work for you.

If someone puts in a 400-character long string, JST will still align a whole column to that (not truncate it).

JST sort of generally assumes you have infinite horizontal screen space. If you don't have enough room to fit the data, it probably won't look nice anymore -- this depends a lot on how your terminal handles soft wrapping (or if it's clever enough to scroll). There's only so much that can be done when we're doing plain text presentation and you've got more data than the screen can hold. (There's also support for kicking some "columns" to their own line (like sub-tables automatically do), but it requires configuration.)

JST is meant for being pretty, not maximizing throughput. It also can't stream. (You can't do columnar layout until you've seen how big all the columns have to be, which inherently requires two passes over the data: one to find the sizes, and another to do the aligned printing.)

Overall, I'd consider using this on things like formatting (config files, or test fixture data files, etc); or rapid prototyping UI; things like that. Be judicious about putting it in a situation that's going to handle totally unbounded user input.

Known Bugs

The size-computing functions used for computing column alignment don't correctly handle multi-byte characters, nor graphemes. They will generally over-estimate the size of these things, which causes too little spacing to be added during aligned printing.

See also caveats for things that aren't bugs, but are still limitations you probably want to know about.

License

SPDX-License-Identifier: Apache-2.0 OR MIT

Documentation

Overview

"jst" -- JSON Table -- is a format that's parsable as JSON, while sprucing up the display to humans using the non-significant whitespace cleverly. Regular data can be piped into a JSON Table formatter, and some simple heuristics will attempt to detect table structure.

Lists can be turned into column-aligned tables:

  • Every time there's a list, and the first entry is a map, we'll try to treat it as a table.
  • Every time a map in that list starts with the same first key as the first map did, it's a table row.
  • Every thing that's a table row will be buffered, and we try to fit each key into a table column.
  • (FUTURE) You can manually specify keys that should be excluded from columns; these will be shifted to the end and packed tightly.
  • We'll store the size of the widest value for each column. We'll need to do this over every row so we can align output spacing.
  • If there's a map in the list that doesn't start with the same first key, it's a table exclusion, and gets formatted densely.
  • If a map has a value that's a list, we attempt to apply this whole ruleset over again from the top.
  • If a table is detected, we'll print the key on its own new line, slightly indented, together with the list open. Then, emit the table onsubsequent further indented lines.

Maps can also be turned into column-aligned tables:

  • You have to use additional configuration to engage this: by default, only lists trigger table mode.
  • The search for table rows begins anew with each map value. The map keys form a defacto first column.
  • Thereafter, all the rules for handling each table row is the same the rules described above for lists.

Decorations can be applied:

  • Defaults include colorizing map keys vs values, and optionally colorizing column names distinctly from other keys.
  • These colorations operate by ANSI codes (e.g., they work in terminals). The palette is accordingly limited.
  • (FUTURE) You can override colors of specific keys and values.

The overall nature of detecting traits of the data (particularly, size) means JSON Tables cannot be created streamingly; we have to process the entire structure first, and only then can we begin to output correctly aligned data. (It's for this reason that this is implemented over IPLD Nodes, and would be somewhat painful to implement using just refmt Tokens -- we'd end up buffering *all* the tokens anyway, and wanting to build an index, etc.)

There's no unmarshal functions because unmarshal is just... regular JSON unmarshal.

Index

Constants

This section is empty.

Variables

This section is empty.

Functions

func Marshal

func Marshal(n datamodel.Node, w io.Writer) error

func MarshalConfigured

func MarshalConfigured(cfg Config, n datamodel.Node, w io.Writer) error

Types

type Color

type Color struct {
	Enabled      bool
	KeyHighlight []byte
	PlainValue   []byte
}

type Config

type Config struct {
	Indent []byte
	Color  Color
}

Directories

Path Synopsis
cmd

Jump to

Keyboard shortcuts

? : This menu
/ : Search site
f or F : Jump to
y or Y : Canonical URL