Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/apexatoll/kangaru
🦘 Kangaru: a framework for building command line applications in Ruby 🦘
https://github.com/apexatoll/kangaru
Last synced: about 2 months ago
JSON representation
🦘 Kangaru: a framework for building command line applications in Ruby 🦘
- Host: GitHub
- URL: https://github.com/apexatoll/kangaru
- Owner: apexatoll
- License: mit
- Created: 2023-09-16T11:00:30.000Z (over 1 year ago)
- Default Branch: main
- Last Pushed: 2023-12-16T18:31:43.000Z (about 1 year ago)
- Last Synced: 2024-10-21T02:07:59.561Z (3 months ago)
- Language: Ruby
- Homepage:
- Size: 375 KB
- Stars: 3
- Watchers: 1
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG.md
- License: LICENSE.txt
Awesome Lists containing this project
README
# Kangaru - A Ruby Framework for Building Command Line Applications
Kangaru is an open-source framework written in Ruby for building powerful and efficient command line applications. This project aims to make it easier for developers to create complex CLI programs with minimal effort, by providing a set of useful tools and libraries in a configurable ecosystem.
> Note: This software is currently in beta mode, meaning it may contain bugs and be subject to changes. Please exercise caution when using this software and report any issues you encounter. The first production-ready release of Kangaru will be version 1.0.0.
## Features
- MVC architecture drawing heavy inspiration from Rails
- ERB rendering of view templates with embedded Ruby capabilities
- SQLite and Sequel integration allowing databases to be created and used by your CLI
- A powerful command parser that routes terminal requests to their controller
- Zeitwerk-based autoloading of gem files
- Simple installation, integration and configuration## Quick Setup
It is recommended to create a new Ruby gem for each Kangaru CLI application. This can be executed through `bundler` with the following command:
```sh
bundle gem gem_name
```Next add Kangaru to your Gem's Gemfile and bundle install:
```ruby
# Gemfile
gem "kangaru"
```
```sh
bundle install
```Kangaru's set up is bundled up into a single Ruby module that must be extended from the entry file for your Gem application. Conventionally this will be the Ruby file at `/gem_name/lib/gem_name.rb`, where `gem_name` is the name of the application specified with the `bundle gem` command.
For example:
```ruby
# gem_name/lib/gem_name.rb
require "kangaru"module GemName
extend Kangaru::Initialiser
end
```This extension will set up Kangaru in the context of your Gem, including setting up processes such as the autoloader and config.
## Documentation
- TBC