X-Git-Url: https://git.netwichtig.de/gitweb/?a=blobdiff_plain;f=launch_here.rb;h=7c4b2a5fcc61c65ee167fae8cf85256fca77648b;hb=69173fe810e61ede90f21d0fdd0b802c0607fc48;hp=2e7161dbc993aee2e8d0e2c4c373f70ce147fece;hpb=07fa0d9565f373feca3774c60fc645c96ac81652;p=user%2Fhenk%2Fcode%2Fruby%2Frbot.git diff --git a/launch_here.rb b/launch_here.rb index 2e7161db..7c4b2a5f 100755 --- a/launch_here.rb +++ b/launch_here.rb @@ -1,27 +1,68 @@ -#!/usr/bin/ruby -# -# Load rbot from this directory. (No need to install it with setup.rb) -# - -BASEDIR = Dir.pwd - -#puts "Load path: #{$LOAD_PATH.inspect}" +#!/usr/bin/env ruby +# +# Load rbot from this directory. (No need to install it with setup.rb) +# -def add_to_path(dir) - $LOAD_PATH.unshift dir +SCM_DIR = File.expand_path File.dirname(__FILE__) +puts "Running from #{SCM_DIR}" + +$:.unshift File.join(SCM_DIR, 'lib') + +$version = '0.9.15' + +pwd = Dir.pwd +begin + Dir.chdir SCM_DIR + + if File.exists? '.git' + begin + git_out = `git log -1 --pretty=raw | git name-rev --stdin`.split("\n") + commit, branch_spec = git_out.first.scan(/^commit (\S+)(?: \((\S+)\))?$/).first + $version_timestamp = git_out[4].split[-2].to_i + subject = git_out[6].strip rescue "" + subject[77..-1] = "..." if subject.length > 80 + rev = "revision #{commit[0,7]}" + rev << " [#{subject}]" unless subject.empty? + changes = `git diff-index --stat HEAD`.split("\n").last.split(", ").first rescue nil + rev << ", #{changes.strip}" if changes + if branch_spec + tag, branch, offset = branch_spec.scan(/^(?:(tag)s\/)?(\S+?)(?:^0)?(?:~(\d+))?$/).first + tag ||= "branch" + branch << " #{tag}" + branch << "-#{offset}" if offset + else + branch = "unknown branch" + end + rescue => e + puts e.inspect + branch = "unknown branch" + rev = "unknown revision" + end + $version << " (#{branch}, #{rev})" + elsif File.directory? File.join(SCM_DIR, '.svn') + rev = " (unknown revision)" + begin + svn_out = `svn info` + rev = " (revision #{$1}" if svn_out =~ /Last Changed Rev: (\d+)/ + svn_st = `svn st #{SCM_DIR}` + rev << ", local changes" if svn_st =~ /^[MDA] / + rev << ")" + rescue => e + puts e.inspect + end + $version += rev + end +ensure + Dir.chdir pwd end - + module Irc - module PKGConfig - DATADIR = File.join BASEDIR, 'data/rbot' - COREDIR = File.join BASEDIR, 'lib/rbot/core' +class Bot + module Config + @@datadir = File.join SCM_DIR, 'data/rbot' + @@coredir = File.join SCM_DIR, 'lib/rbot/core' end -end - -add_to_path( File.join BASEDIR, 'lib' ) - -p ARGV -ARGV << "--debug" -p ARGV +end +end -load( File.join BASEDIR, 'bin/rbot' ) +load File.join(SCM_DIR, 'bin/rbot')