X-Git-Url: https://git.netwichtig.de/gitweb/?a=blobdiff_plain;f=data%2Frbot%2Fplugins%2Fdice.rb;h=ab40aa28e6d07184a08bdc5c04e8a7e8e21c724d;hb=088cea5b9473cbf5796aac0e6104442138a11f07;hp=f0258c80f4f988761fc7b2e2cbbf508e40e7ccf1;hpb=38dde2ea8379f1919e39a4b87c91faae4b068b66;p=user%2Fhenk%2Fcode%2Fruby%2Frbot.git diff --git a/data/rbot/plugins/dice.rb b/data/rbot/plugins/dice.rb index f0258c80..ab40aa28 100644 --- a/data/rbot/plugins/dice.rb +++ b/data/rbot/plugins/dice.rb @@ -21,58 +21,96 @@ #################################################### class DiceDisplay - attr_reader :total, :view - def initialize(view, total) + attr_reader :total, :view, :dice + def initialize(dice, view, total) @total = total + @dice = dice @view = view end + + def get_view() + return "["+ dice.to_s + ": " + total.to_s + " | " + view + "] " + end end class DicePlugin < Plugin + BotConfig.register BotConfigIntegerValue.new('dice.max_dices', + :default => 100, :validate => Proc.new{|v| v > 0}, + :desc => "Maximum number of dices to throw.") + def help(plugin, topic="") - "dice (where is something like: d6 or 2d6 or 2d6+4 or 2d6+1d20 or 2d6+1d5+4d7-3d4-6) => Rolls that set of virtual dice" + plugin + " (where is something like: d6 or 2d6 or 2d6+4 or 2d6+1d20 or 2d6+1d5+4d7-3d4-6) => Rolls that set of virtual dice" end def rolldice(d) dice = d.split(/d/) + repr = [] r = 0 unless dice[0] =~ /^[0-9]+/ dice[0] = 1 end for i in 0...dice[0].to_i - r = r + rand(dice[1].to_i) + 1 + tmp = rand(dice[1].to_i) + 1 + repr << tmp.to_s + r = r + tmp end - return r + return DiceDisplay.new(d, repr.join(", "), r) end def iddice(d) + dice = d porm = d.slice!(0,1) if d =~ /d/ - r = rolldice(d) + rolled = rolldice(d) + d = rolled.view + r = rolled.total else r = d end + if porm == "-" r = 0 - r.to_i end - viewer = DiceDisplay.new("[" + porm.to_s + d.to_s + "=" + r.to_s + "] ", r) + + viewer = DiceDisplay.new(porm + dice, d.to_s, r) return viewer end def privmsg(m) - unless(m.params && m.params =~ /^[0-9]*d[0-9]+([+-]([0-9]+|[0-9]*d[0-9])+)*$/) + # If either not given parameters or given incorrect parameters, return with + # the help message + unless(m.params && m.params =~ /^[0-9]*d[0-9]+(\s*[+-]\s*([0-9]+|[0-9]*d[0-9])+)*$/) m.nickreply "incorrect usage: " + help(m.plugin) return end - a = m.params.scan(/^[0-9]*d[0-9]+|[+-][0-9]*d[0-9]+|[+-][0-9]+/) - r = rolldice(a[0]) - t = "[" + a[0].to_s + "=" + r.to_s + "] " + + # Extract the actual dice request from the message parameters, splitting it + # into dice and modifiers + a = m.params.gsub(/\s+/,'').scan(/^[0-9]*d[0-9]+|[+-][0-9]*d[0-9]+|[+-][0-9]+/) + # check nr of total dices + nr = 0 + a.each { |dice| + # We use .max with 1 so that specs such as d6 count as 1 and not as 0 + nr += [dice.split(/d/)[0].to_i, 1].max + } + if nr > @bot.config['dice.max_dices'] + m.reply "can't handle more than %u dices" % @bot.config['dice.max_dices'] + return + end + + # Roll the dice with the extracted request + rolled = rolldice(a[0]) + r = rolled.total + t = rolled.get_view() + + # Deal with all the remaining parts of the given dice request for i in 1...a.length tmp = iddice(a[i]) r = r + tmp.total.to_i - t = t + tmp.view.to_s + t = t + tmp.get_view end - m.nickreply r.to_s + " | " + t + t.chop! + m.nickreply r.to_s + " || " + m.params + ": " + t end end plugin = DicePlugin.new