X-Git-Url: https://git.netwichtig.de/gitweb/?a=blobdiff_plain;f=bin%2Frbot;h=6ede9a615b84f99fc44b7198966c52642818302c;hb=8db3c907730752ccc668c69080680d1b90140c10;hp=c46b9571051601b34ec8657717494f0a91136b22;hpb=aabe8920ae1e120587c8e27a62827d28afdc04e5;p=user%2Fhenk%2Fcode%2Fruby%2Frbot.git diff --git a/bin/rbot b/bin/rbot index c46b9571..6ede9a61 100755 --- a/bin/rbot +++ b/bin/rbot @@ -25,37 +25,57 @@ $VERBOSE=true require 'etc' require 'getoptlong' -require 'rbot/ircbot' require 'fileutils' -require 'rbconfig' -$debug = true -$version="0.9.8" +$version="0.9.9" $opts = Hash.new -# print +message+ if debugging is enabled -def debug(message=nil) - print "DEBUG: #{message}\n" if($debug && message) - #yield -end +orig_opts = ARGV.dup opts = GetoptLong.new( - [ "--debug", "-d", GetoptLong::NO_ARGUMENT ], - [ "--help", "-h", GetoptLong::OPTIONAL_ARGUMENT ] + ["--debug", "-d", GetoptLong::NO_ARGUMENT], + ["--help", "-h", GetoptLong::NO_ARGUMENT], + ["--trace", "-t", GetoptLong::REQUIRED_ARGUMENT], + ["--version", "-v", GetoptLong::NO_ARGUMENT] ) +$debug = false opts.each {|opt, arg| $debug = true if(opt == "--debug") $opts[opt.sub(/^-+/, "")] = arg } -if(bot = Irc::IrcBot.new(ARGV.shift)) - if($opts["help"]) - # query bot help from the commandline - puts bot.help($opts["help"]) - else - # just run the bot - bot.mainloop - end +if ($opts["trace"]) + set_trace_func proc { |event, file, line, id, binding, classname| + if classname.to_s == $opts["trace"] + printf "TRACE: %8s %s:%-2d %10s %8s\n", event, File.basename(file), line, id, classname + end + } +end + +begin + require 'rbot/ircbot' +rescue LoadError => e + puts "Error: couldn't find the rbot/ircbot module for loading\n - did you install rbot using install.rb?" + exit 2 +end + +if ($opts["version"]) + puts "rbot #{$version}" + exit 0 +end + +if ($opts["help"]) + puts "usage: rbot [options] [config directory]" + puts " -h, --help this message" + puts " -v, --version version information" + puts " -d, --debug enable debug messages" + puts "config directory defaults to ~/.rbot" + exit 0 +end + +if(bot = Irc::IrcBot.new(ARGV.shift, :argv => orig_opts)) + # just run the bot + bot.mainloop end