Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/iostreamer-x/awkward

A NodeJS based shell. Everything is an Object!
https://github.com/iostreamer-x/awkward

coffeescript javascript nodejs terminal

Last synced: 2 days ago
JSON representation

A NodeJS based shell. Everything is an Object!

Awesome Lists containing this project

README

        

# Awkward
[![Build Status](https://travis-ci.org/iostreamer-X/Awkward.png)](https://travis-ci.org/iostreamer-X/Awkward)

![](https://labs.turbo.run/git-brag?repo=Awkward&user=iostreamer-X&maxn-3000)

A NodeJS based shell. Everything is an Object!

# Install

`npm install -g awkward`

# Whuuut?
To me, awk is powerful but really weird. Often times I want to get some information
out of a command which gives a structured output but I get discouraged because
I am really lazy.

Enter, awkward. It's a NodeJS based shell. It lets you run
javascript functions on system commands.

For example:
`ls().forEach(a => console.log(a[0], a[0].length))`

One can also use flags and piped commands like this:


`(ps -ef)().map(a => [a[0], a[7]]).forEach(a => console.log(a))`

### Update:

Underscore added as a dependency and now you can use it in the awkward terminal

# Philosophy

Every structured data given as an output by shell commands or other
binaries can be represented as a JS array and one should be able apply
`Array` methods like `map`, `forEach`, `filter` on the data in a functional style.

# How it works
Once the program notices that the user wants to run js functions, it runs the command
and stores the result in an array. Let's take the example of `ps`:

### Shell output
``` shell
PID TTY TIME CMD
13750 pts/14 00:00:00 bash
25193 pts/14 00:00:03 node
25271 pts/14 00:00:00 sh
25272 pts/14 00:00:00 ps
```

### Corresponding array
``` js
[ [ 'PID', 'TTY', 'TIME', 'CMD' ],
[ '13750', 'pts/14', '00:00:00', 'bash' ],
[ '25193', 'pts/14', '00:00:03', 'node' ],
[ '25283', 'pts/14', '00:00:00', 'sh' ],
[ '25284', 'pts/14', '00:00:00', 'ps' ] ]
```

And the functions you pass are `eval`uated as:


`resulting_array.`.

Which actually is the only supported syntax, for now. One can only chain
commands and functions like this:


`(command).function((elem)=>{})`

So, doing `console.log(ls())` won't work, for now.

# Demo