Module: ButlerMainframe

Extended by:
ButlerMainframe
Included in:
ButlerMainframe
Defined in:
lib/mainframe/passport.rb,
lib/butler-mainframe.rb,
lib/core/configuration.rb,
lib/mainframe/host_base.rb,
lib/core/configuration_dynamic.rb,
lib/generators/butler_mainframe.rb

Overview

This class use Rocket 3270 emulator API www.rocketsoftware.com/products/rocket-passport-web-to-host

Defined Under Namespace

Modules: Base, Settings Classes: Configuration, Host, HostBase

Class Method Summary collapse

Instance Method Summary collapse

Class Method Details

.configurationObject



16
17
18
# File 'lib/core/configuration.rb', line 16

def self.configuration
  @configuration ||= Configuration.new
end

.configuration=(config) ⇒ Object



20
21
22
# File 'lib/core/configuration.rb', line 20

def self.configuration=(config)
  @configuration = config
end

.configure {|configuration| ... } ⇒ Object

Yields:



24
25
26
# File 'lib/core/configuration.rb', line 24

def self.configure
  yield configuration
end

.rootObject



14
15
16
# File 'lib/butler-mainframe.rb', line 14

def self.root
  File.expand_path('../..', __FILE__)
end

Instance Method Details

#configure_on_the_fly(&block) ⇒ Object

And we define a wrapper for the configuration block, that we’ll use to set up our set of options



29
30
31
# File 'lib/core/configuration_dynamic.rb', line 29

def configure_on_the_fly(&block)
  instance_eval &block
end

#parameter(*names) ⇒ Object

Appdata provides a basic single-method DSL with .parameter method being used to define a set of available settings. This method takes one or more symbols, with each one being a name of the configuration option.



13
14
15
16
17
18
19
20
21
22
23
24
25
# File 'lib/core/configuration_dynamic.rb', line 13

def parameter(*names)
  names.each do |name|
    attr_accessor name

    # For each given symbol we generate accessor method that sets option's

    # value being called with an argument, or returns option's current value

    # when called without arguments

    define_method name do |*values|
      value = values.first
      value ? self.send("#{name}=", value) : instance_variable_get("@#{name}")
    end
  end
end