xref: /trunk/main/solenv/bin/modules/packager/exiter.pm (revision 9780544f)
1#**************************************************************
2#
3#  Licensed to the Apache Software Foundation (ASF) under one
4#  or more contributor license agreements.  See the NOTICE file
5#  distributed with this work for additional information
6#  regarding copyright ownership.  The ASF licenses this file
7#  to you under the Apache License, Version 2.0 (the
8#  "License"); you may not use this file except in compliance
9#  with the License.  You may obtain a copy of the License at
10#
11#    http://www.apache.org/licenses/LICENSE-2.0
12#
13#  Unless required by applicable law or agreed to in writing,
14#  software distributed under the License is distributed on an
15#  "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
16#  KIND, either express or implied.  See the License for the
17#  specific language governing permissions and limitations
18#  under the License.
19#
20#**************************************************************
21
22
23
24
25package packager::exiter;
26
27use packager::files;
28use packager::globals;
29
30############################################
31# Exiting the program with an error
32# This function is used instead of "die"
33############################################
34
35sub exit_program
36{
37	my ($message, $function) = @_;
38
39	my $infoline;
40
41	$infoline = "\n***************************************************************\n";
42	push(@packager::globals::logfileinfo, $infoline);
43	print("$infoline");
44
45	$infoline = "$message\n";
46	push(@packager::globals::logfileinfo, $infoline);
47	print("$infoline");
48
49	$infoline = "in function: $function\n";
50	push(@packager::globals::logfileinfo, $infoline);
51	print("$infoline");
52
53	$infoline = "***************************************************************\n";
54	push(@packager::globals::logfileinfo, $infoline);
55
56    if ( $packager::globals::logging )
57    {
58        packager::files::save_file($packager::globals::logfilename ,\@packager::globals::logfileinfo);
59        print("Saved logfile: $packager::globals::logfilename\n");
60    }
61
62	print("$infoline");
63
64	exit(-1);
65}
66
671;
68