Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/nshki/chusaku
Annotate your Rails controllers with route info.
https://github.com/nshki/chusaku
annotations controller gem rails routes ruby
Last synced: 2 days ago
JSON representation
Annotate your Rails controllers with route info.
- Host: GitHub
- URL: https://github.com/nshki/chusaku
- Owner: nshki
- License: mit
- Created: 2019-05-24T01:30:45.000Z (over 5 years ago)
- Default Branch: main
- Last Pushed: 2024-12-26T17:56:25.000Z (26 days ago)
- Last Synced: 2025-01-12T10:03:17.500Z (9 days ago)
- Topics: annotations, controller, gem, rails, routes, ruby
- Language: Ruby
- Homepage: https://rubygems.org/gems/chusaku
- Size: 128 KB
- Stars: 93
- Watchers: 3
- Forks: 5
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE.txt
Awesome Lists containing this project
README
# Chusaku
[![Gem Version](https://badge.fury.io/rb/chusaku.svg)](https://badge.fury.io/rb/chusaku)
Add comments above your Rails actions that look like:
```ruby
# @route GET /waterlilies/:id (waterlily)
def show
# ...
end# @route PATCH /waterlilies/:id (waterlily)
# @route PUT /waterlilies/:id (waterlily)
def update
# ...
end
```Based on your `routes.rb` file!
## Installation
Add this line to your Rails application's Gemfile:
```ruby
group :development do
gem "chusaku", require: false
end
```And then execute:
```sh
bundle install
```## Usage
From the root of your Rails application, run:
```sh
bundle exec chusaku
```Chusaku has some flags available for use as well:
```
$ bundle exec chusaku --help
Usage: chusaku [options]
--dry-run Run without file modifications
--exit-with-error-on-annotation Fail if any file was annotated
-c, --controllers-pattern=GLOB Specify alternative controller files glob pattern
-e, --exclusion-pattern=GLOB Specify controller files exclusion glob pattern
--verbose Print all annotated files
-v, --version Show Chusaku version number and quit
-h, --help Show this help message and quit
```### Rake usage
If you'd like to use Chusaku as a Rake task, add the following line to your `Rakefile`:
```ruby
require "chusaku"
Chusaku.load_tasks
```This will then allow you to call:
```sh
bin/rake chusaku
```To pass flags, pass them like you would from the CLI executable:
```sh
bin/rake chusaku -- --dry-run --exit-with-error-on-annotation
```## Development
Read the blog post explaining how the gem works at a high level: https://nshki.com/chusaku-a-controller-annotation-gem.
After checking out the repo, run `bin/setup` to install dependencies. Then, run `bundle exec rake test` to run the tests. You can also run `bin/console` for an interactive prompt that will allow you to experiment.
To release a new version, update the version number in `version.rb`, and then run `bundle exec rake release`, which will create a git tag for the version, git commits and tags, and push the `.gem` file to [rubygems.org](https://rubygems.org).