Project

co_aspects

0.0
Repository is archived
No commit activity in last 3 years
No release in over 3 years
Collection of ready to use aspects with an annotation-like syntax to attach it to methods.
2005
2006
2007
2008
2009
2010
2011
2012
2013
2014
2015
2016
2017
2018
2019
2020
2021
2022
2023
2024
2025
 Dependencies

Development

~> 1.9
~> 10.0
>= 0

Runtime

 Project Readme

CoAspects

Easily attach aspector aspects via annotations.

Installation

Add this line to your application's Gemfile:

gem 'co_aspects'

And then execute:

$ bundle

Usage

To start using the annotations, first tell the class that you want them:

class MyClass
  aspects_annotations!

  ...
end

Then you can attach any aspect to a given method via the analogous annotation:

class MyClass
  ...

  _rescue_and_notify
  def important!
    ...
  end
end

The aspect attached to a method is the camelized version of the annotation followed by "Aspect". For example, the _rescue_and_notify will attach the RescueAndNotifyAspect aspect.

Several aspects can be attached to the same method, and the same aspect can be attached to different methods.

Arguments

Aspects can receive hash arguments and a block if it needs some dynamic information from the call. These hash arguments and block must be passed via the annotation:

class Quoter
  ...

  _stats_increment as: 'ws.quoteapp' { |quote| key(quote) }
  def save_quote(quote)
    ...
  end
end

The StatsIncrementAspect, for example, can receive an alias to override the default StatsD prefix key, and a block to include a dynamic part at the end of the StatsD key.

Each aspect defines which arguments it supports and if it support a block.

Aspects

For documentation on the available aspects, refer to each aspect class located in the aspects directory.

Development

After checking out the repo, run bin/setup to install dependencies. Then, run bin/test to run the tests. You can also run bin/console for an interactive prompt that will allow you to experiment.

To install this gem onto your local machine, run bundle exec rake install.

Deployment

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, push git commits and tags, and push the .gem file to rubygems.org.

Contributing

Bug reports and pull requests are welcome on GitHub Issues.

License

The gem is available as open source under the terms of the MIT License.