Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/fsquillace/buava
The utility library for Bash you always dreamed of
https://github.com/fsquillace/buava
Last synced: 2 months ago
JSON representation
The utility library for Bash you always dreamed of
- Host: GitHub
- URL: https://github.com/fsquillace/buava
- Owner: fsquillace
- License: gpl-3.0
- Created: 2017-06-25T13:59:32.000Z (over 7 years ago)
- Default Branch: master
- Last Pushed: 2022-03-03T18:26:48.000Z (almost 3 years ago)
- Last Synced: 2024-08-21T21:27:52.555Z (5 months ago)
- Language: Shell
- Size: 94.7 KB
- Stars: 14
- Watchers: 3
- Forks: 2
- Open Issues: 2
-
Metadata Files:
- Readme: README.md
- Contributing: CONTRIBUTING.md
- License: LICENSE
Awesome Lists containing this project
README
Buava
=====
The utility library for Bash you always dreamed of.|Project Status|
|:-----------:|
|[![Build status](https://api.travis-ci.org/fsquillace/buava.png?branch=master)](https://travis-ci.org/fsquillace/buava) |**Table of Contents**
- [Quickstart](#quickstart)
- [Troubleshooting](#troubleshooting)
- [Contributing](#contributing)Quickstart
==========
Take a look at the script located in [lib directory](lib) like [utils.sh](lib/utils.sh).Table of buava functions
==================
This table shows a incomplete list of functions available in Buava:| Function name | Description |
| ------------- | ----------- |
| `check_not_null` | Raise an error if variable is null |
| `echoerr` | Print on stderr |
| `die` | Print a stderr message and terminate with status 1 |
| `die_on_status` | Print a stderr message and terminate with the given status code |
| `error` | Print an error in stderr |
| `warn` | Print a warn in stderr |
| `info` | Print an info in stdout |
| `bold_white` | Change color |
| `bold_cyan` | Change color |
| `bold_cyan` | Change color |
| `bold_red` | Change color |
| `normal` | Change color |
| `ask` | Ask a question to answer Yes/No |
| `choose` | Choose between multiple option |
| `contains_element ` | Check if element is in an array |
| `input` | Take a free form input |
| `check_and_trap` | Before `trap` signal check whether the trap already exists |
| `check_and_force_trap` | Before `trap` signal warn if the trap already exists |
| `apply` | Idempotent apply a message in a file |
| `is_applied` | Check if the message has been applied in a file |
| `unapply` | Idempotent unapply a message in a file |
| `link` | Idempotent link a configuration file to a well-known program (i.e. vim, emacs, and many others)
| `unlink` | Idempotent unlink a configuration file to a well-known program |
| `link_to` | Idempotent symlink from a source to a destination |
| `check_link` | Check symlink
| `unlink_from` | Idempotent unlink a symlink from source to a destination |
| `download` | Flexible and resilient download function |
| `install_or_update_vim_plugin_git_repo` | Idempotent management of vim plugins |
| `install_or_update_git_repo` | Idempotent management of git repos |
| `setup_configuration` | Flexible setup for configurations |
| `backup` | Keep efficiently a number of backups for a given file |
| `delete` | Idempotent delete for files and directories |
| `osx_detect` | True whether the platform is OSX |Troubleshooting
===============
This section has been left blank intentionally.
It will be filled up as soon as troubles come in!Contributing
============
You could help improving Buava in the following ways:- [Reporting Bugs](CONTRIBUTING.md#reporting-bugs)
- [Suggesting Enhancements](CONTRIBUTING.md#suggesting-enhancements)
- [Writing Code](CONTRIBUTING.md#your-first-code-contribution)