It's really ugly to have to keep repeating File.dirname(__FILE__), so we use a temporary variable, even in the case of a single require. This minimises long "requires" lines and "requires" statements with needing line-breaks, and should make search-and-replace a bit easier if we later want to migrate to __dir__ (Ruby >= 2.0) or require_relative. http://stackoverflow.com/questions/4333286/ruby-require-vs-require-relative-best-practice-to-workaround-running-in-both I've deliberately rejected the pattern: require File.expand_path('../relative/path', __FILE__) because it relies on inconsistent semantics and inconsistent documentation in File.expand_path: http://stackoverflow.com/questions/4333286/ruby-require-vs-require-relative-best-practice-to-workaround-running-in-both#comment34147297_4333552
		
			
				
	
	
		
			41 lines
		
	
	
		
			1.0 KiB
		
	
	
	
		
			Ruby
		
	
	
	
	
	
			
		
		
	
	
			41 lines
		
	
	
		
			1.0 KiB
		
	
	
	
		
			Ruby
		
	
	
	
	
	
this_dir = File.dirname(__FILE__)
 | 
						|
require File.expand_path('../resource', this_dir)
 | 
						|
require File.expand_path('../mixins/resource_meta', this_dir)
 | 
						|
 | 
						|
class Pacemaker::Resource::Group < Pacemaker::Resource
 | 
						|
  TYPE = 'group'
 | 
						|
  register_type TYPE
 | 
						|
 | 
						|
  include Pacemaker::Mixins::Resource::Meta
 | 
						|
 | 
						|
  # FIXME: need to handle params as well as meta
 | 
						|
 | 
						|
  attr_accessor :members
 | 
						|
 | 
						|
  def self.attrs_to_copy_from_chef
 | 
						|
    %w(members meta)
 | 
						|
  end
 | 
						|
 | 
						|
  def parse_definition
 | 
						|
    unless definition =~ /^#{self.class::TYPE} (\S+) (.+?)(\s+\\)?$/
 | 
						|
      raise Pacemaker::CIBObject::DefinitionParseError, \
 | 
						|
        "Couldn't parse definition '#{definition}'"
 | 
						|
    end
 | 
						|
    self.name    = $1
 | 
						|
    members = $2.split
 | 
						|
    trim_from = members.find_index('meta')
 | 
						|
    members = members[0..trim_from-1] if trim_from
 | 
						|
    self.members = members
 | 
						|
    self.meta    = self.class.extract_hash(definition, 'meta')
 | 
						|
  end
 | 
						|
 | 
						|
  def definition_string
 | 
						|
    str = "#{self.class::TYPE} #{name} " + members.join(' ')
 | 
						|
    unless meta.empty?
 | 
						|
      str << continuation_line(meta_string)
 | 
						|
    end
 | 
						|
    str
 | 
						|
  end
 | 
						|
 | 
						|
end
 |