#!/usr/bin/env ruby require 'rbbt-util' require 'rbbt/util/simpleopt' require 'rbbt/workflow' require 'rbbt/monitor' $0 = "rbbt #{$previous_commands*""} #{ File.basename(__FILE__) }" if $previous_commands options = SOPT.setup < -a--all Apply to all jobs, not only uncompleted -o--older* Clean jobs not access in some time -f--force Remove locks and files regardless of been active -q--quick Quick check -d--dirty Clean dirty jobs -h--help Print this help EOF rbbt_usage and exit 0 if options[:help] workflow, task = ARGV workflow = workflow.split "," if workflow task = task.split "," if task all = options.delete :all force = options.delete :force dirty = options.delete :dirty time = options.delete :older time = Misc.timespan time, 'd' if time puts Log.color(:magenta, "# System clean") locks = Rbbt.lock_info if locks.any? puts puts Log.color(:magenta, "Locks:") locks.each do |file,info| if force or (info[:pid] and not Misc.pid_exists? info[:pid]) puts " Removing #{ file }" File.unlink file end end end persists = Rbbt.persist_info if persists.any? puts puts Log.color(:magenta, "Persist:") persists.each do |file,info| if force or (info[:pid] and Misc.pid_exists? info[:pid]) puts " Removing #{ file }" File.unlink file end end end sensiblewrites = Rbbt.sensiblewrite_info if sensiblewrites.any? puts puts Log.color(:magenta, "Writes:") sensiblewrites.each do |file,info| if force or (info[:pid] and Misc.pid_exists? info[:pid]) puts " Removing #{ file }" File.unlink file end end end exit 0 if workflow.nil? workflow = nil if workflow == ["all"] puts puts Log.color(:magenta, "# Workflow clean") puts jobs = Rbbt.job_info workflow, task workflows = {} TSV.traverse jobs, :_bar => "Checking job status" do |file,i| if options[:quick] and i[:done] status = 'done' else info = begin Open.open(i[:info_file]) do |f| Step::INFO_SERIALIAZER.load(f) end rescue {:status => :noinfo} end pid = info[:pid] status = info[:status].to_s status = :missing if status == "done" and not File.exist? file status = :nopid if status != "done" and pid.nil? status = :dead if status != "done" and pid and not Misc.pid_exists?(pid) status = :sync if status != "done" and File.exist? file status = :dirty if info[:status].to_s == "done" and dirty and Workflow.load_step(file).dirty? status = status.to_s end if time and File.exists?(file) old = Time.now - File.atime(file) status = 'old' end if (force and status !~ /done/) or status =~ /\b(old|dirty|nopid|error|missing|aborted|dead|sync)$/ or status == "" puts " Removing #{ file } - #{status}" Step.clean(file) end end