cdrtools/libschily/fcomerr.c
2025-06-15 04:19:58 +08:00

206 lines
4.0 KiB
C

/* @(#)fcomerr.c 1.6 15/06/28 Copyright 1985-1989, 1995-2015 J. Schilling */
/*
* Routines for printing command errors on a specified FILE *
*
* Copyright (c) 1985-1989, 1995-2015 J. Schilling
*/
/*
* The contents of this file are subject to the terms of the
* Common Development and Distribution License, Version 1.0 only
* (the "License"). You may not use this file except in compliance
* with the License.
*
* See the file CDDL.Schily.txt in this distribution for details.
* A copy of the CDDL is also available via the Internet at
* http://www.opensource.org/licenses/cddl1.txt
*
* When distributing Covered Code, include this CDDL HEADER in each
* file and include the License file CDDL.Schily.txt from this distribution.
*/
#include <schily/mconfig.h>
#include <schily/unistd.h> /* include <sys/types.h> try to get size_t */
#include <schily/stdio.h> /* Try again for size_t */
#include <schily/stdlib.h> /* Try again for size_t */
#include <schily/standard.h>
#include <schily/varargs.h>
#include <schily/string.h>
#include <schily/schily.h>
#include <schily/errno.h>
EXPORT void fcomerr __PR((FILE *, const char *, ...));
EXPORT void fxcomerr __PR((FILE *, int, const char *, ...));
EXPORT void fcomerrno __PR((FILE *, int, const char *, ...));
EXPORT void fxcomerrno __PR((FILE *, int, int, const char *, ...));
EXPORT int ferrmsg __PR((FILE *, const char *, ...));
EXPORT int ferrmsgno __PR((FILE *, int, const char *, ...));
/*
* Fetch current errno, print a related message and exit(errno).
*/
/* VARARGS1 */
#ifdef PROTOTYPES
EXPORT void
fcomerr(FILE *f, const char *msg, ...)
#else
EXPORT void
fcomerr(f, msg, va_alist)
FILE *f;
char *msg;
va_dcl
#endif
{
va_list args;
#ifdef PROTOTYPES
va_start(args, msg);
#else
va_start(args);
#endif
(void) _comerr(f, COMERR_EXIT, 0, geterrno(), msg, args);
/* NOTREACHED */
va_end(args);
}
/*
* Fetch current errno, print a related message and exit(exc).
*/
/* VARARGS2 */
#ifdef PROTOTYPES
EXPORT void
fxcomerr(FILE *f, int exc, const char *msg, ...)
#else
EXPORT void
fxcomerr(f, exc, msg, va_alist)
int exc;
FILE *f;
char *msg;
va_dcl
#endif
{
va_list args;
#ifdef PROTOTYPES
va_start(args, msg);
#else
va_start(args);
#endif
(void) _comerr(f, COMERR_EXCODE, exc, geterrno(), msg, args);
/* NOTREACHED */
va_end(args);
}
/*
* Print a message related to err and exit(err).
*/
/* VARARGS2 */
#ifdef PROTOTYPES
EXPORT void
fcomerrno(FILE *f, int err, const char *msg, ...)
#else
EXPORT void
fcomerrno(f, err, msg, va_alist)
FILE *f;
int err;
char *msg;
va_dcl
#endif
{
va_list args;
#ifdef PROTOTYPES
va_start(args, msg);
#else
va_start(args);
#endif
(void) _comerr(f, COMERR_EXIT, 0, err, msg, args);
/* NOTREACHED */
va_end(args);
}
/*
* Print a message related to err and exit(exc).
*/
/* VARARGS3 */
#ifdef PROTOTYPES
EXPORT void
fxcomerrno(FILE *f, int exc, int err, const char *msg, ...)
#else
EXPORT void
fxcomerrno(f, exc, err, msg, va_alist)
FILE *f;
int exc;
int err;
char *msg;
va_dcl
#endif
{
va_list args;
#ifdef PROTOTYPES
va_start(args, msg);
#else
va_start(args);
#endif
(void) _comerr(f, COMERR_EXCODE, exc, err, msg, args);
/* NOTREACHED */
va_end(args);
}
/*
* Fetch current errno, print a related message and return(errno).
*/
/* VARARGS1 */
#ifdef PROTOTYPES
EXPORT int
ferrmsg(FILE *f, const char *msg, ...)
#else
EXPORT int
ferrmsg(f, msg, va_alist)
FILE *f;
char *msg;
va_dcl
#endif
{
va_list args;
int ret;
#ifdef PROTOTYPES
va_start(args, msg);
#else
va_start(args);
#endif
ret = _comerr(f, COMERR_RETURN, 0, geterrno(), msg, args);
va_end(args);
return (ret);
}
/*
* Print a message related to err and return(err).
*/
/* VARARGS2 */
#ifdef PROTOTYPES
EXPORT int
ferrmsgno(FILE *f, int err, const char *msg, ...)
#else
EXPORT int
ferrmsgno(f, err, msg, va_alist)
FILE *f;
int err;
char *msg;
va_dcl
#endif
{
va_list args;
int ret;
#ifdef PROTOTYPES
va_start(args, msg);
#else
va_start(args);
#endif
ret = _comerr(f, COMERR_RETURN, 0, err, msg, args);
va_end(args);
return (ret);
}