1*b1cdbd2cSJim Jagielski#************************************************************** 2*b1cdbd2cSJim Jagielski# 3*b1cdbd2cSJim Jagielski# Licensed to the Apache Software Foundation (ASF) under one 4*b1cdbd2cSJim Jagielski# or more contributor license agreements. See the NOTICE file 5*b1cdbd2cSJim Jagielski# distributed with this work for additional information 6*b1cdbd2cSJim Jagielski# regarding copyright ownership. The ASF licenses this file 7*b1cdbd2cSJim Jagielski# to you under the Apache License, Version 2.0 (the 8*b1cdbd2cSJim Jagielski# "License"); you may not use this file except in compliance 9*b1cdbd2cSJim Jagielski# with the License. You may obtain a copy of the License at 10*b1cdbd2cSJim Jagielski# 11*b1cdbd2cSJim Jagielski# http://www.apache.org/licenses/LICENSE-2.0 12*b1cdbd2cSJim Jagielski# 13*b1cdbd2cSJim Jagielski# Unless required by applicable law or agreed to in writing, 14*b1cdbd2cSJim Jagielski# software distributed under the License is distributed on an 15*b1cdbd2cSJim Jagielski# "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY 16*b1cdbd2cSJim Jagielski# KIND, either express or implied. See the License for the 17*b1cdbd2cSJim Jagielski# specific language governing permissions and limitations 18*b1cdbd2cSJim Jagielski# under the License. 19*b1cdbd2cSJim Jagielski# 20*b1cdbd2cSJim Jagielski#************************************************************** 21*b1cdbd2cSJim Jagielski 22*b1cdbd2cSJim Jagielski 23*b1cdbd2cSJim Jagielski 24*b1cdbd2cSJim Jagielskipackage installer::exiter; 25*b1cdbd2cSJim Jagielski 26*b1cdbd2cSJim Jagielskiuse installer::files; 27*b1cdbd2cSJim Jagielskiuse installer::globals; 28*b1cdbd2cSJim Jagielskiuse installer::logger; 29*b1cdbd2cSJim Jagielskiuse installer::systemactions; 30*b1cdbd2cSJim Jagielskiuse installer::worker; 31*b1cdbd2cSJim Jagielski 32*b1cdbd2cSJim Jagielski############################################ 33*b1cdbd2cSJim Jagielski# Exiting the program with an error 34*b1cdbd2cSJim Jagielski# This function is used instead of "die" 35*b1cdbd2cSJim Jagielski############################################ 36*b1cdbd2cSJim Jagielski 37*b1cdbd2cSJim Jagielskisub exit_program 38*b1cdbd2cSJim Jagielski{ 39*b1cdbd2cSJim Jagielski my ($message, $function) = @_; 40*b1cdbd2cSJim Jagielski 41*b1cdbd2cSJim Jagielski # If an installation set is currently created, the directory name is saved in $installer::globals::saveinstalldir 42*b1cdbd2cSJim Jagielski # If this directory name matches with "_inprogress", it has to be renamed into "_witherror" 43*b1cdbd2cSJim Jagielski 44*b1cdbd2cSJim Jagielski if ( $installer::globals::saveinstalldir =~ /_inprogress/ ) { installer::systemactions::rename_string_in_directory($installer::globals::saveinstalldir, "_inprogress", "_witherror"); } 45*b1cdbd2cSJim Jagielski 46*b1cdbd2cSJim Jagielski # Cleaning files from pool tooling 47*b1cdbd2cSJim Jagielski if ( $installer::globals::processhaspoolcheckfile ) { unlink $installer::globals::poolcheckfilename; } 48*b1cdbd2cSJim Jagielski if ( $installer::globals::processhaspoollockfile ) { unlink $installer::globals::poollockfilename; } 49*b1cdbd2cSJim Jagielski 50*b1cdbd2cSJim Jagielski installer::worker::clean_output_tree(); # removing directories created in the output tree 51*b1cdbd2cSJim Jagielski 52*b1cdbd2cSJim Jagielski # If @installer::globals::logfileinfo is not empty, it can be used. 53*b1cdbd2cSJim Jagielski # Otherwise the content of @installer::globals::globallogfileinfo has to be used. 54*b1cdbd2cSJim Jagielski 55*b1cdbd2cSJim Jagielski my $infoline; 56*b1cdbd2cSJim Jagielski 57*b1cdbd2cSJim Jagielski $installer::globals::logfilename = $installer::globals::exitlog . $installer::globals::logfilename; 58*b1cdbd2cSJim Jagielski 59*b1cdbd2cSJim Jagielski if ( ! $installer::globals::globalinfo_copied ) { installer::logger::copy_globalinfo_into_logfile(); } 60*b1cdbd2cSJim Jagielski 61*b1cdbd2cSJim Jagielski if ( $#installer::globals::logfileinfo > -1 ) 62*b1cdbd2cSJim Jagielski { 63*b1cdbd2cSJim Jagielski $installer::logger::Lang->print("\n"); 64*b1cdbd2cSJim Jagielski $installer::logger::Lang->print("***************************************************************\n"); 65*b1cdbd2cSJim Jagielski $installer::logger::Lang->print($message."\n"); 66*b1cdbd2cSJim Jagielski $installer::logger::Lang->printf("in function: %s\n", $function); 67*b1cdbd2cSJim Jagielski $installer::logger::Lang->printf("***************************************************************\n"); 68*b1cdbd2cSJim Jagielski 69*b1cdbd2cSJim Jagielski# installer::files::save_file($installer::globals::logfilename ,\@installer::globals::logfileinfo); 70*b1cdbd2cSJim Jagielski } 71*b1cdbd2cSJim Jagielski else 72*b1cdbd2cSJim Jagielski { 73*b1cdbd2cSJim Jagielski $installer::logger::Global->print("\n"); 74*b1cdbd2cSJim Jagielski $installer::logger::Global->print("***************************************************************\n"); 75*b1cdbd2cSJim Jagielski $installer::logger::Global->print($message."\n"); 76*b1cdbd2cSJim Jagielski $installer::logger::Global->printf("in function: %s\n", $function); 77*b1cdbd2cSJim Jagielski $installer::logger::Global->printf("***************************************************************\n"); 78*b1cdbd2cSJim Jagielski 79*b1cdbd2cSJim Jagielski# installer::files::save_file($installer::globals::logfilename ,\@installer::globals::globallogfileinfo); 80*b1cdbd2cSJim Jagielski } 81*b1cdbd2cSJim Jagielski installer::logger::print_error("$message\nin function: $function"); 82*b1cdbd2cSJim Jagielski# installer::logger::print_error("Saved logfile: $installer::globals::logfilename\n"); 83*b1cdbd2cSJim Jagielski 84*b1cdbd2cSJim Jagielski # Saving the debug info 85*b1cdbd2cSJim Jagielski 86*b1cdbd2cSJim Jagielski if ( $installer::globals::debug ) { installer::logger::savedebug($installer::globals::exitlog); } 87*b1cdbd2cSJim Jagielski 88*b1cdbd2cSJim Jagielski installer::logger::stoptime(); 89*b1cdbd2cSJim Jagielski 90*b1cdbd2cSJim Jagielski if (defined($installer::globals::exithandler)) { 91*b1cdbd2cSJim Jagielski &$installer::globals::exithandler; 92*b1cdbd2cSJim Jagielski } 93*b1cdbd2cSJim Jagielski 94*b1cdbd2cSJim Jagielski exit(-1); 95*b1cdbd2cSJim Jagielski} 96*b1cdbd2cSJim Jagielski 97*b1cdbd2cSJim Jagielski1; 98