public
Description: AASM - State machines for Ruby classes
Homepage: http://rubyi.st/aasm
Clone URL: git://github.com/rubyist/aasm.git
Click here to lend your support to: aasm and make a donation at www.pledgie.com !
rubyist (author)
Wed Jun 04 10:02:16 -0700 2008
commit  2d87b4b3b1e35fbd47b6bec5374990afa197d9c0
tree    4a112806c67522e3b4383f1b6e9327b47e7f7613
parent  8a7320b9d0f943b0b24b93563cc877fdb740efb4
aasm /
name age message
file .gitignore Thu May 29 13:28:06 -0700 2008 add coverage output to gitignore [rubyist]
file CHANGELOG Wed Jun 04 10:02:16 -0700 2008 Add Kevin's change to changelog [rubyist]
file MIT-LICENSE Wed Oct 14 20:07:46 -0700 2009 cleanup, move to jeweler, nuke gemspec [Travis Tilley]
file README.rdoc Thu May 29 07:24:01 -0700 2008 Updating readme [spicycode]
file Rakefile Thu May 29 13:27:44 -0700 2008 That doesn't work [rubyist]
file TODO Sat May 31 15:08:12 -0700 2008 Support enter and exit actions on states [rubyist]
file aasm.gemspec Thu May 29 07:16:45 -0700 2008 Updated changelog and version [spicycode]
file aasm.rb Mon Jan 07 11:11:38 -0800 2008 Import into git [rubyist]
directory doc/ Thu Feb 21 08:41:56 -0800 2008 Prepare rakefile and rake tasks for gem packagi... [rubyist]
directory lib/ Tue Jun 03 21:44:25 -0700 2008 allowed :to array and :on_transition callback, ... [KevinTriplett]
directory spec/ Tue Jun 03 21:44:25 -0700 2008 allowed :to array and :on_transition callback, ... [KevinTriplett]
README.rdoc

AASM - Ruby state machines

This package contains AASM, a library for adding finite state machines to Ruby classes.

AASM started as the acts_as_state_machine plugin but has evolved into a more generic library that no longer targets only ActiveRecord models.

AASM has the following features:

  • States
  • Machines
  • Events
  • Transitions

Download

The latest AASM can currently be pulled from the git repository on github.

A release and a gem are forthcoming.

Installation

From GitHub hosted gems

  % sudo gem sources -a http://gems.github.com # (you only need to do this once)
  % sudo gem install rubyist-aasm

Building your own gems

  % rake gem
  % sudo gem install pkg/aasm-0.0.2.gem

Simple Example

Here’s a quick example highlighting some of the features.

  class Conversation
    include AASM

    aasm_initial_state :new

    aasm_state :new
    aasm_state :read
    aasm_state :closed

    aasm_event :view do
      transitions :to => :read, :from => [:new]
    end

    aasm_event :close do
      transitions :to => :closed, :from => [:read, :new]
    end
  end

Other Stuff

Author:Scott Barron <scott at elitists dot net>
License:Copyright 2006, 2007, 2008 by Scott Barron. Released under an MIT-style license. See the LICENSE file included in the distribution.

Warranty

This software is provided "as is" and without any express or implied warranties, including, without limitation, the implied warranties of merchantibility and fitness for a particular purpose.