Module: StateMachine::Integrations::Base::ClassMethods
- Included in:
- StateMachine::Integrations::Base
- Defined in:
- lib/state_machine/integrations/base.rb
Instance Attribute Summary collapse
-
#defaults ⇒ Object
readonly
The default options to use for state machines using this integration.
Instance Method Summary collapse
-
#available? ⇒ Boolean
Whether this integration is available for the current library.
-
#extended(base) ⇒ Object
Extends the given object with any version overrides that are currently active.
-
#integration_name ⇒ Object
The name of the integration.
-
#locale_path ⇒ Object
The path to the locale file containing translations for this integration.
-
#matches?(klass) ⇒ Boolean
Whether the integration should be used for the given class.
-
#version(name, &block) ⇒ Object
Creates a new version override for an integration.
-
#versions ⇒ Object
Tracks the various version overrides for an integration.
Instance Attribute Details
#defaults ⇒ Object (readonly)
The default options to use for state machines using this integration
7 8 9 |
# File 'lib/state_machine/integrations/base.rb', line 7 def defaults @defaults end |
Instance Method Details
#available? ⇒ Boolean
Whether this integration is available for the current library. This is usually only true if the ORM that the integration is for is currently defined. Default is false.
23 24 25 |
# File 'lib/state_machine/integrations/base.rb', line 23 def available? false end |
#extended(base) ⇒ Object
Extends the given object with any version overrides that are currently active
77 78 79 80 81 |
# File 'lib/state_machine/integrations/base.rb', line 77 def extended(base) versions.each do |version| base.extend(version) if version.active? end end |
#integration_name ⇒ Object
The name of the integration
10 11 12 13 14 15 16 17 18 |
# File 'lib/state_machine/integrations/base.rb', line 10 def integration_name @integration_name ||= begin name = self.name.split('::').last name.gsub!(/([A-Z]+)([A-Z][a-z])/,'\1_\2') name.gsub!(/([a-z\d])([A-Z])/,'\1_\2') name.downcase! name.to_sym end end |
#locale_path ⇒ Object
The path to the locale file containing translations for this integration. This file will only exist for integrations that actually support i18n.
70 71 72 73 |
# File 'lib/state_machine/integrations/base.rb', line 70 def locale_path path = "#{File.dirname(__FILE__)}/#{integration_name}/locale.rb" path if File.exists?(path) end |
#matches?(klass) ⇒ Boolean
Whether the integration should be used for the given class. Default is false.
29 30 31 |
# File 'lib/state_machine/integrations/base.rb', line 29 def matches?(klass) false end |
#version(name, &block) ⇒ Object
Creates a new version override for an integration. When this integration is activated, each version that is marked as active will also extend the integration.
Example
module StateMachine
module Integrations
module ORMLibrary
version '0.2.x - 0.3.x' do
def self.active?
::ORMLibrary::VERSION >= '0.2.0' && ::ORMLibrary::VERSION < '0.4.0'
end
def invalidate(object, attribute, , values = [])
# Override here...
end
end
end
end
end
In the above example, a version override is defined for the ORMLibrary integration when the version is between 0.2.x and 0.3.x.
62 63 64 65 |
# File 'lib/state_machine/integrations/base.rb', line 62 def version(name, &block) versions << mod = Module.new(&block) mod end |
#versions ⇒ Object
Tracks the various version overrides for an integration
34 35 36 |
# File 'lib/state_machine/integrations/base.rb', line 34 def versions @versions ||= [] end |