
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
|