Huge News!Announcing our $40M Series B led by Abstract Ventures.Learn More
Socket
Sign inDemoInstall
Socket

noon

Package Overview
Dependencies
Maintainers
1
Versions
114
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

noon

'nother ordinary object notation

  • 0.5.6
  • Source
  • npm
  • Socket score

Version published
Weekly downloads
15
decreased by-92.39%
Maintainers
1
Weekly downloads
 
Created
Source

noon

'nother ordinary object notation

noon

format

  • hierarchy is expressed by indentation with spaces.
grandpa
    parent
        child
        sibling
    uncle
  • two or more spaces mark the end of a dictionary key, therefore ...
  • keys and list items can have single spaces in them but ...
  • only dictionary values can contain consecutive spaces:
key 1    value 1
key 2    value 2 contains    spaces
  • if trimming your strings is not an option, you can escape:
a             |  leading spaces
b             trailing spaces  |
c             |  leading and trailing spaces  |
pipe symbol   |||
empty string  ||
  • keys must be escaped from both ends:
| s  pace |  key keeps spaces
|    |       key consists of spaces
||           key is empty string
  • objects inside lists are expressed like this:
.
    a  1
.
    b  2
  • dense notation:
key  . a .. b . c

is equivalent to

key
    a
        b
    c
advantages
  • easy to read
  • easy to write
  • fast to parse
  • normally no need to escape characters
disadvantages
  • keys can't start with the pipe symbol: |
  • escaped keys can't contain the pipe symbol
  • empty objects are not expressible
example files
  • language
  • urtil
  • font

module

noon = require 'noon'

# usage is similar to JSON 

noon.stringify { hello: 'world' }

# hello    world

noon.parse """
hello         world
what's up?    ☺
"""

# { hello: 'world', 'what\'s up?': '☺' }

stringify_options =  # stringify's second argument, defaults are: 
    indent:   4      # number of spaces per indent level
    align:    true   # vertically align object values
    maxalign: 32     # maximal number of spaces when aligning
    sort:     false  # sort object keys alphabetically
    circular: false  # check for circular references (expensive!)
    colors:   false  # colorize output with ansi colors
                     # custom dictionary or true for default colors:

 defaultColors =
     key:     chalk.bold.gray
     null:    chalk.bold.blue
     value:   chalk.bold.magenta
     string:  chalk.bold.white
     visited: chalk.bold.red

caveats

This is in alpha stadium and not meant to be completely foolproof.
Don't use it if you can't live with the limitations mentioned above.
Don't expect your data to convert flawlessly!

Keywords

FAQs

Package last updated on 05 Jan 2016

Did you know?

Socket

Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.

Install

Related posts

SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap
  • Changelog

Packages

npm

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc