Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/geoffharcourt/sydney
A gem for parsing bash alias files
https://github.com/geoffharcourt/sydney
Last synced: 19 days ago
JSON representation
A gem for parsing bash alias files
- Host: GitHub
- URL: https://github.com/geoffharcourt/sydney
- Owner: geoffharcourt
- License: mit
- Created: 2013-01-20T19:17:27.000Z (about 12 years ago)
- Default Branch: master
- Last Pushed: 2013-01-29T13:48:12.000Z (almost 12 years ago)
- Last Synced: 2024-04-26T08:21:17.955Z (9 months ago)
- Language: JavaScript
- Size: 199 KB
- Stars: 0
- Watchers: 1
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# Sydney
[![Gem Version](https://badge.fury.io/rb/sydney.png)](http://badge.fury.io/rb/sydney)
[![Dependency Status](https://gemnasium.com/geoffharcourt/sydney.png)](https://gemnasium.com/geoffharcourt/sydney)
[![Build Status](https://secure.travis-ci.org/geoffharcourt/sydney.png)](http://travis-ci.org/geoffharcourt/sydney?branch=master)
[![Code Climate](https://codeclimate.com/badge.png)](https://codeclimate.com/github/geoffharcourt/sydney)A [Treetop](https://github.com/nathansobo/treetop) parser for bash alias files. Organize your aliases by sections and keep comments associated with the aliases they document.
Sydney was created to feed my process an alias file and feed it to
[cheaters](https://github.com/ttscoff/cheaters), an excellent
cheatsheet system by Brett Terpstra. The output from Sydney can be a Treetop::Runtime::SyntaxNode tree, an array of the sections in your alias file, or an array of the aliases without section groupings.## Installation
Install it yourself as:
$ gem install sydney
## Usage
Feed your alias file to Sydney as a single string.
Sydney.parse(IO.readlines("/my/home/folder/.aliases").join)
Sydney.parse returns a Treetop syntax tree. If you organize your alias
file into sections, preceeding each section with double-banged comments,
you can use `Sydney.sections` to return an array of Section nodes. `Sydney.aliases` returns an array of AliasEntry nodes, with sections flattened out.Each section contains one or more AliasEntry nodes. An AliasEntry node
ties comments (AliasComment) before an alias to the definition
(AliasDefinition). See the documentation## Credits
Sydney was created and is maintained by [Geoff Harcourt](http://github.com/geoffharcourt) at [Five Tool Development](http://fivetool.io).## Contributing
I'm looking for further ideas for Sydney. Please report parsing issues through [Github Issues](https://github.com/geoffharcourt/sydney/issues). Pull requests for feature additions are welcome!
1. Fork it
2. Create your feature branch (`git checkout -b my-new-feature`)
3. Commit your changes (`git commit -am 'Add some feature'`)
4. Push to the branch (`git push origin my-new-feature`)
5. Create new Pull Request