require 'open3'
require 'pp'
-@exit_status = nil
-
-%w( INT TERM QUIT ).each do |signal|
- Signal.trap(signal) do
- exit_status = signal
- exit
- end
-end
-
-at_exit {
- pp @exit_status
-}
-
# Biopieces are command line scripts and uses OptionParser to parse command line
# options according to a list of casts. Each cast prescribes the long and short
# name of the option, the type, if it is mandatory, the default value, and allowed
@output = output
@status = Status.new
@status.set unless @test
- #prime_teardown
end
# Check the integrity of a list of casts, followed by parsion options from argv
path
end
- def prime_teardown
+ # Stuff to be done at begin such as setting the exit status
+ # and signal handlers
+ def self.do_at_begin
+ status = Status.new
+ status.set
exit_status = "OK"
# Install signal handlers
end
end
+ exit_status
+ end
+
+ # Make sure that file streams are closed, tmpdir removed, and
+ # exit status is written to log file.
+ def self.do_at_exit(exit_status)
at_exit do
begin
- @in.close if @in.respond_to? :close
- @out.close if @out.respond_to? :close
-
+ @in.close if @in.respond_to? :close # FIXME: This can never work
+ @out.close if @out.respond_to? :close # FIXME: Same
rescue Exception => exception
+ $stderr.puts "Exception caught!" # DEBUG
case exit_status
when 'INT' then exit_status = 'INTERRUPTED'
when 'TERM' then exit_status = 'TERMINATED'
exit_status = "DIED" unless exit_status =~ /INT|TERM|QUIT/
$stderr.puts exit_status
$stderr.puts exception.backtrace
-
ensure
status = Status.new
FileUtils.remove_entry_secure(status.get_tmpdir)
status.log(exit_status)
status.delete
+ puts "EXIT STATUS: #{exit_status}"
end
end
end
end
-# Stuff to be done at begin such as setting the exit status
-# and signal handlers
-def do_at_begin
- status = Status.new
- status.set
- exit_status = "OK"
-
- # Install signal handlers
- %w( INT TERM QUIT ).each do |signal|
- Signal.trap(signal) do
- exit_status = signal
- exit
- end
- end
-
- exit_status
-end
-
-# Make sure that file streams are closed, tmpdir removed, and
-# exit status is written to log file.
-def do_at_exit(exit_status)
- at_exit do
- begin
- @in.close if @in.respond_to? :close
- @out.close if @out.respond_to? :close
- rescue Exception => exception
- $stderr.puts "Exception caught!" # DEBUG
- case exit_status
- when 'INT' then exit_status = 'INTERRUPTED'
- when 'TERM' then exit_status = 'TERMINATED'
- end
- exit_status = "DIED" unless exit_status =~ /INT|TERM|QUIT/
- $stderr.puts exit_status
- $stderr.puts exception.backtrace
-
- ensure
- status = Status.new
- FileUtils.remove_entry_secure(status.get_tmpdir)
- status.log(exit_status)
- status.delete
- puts "EXIT STATUS: #{exit_status}"
- end
- end
-end
-
-exit_status = do_at_begin
-do_at_exit(exit_status)
-
-
__END__