X-Git-Url: https://git.netwichtig.de/gitweb/?a=blobdiff_plain;f=lib%2Frbot%2Fconfig.rb;h=23a445f978a5ccfeb245bb59aeac2834c521d2bd;hb=9996da20c88d45c34b8f1267b23b83ae1e1bbea3;hp=360cba01867c548339e2daca78dbfe9ac324926c;hpb=1ad496b1f55715c33593b545299f5c5e877e25f0;p=user%2Fhenk%2Fcode%2Fruby%2Frbot.git diff --git a/lib/rbot/config.rb b/lib/rbot/config.rb index 360cba01..23a445f9 100644 --- a/lib/rbot/config.rb +++ b/lib/rbot/config.rb @@ -63,18 +63,20 @@ module Config end def get return @manager.config[@key] if @manager.config.has_key?(@key) - return @default + return default end alias :value :get def set(value, on_change = true) @manager.config[@key] = value @manager.changed = true @on_change.call(@manager.bot, value) if on_change && @on_change + return self end def unset @manager.config.delete(@key) @manager.changed = true @on_change.call(@manager.bot, value) if @on_change + return self end # set string will raise ArgumentErrors on failed parse/validate @@ -287,9 +289,13 @@ module Config return false end - # TODO should I implement this via Value or leave it direct? - # def []=(key, value) - # end + def []=(key, value) + return @items[key.to_sym].set(value) if @items.has_key?(key.to_sym) + if @config.has_key?(key.to_sym) + warning _("Unregistered lookup #{key.to_sym.inspect}") + return @config[key.to_sym] = value + end + end # pass everything else through to the hash def method_missing(method, *args, &block)