node/deps/npm/node_modules/archy/README.markdown

89 lines
1.7 KiB
Markdown
Raw Normal View History

2014-11-05 07:08:12 +08:00
# archy
2012-03-29 10:36:44 +08:00
Render nested hierarchies `npm ls` style with unicode pipes.
2014-11-05 07:08:12 +08:00
[![browser support](http://ci.testling.com/substack/node-archy.png)](http://ci.testling.com/substack/node-archy)
2012-03-29 10:36:44 +08:00
[![build status](https://secure.travis-ci.org/substack/node-archy.png)](http://travis-ci.org/substack/node-archy)
2014-11-05 07:08:12 +08:00
# example
2012-03-29 10:36:44 +08:00
``` js
var archy = require('archy');
var s = archy({
label : 'beep',
nodes : [
'ity',
{
label : 'boop',
nodes : [
{
label : 'o_O',
nodes : [
{
label : 'oh',
nodes : [ 'hello', 'puny' ]
},
'human'
]
},
'party\ntime!'
]
}
]
});
console.log(s);
```
output
```
beep
├── ity
└─┬ boop
├─┬ o_O
│ ├─┬ oh
│ │ ├── hello
│ │ └── puny
│ └── human
└── party
time!
```
2014-11-05 07:08:12 +08:00
# methods
2012-03-29 10:36:44 +08:00
var archy = require('archy')
2014-11-05 07:08:12 +08:00
## archy(obj, prefix='', opts={})
2012-03-29 10:36:44 +08:00
Return a string representation of `obj` with unicode pipe characters like how
`npm ls` looks.
`obj` should be a tree of nested objects with `'label'` and `'nodes'` fields.
`'label'` is a string of text to display at a node level and `'nodes'` is an
array of the descendents of the current node.
If a node is a string, that string will be used as the `'label'` and an empty
array of `'nodes'` will be used.
`prefix` gets prepended to all the lines and is used by the algorithm to
recursively update.
If `'label'` has newlines they will be indented at the present indentation level
with the current prefix.
To disable unicode results in favor of all-ansi output set `opts.unicode` to
`false`.
2014-11-05 07:08:12 +08:00
# install
2012-03-29 10:36:44 +08:00
With [npm](http://npmjs.org) do:
```
npm install archy
```
2014-11-05 07:08:12 +08:00
# license
2012-03-29 10:36:44 +08:00
2014-11-05 07:08:12 +08:00
MIT