X-Git-Url: https://git.netwichtig.de/gitweb/?a=blobdiff_plain;f=launch_here.rb;h=aa0448879f47675abaa100a6a9e09f4b7668cd66;hb=619870dc4934ca1360d925a6671e61ed15a8f1a2;hp=95d383ba4f5300a5cd241db2c7dcd2bedf22b713;hpb=f7c5aadba0ab9642f8ec9685b1a2a0c9fd6781d8;p=user%2Fhenk%2Fcode%2Fruby%2Frbot.git diff --git a/launch_here.rb b/launch_here.rb index 95d383ba..aa044887 100755 --- a/launch_here.rb +++ b/launch_here.rb @@ -4,14 +4,58 @@ # SCM_DIR = File.expand_path File.dirname(__FILE__) -$0 = File.expand_path $0 - -Dir.chdir SCM_DIR - puts "Running from #{SCM_DIR}" $:.unshift File.join(SCM_DIR, 'lib') +$version = '0.9.12-git' + +pwd = Dir.pwd +begin + Dir.chdir SCM_DIR + + if File.exists? '.git' + begin + git_out = `git status` + git_out.match(/^# On branch (.*)\n/) + if $1 # git 1.5.x + branch = $1.dup || "unknown" + changed = git_out.match(/^# Change(.*)\n/) + rev = "revision " + git_out = `git log -1 --pretty=format:"%h%n%b%n%ct"`.split("\n") + rev << git_out.first + $version_timestamp = git_out.last.to_i + rev << "(svn #{$1})" if git_out[1].match(/^git-svn-id: \S+@(\d+)/) + rev << ", local changes" if changed + else # older gits + git_out = `git branch` + git_out.match(/^\* (.*)\n/) + branch = $1.dup rescue "unknown" + rev = "revision " + `git rev-parse HEAD`[0,6] + end + rescue => e + puts e.inspect + branch = "unknown branch" + rev = "unknown revision" + end + $version << " (#{branch} branch, #{rev})" + elsif File.directory? File.join(up, '.svn') + rev = " (unknown revision)" + begin + svn_out = `svn info` + rev = " (revision #{$1}" if svn_out =~ /Last Changed Rev: (\d+)/ + svn_st = `svn st #{up}` + rev << ", local changes" if svn_st =~ /^[MDA] / + rev << ")" + rescue => e + puts e.inspect + end + $version += rev + end +ensure + Dir.chdir pwd +end + module Irc class Bot module Config