xref: /freebsd/contrib/libarchive/libarchive_fe/err.c (revision b9128a37faafede823eb456aa65a11ac69997284)
1caf54c4fSMartin Matuska /*-
2caf54c4fSMartin Matuska  * Copyright (c) 2003-2007 Tim Kientzle
3caf54c4fSMartin Matuska  * All rights reserved.
4caf54c4fSMartin Matuska  *
5caf54c4fSMartin Matuska  * Redistribution and use in source and binary forms, with or without
6caf54c4fSMartin Matuska  * modification, are permitted provided that the following conditions
7caf54c4fSMartin Matuska  * are met:
8caf54c4fSMartin Matuska  * 1. Redistributions of source code must retain the above copyright
9caf54c4fSMartin Matuska  *    notice, this list of conditions and the following disclaimer
10caf54c4fSMartin Matuska  *    in this position and unchanged.
11caf54c4fSMartin Matuska  * 2. Redistributions in binary form must reproduce the above copyright
12caf54c4fSMartin Matuska  *    notice, this list of conditions and the following disclaimer in the
13caf54c4fSMartin Matuska  *    documentation and/or other materials provided with the distribution.
14caf54c4fSMartin Matuska  *
15caf54c4fSMartin Matuska  * THIS SOFTWARE IS PROVIDED BY THE AUTHOR(S) ``AS IS'' AND ANY EXPRESS OR
16caf54c4fSMartin Matuska  * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
17caf54c4fSMartin Matuska  * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
18caf54c4fSMartin Matuska  * IN NO EVENT SHALL THE AUTHOR(S) BE LIABLE FOR ANY DIRECT, INDIRECT,
19caf54c4fSMartin Matuska  * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
20caf54c4fSMartin Matuska  * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
21caf54c4fSMartin Matuska  * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
22caf54c4fSMartin Matuska  * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
23caf54c4fSMartin Matuska  * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
24caf54c4fSMartin Matuska  * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
25caf54c4fSMartin Matuska  */
26caf54c4fSMartin Matuska 
27caf54c4fSMartin Matuska #include "lafe_platform.h"
28caf54c4fSMartin Matuska #ifdef HAVE_STDARG_H
29caf54c4fSMartin Matuska #include <stdarg.h>
30caf54c4fSMartin Matuska #endif
31caf54c4fSMartin Matuska #include <stdio.h>
32caf54c4fSMartin Matuska #ifdef HAVE_STDLIB_H
33caf54c4fSMartin Matuska #include <stdlib.h>
34caf54c4fSMartin Matuska #endif
35caf54c4fSMartin Matuska #ifdef HAVE_STRING_H
36caf54c4fSMartin Matuska #include <string.h>
37caf54c4fSMartin Matuska #endif
38caf54c4fSMartin Matuska 
39caf54c4fSMartin Matuska #include "err.h"
40caf54c4fSMartin Matuska 
41fd082e96SMartin Matuska static void lafe_vwarnc(int, const char *, va_list) __LA_PRINTFLIKE(2, 0);
42fd082e96SMartin Matuska 
43*cdf63a70SMartin Matuska static const char *lafe_progname;
44*cdf63a70SMartin Matuska 
45*cdf63a70SMartin Matuska const char *
46*cdf63a70SMartin Matuska lafe_getprogname(void)
47*cdf63a70SMartin Matuska {
48*cdf63a70SMartin Matuska 
49*cdf63a70SMartin Matuska 	return lafe_progname;
50*cdf63a70SMartin Matuska }
51*cdf63a70SMartin Matuska 
52*cdf63a70SMartin Matuska void
53*cdf63a70SMartin Matuska lafe_setprogname(const char *name, const char *defaultname)
54*cdf63a70SMartin Matuska {
55*cdf63a70SMartin Matuska 
56*cdf63a70SMartin Matuska 	if (name == NULL)
57*cdf63a70SMartin Matuska 		name = defaultname;
58*cdf63a70SMartin Matuska #if defined(_WIN32) && !defined(__CYGWIN__)
59*cdf63a70SMartin Matuska 	lafe_progname = strrchr(name, '\\');
60*cdf63a70SMartin Matuska 	if (strrchr(name, '/') > lafe_progname)
61*cdf63a70SMartin Matuska #endif
62*cdf63a70SMartin Matuska 	lafe_progname = strrchr(name, '/');
63*cdf63a70SMartin Matuska 	if (lafe_progname != NULL)
64*cdf63a70SMartin Matuska 		lafe_progname++;
65*cdf63a70SMartin Matuska 	else
66*cdf63a70SMartin Matuska 		lafe_progname = name;
67*cdf63a70SMartin Matuska }
68caf54c4fSMartin Matuska 
69caf54c4fSMartin Matuska static void
70caf54c4fSMartin Matuska lafe_vwarnc(int code, const char *fmt, va_list ap)
71caf54c4fSMartin Matuska {
72caf54c4fSMartin Matuska 	fprintf(stderr, "%s: ", lafe_progname);
73caf54c4fSMartin Matuska 	vfprintf(stderr, fmt, ap);
74caf54c4fSMartin Matuska 	if (code != 0)
75caf54c4fSMartin Matuska 		fprintf(stderr, ": %s", strerror(code));
76caf54c4fSMartin Matuska 	fprintf(stderr, "\n");
77caf54c4fSMartin Matuska }
78caf54c4fSMartin Matuska 
79caf54c4fSMartin Matuska void
80caf54c4fSMartin Matuska lafe_warnc(int code, const char *fmt, ...)
81caf54c4fSMartin Matuska {
82caf54c4fSMartin Matuska 	va_list ap;
83caf54c4fSMartin Matuska 
84caf54c4fSMartin Matuska 	va_start(ap, fmt);
85caf54c4fSMartin Matuska 	lafe_vwarnc(code, fmt, ap);
86caf54c4fSMartin Matuska 	va_end(ap);
87caf54c4fSMartin Matuska }
88caf54c4fSMartin Matuska 
89caf54c4fSMartin Matuska void
90caf54c4fSMartin Matuska lafe_errc(int eval, int code, const char *fmt, ...)
91caf54c4fSMartin Matuska {
92caf54c4fSMartin Matuska 	va_list ap;
93caf54c4fSMartin Matuska 
94caf54c4fSMartin Matuska 	va_start(ap, fmt);
95caf54c4fSMartin Matuska 	lafe_vwarnc(code, fmt, ap);
96caf54c4fSMartin Matuska 	va_end(ap);
97caf54c4fSMartin Matuska 	exit(eval);
98caf54c4fSMartin Matuska }
99