From fd23821950f0562a8995735105cd31fdc6d55933 Mon Sep 17 00:00:00 2001 From: Patrick J Cherry Date: Fri, 22 Jul 2011 16:55:01 +0100 Subject: * Rejigged configuration * Added --test and --verbose flags for the server config * Started proper test suite * Config parsing now gives more sensible errors + backtrace * Rejigged people and source lists --- lib/mauve/configuration_builder.rb | 38 ++++++++++++++++++++++++++++++++++++++ 1 file changed, 38 insertions(+) create mode 100644 lib/mauve/configuration_builder.rb (limited to 'lib/mauve/configuration_builder.rb') diff --git a/lib/mauve/configuration_builder.rb b/lib/mauve/configuration_builder.rb new file mode 100644 index 0000000..fb3c781 --- /dev/null +++ b/lib/mauve/configuration_builder.rb @@ -0,0 +1,38 @@ +# encoding: UTF-8 +require 'object_builder' +require 'mauve/configuration' +require 'mauve/people_list' +require 'mauve/source_list' + +module Mauve + class ConfigurationBuilder < ObjectBuilder + + # + # This overwrites the default ObjectBuilder initialize method, such that + # the context is set as a new configuration + # + def initialize + @context = @result = Configuration.new + # FIXME: need to test blocks that are not immediately evaluated + end + + def source_list(label, *list) + _logger.warn "Duplicate source_list '#{label}'" if @result.source_lists.has_key?(label) + @result.source_lists[label] += list + end + + def people_list(label, *list) + _logger.warn("Duplicate people_list '#{label}'") if @result.people_lists.has_key?(label) + @result.people_lists[label] += list + end + + # + # Have to use the method _logger here, cos logger is defined as a builder elsewhere. + # + def _logger + @logger ||= Log4r::Logger.new(self.class.to_s) + end + + end + +end -- cgit v1.2.1