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