2006-11-25 13:07:29 -07:00
|
|
|
/*\
|
2015-05-10 04:16:20 -06:00
|
|
|
* COPYRIGHT 1990
|
|
|
|
* DIGITAL EQUIPMENT CORPORATION
|
|
|
|
* MAYNARD, MASSACHUSETTS
|
|
|
|
* ALL RIGHTS RESERVED.
|
2006-11-25 13:07:29 -07:00
|
|
|
*
|
|
|
|
* THE INFORMATION IN THIS SOFTWARE IS SUBJECT TO CHANGE WITHOUT NOTICE AND
|
|
|
|
* SHOULD NOT BE CONSTRUED AS A COMMITMENT BY DIGITAL EQUIPMENT CORPORATION.
|
2015-05-10 04:16:20 -06:00
|
|
|
* DIGITAL MAKES NO REPRESENTATIONS ABOUT THE SUITABILITY OF THIS SOFTWARE
|
|
|
|
* FOR ANY PURPOSE. IT IS SUPPLIED "AS IS" WITHOUT EXPRESS OR IMPLIED
|
2006-11-25 13:07:29 -07:00
|
|
|
* WARRANTY.
|
|
|
|
*
|
|
|
|
* IF THE SOFTWARE IS MODIFIED IN A MANNER CREATING DERIVATIVE COPYRIGHT
|
|
|
|
* RIGHTS, APPROPRIATE LEGENDS MAY BE PLACED ON THE DERIVATIVE WORK IN
|
|
|
|
* ADDITION TO THAT SET FORTH ABOVE.
|
|
|
|
*
|
|
|
|
* Permission to use, copy, modify, and distribute this software and its
|
|
|
|
* documentation for any purpose and without fee is hereby granted, provided
|
|
|
|
* that the above copyright notice appear in all copies and that both that
|
|
|
|
* copyright notice and this permission notice appear in supporting
|
|
|
|
* documentation, and that the name of Digital Equipment Corporation not be
|
2015-05-10 04:16:20 -06:00
|
|
|
* used in advertising or publicity pertaining to distribution of the
|
2006-11-25 13:07:29 -07:00
|
|
|
* software without specific, written prior permission.
|
|
|
|
\*/
|
2015-05-10 04:16:20 -06:00
|
|
|
|
|
|
|
#ifdef HAVE_CONFIG_H
|
|
|
|
#include "config.h"
|
|
|
|
#endif
|
2006-11-25 13:07:29 -07:00
|
|
|
|
|
|
|
#include "utils.h"
|
|
|
|
#include <ctype.h>
|
|
|
|
#include <stdlib.h>
|
|
|
|
|
2010-03-28 07:05:38 -06:00
|
|
|
unsigned int debugFlags;
|
|
|
|
|
|
|
|
|
2006-11-25 13:07:29 -07:00
|
|
|
/***====================================================================***/
|
|
|
|
|
2015-05-10 04:16:20 -06:00
|
|
|
static FILE *errorFile = NULL;
|
2006-11-25 13:07:29 -07:00
|
|
|
|
|
|
|
Boolean
|
2015-05-10 04:16:20 -06:00
|
|
|
uSetErrorFile(const char *name)
|
2006-11-25 13:07:29 -07:00
|
|
|
{
|
2015-05-10 04:16:20 -06:00
|
|
|
if ((errorFile != NULL) && (errorFile != stderr)) {
|
|
|
|
fprintf(errorFile, "switching to %s\n", name ? name : "stderr");
|
|
|
|
fclose(errorFile);
|
2006-11-25 13:07:29 -07:00
|
|
|
}
|
2015-05-10 04:16:20 -06:00
|
|
|
if (name != NullString)
|
|
|
|
errorFile = fopen(name, "w");
|
|
|
|
else
|
|
|
|
errorFile = stderr;
|
|
|
|
if (errorFile == NULL) {
|
|
|
|
errorFile = stderr;
|
|
|
|
return (False);
|
2006-11-25 13:07:29 -07:00
|
|
|
}
|
2015-05-10 04:16:20 -06:00
|
|
|
return (True);
|
2006-11-25 13:07:29 -07:00
|
|
|
}
|
|
|
|
|
|
|
|
void
|
2015-05-10 04:16:20 -06:00
|
|
|
uInformation(const char *s, ...)
|
2006-11-25 13:07:29 -07:00
|
|
|
{
|
|
|
|
va_list ap;
|
|
|
|
|
|
|
|
va_start(ap, s);
|
2015-05-10 04:16:20 -06:00
|
|
|
vfprintf(errorFile, s, ap);
|
2006-11-25 13:07:29 -07:00
|
|
|
fflush(errorFile);
|
|
|
|
va_end(ap);
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
/***====================================================================***/
|
|
|
|
|
|
|
|
void
|
2015-05-10 04:16:20 -06:00
|
|
|
uAction(const char *s, ...)
|
2006-11-25 13:07:29 -07:00
|
|
|
{
|
|
|
|
va_list ap;
|
|
|
|
|
|
|
|
va_start(ap, s);
|
2015-05-10 04:16:20 -06:00
|
|
|
fprintf(errorFile, " ");
|
|
|
|
vfprintf(errorFile, s, ap);
|
2006-11-25 13:07:29 -07:00
|
|
|
fflush(errorFile);
|
|
|
|
va_end(ap);
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
/***====================================================================***/
|
|
|
|
|
|
|
|
void
|
2015-05-10 04:16:20 -06:00
|
|
|
uWarning(const char *s, ...)
|
2006-11-25 13:07:29 -07:00
|
|
|
{
|
|
|
|
va_list ap;
|
|
|
|
|
|
|
|
va_start(ap, s);
|
2015-05-10 04:16:20 -06:00
|
|
|
fprintf(errorFile, "Warning: ");
|
|
|
|
vfprintf(errorFile, s, ap);
|
2006-11-25 13:07:29 -07:00
|
|
|
fflush(errorFile);
|
|
|
|
va_end(ap);
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
/***====================================================================***/
|
|
|
|
|
|
|
|
void
|
2015-05-10 04:16:20 -06:00
|
|
|
uError(const char *s, ...)
|
2006-11-25 13:07:29 -07:00
|
|
|
{
|
|
|
|
va_list ap;
|
|
|
|
|
|
|
|
va_start(ap, s);
|
2015-05-10 04:16:20 -06:00
|
|
|
fprintf(errorFile, "Error: ");
|
|
|
|
vfprintf(errorFile, s, ap);
|
2006-11-25 13:07:29 -07:00
|
|
|
fflush(errorFile);
|
|
|
|
va_end(ap);
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
/***====================================================================***/
|
|
|
|
|
|
|
|
void
|
2015-05-10 04:16:20 -06:00
|
|
|
uFatalError(const char *s, ...)
|
2006-11-25 13:07:29 -07:00
|
|
|
{
|
|
|
|
va_list ap;
|
|
|
|
|
|
|
|
va_start(ap, s);
|
2015-05-10 04:16:20 -06:00
|
|
|
fprintf(errorFile, "Fatal Error: ");
|
|
|
|
vfprintf(errorFile, s, ap);
|
|
|
|
fprintf(errorFile, " Exiting\n");
|
2006-11-25 13:07:29 -07:00
|
|
|
fflush(errorFile);
|
|
|
|
va_end(ap);
|
|
|
|
exit(1);
|
|
|
|
/* NOTREACHED */
|
|
|
|
}
|
|
|
|
|
|
|
|
/***====================================================================***/
|
|
|
|
|
|
|
|
void
|
2015-05-10 04:16:20 -06:00
|
|
|
uInternalError(const char *s, ...)
|
2006-11-25 13:07:29 -07:00
|
|
|
{
|
|
|
|
va_list ap;
|
|
|
|
|
|
|
|
va_start(ap, s);
|
2015-05-10 04:16:20 -06:00
|
|
|
fprintf(errorFile, "Internal error: ");
|
|
|
|
vfprintf(errorFile, s, ap);
|
2006-11-25 13:07:29 -07:00
|
|
|
fflush(errorFile);
|
|
|
|
va_end(ap);
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
/***====================================================================***/
|
|
|
|
|
2015-05-10 04:16:20 -06:00
|
|
|
#ifndef HAVE_ASPRINTF
|
|
|
|
int
|
|
|
|
uAsprintf(char ** ret, const char *format, ...)
|
2006-11-25 13:07:29 -07:00
|
|
|
{
|
2015-05-10 04:16:20 -06:00
|
|
|
char buf[256];
|
|
|
|
int len;
|
|
|
|
va_list ap;
|
2006-11-25 13:07:29 -07:00
|
|
|
|
2015-05-10 04:16:20 -06:00
|
|
|
va_start(ap, format);
|
|
|
|
len = vsnprintf(buf, sizeof(buf), format, ap);
|
|
|
|
va_end(ap);
|
2006-11-25 13:07:29 -07:00
|
|
|
|
2015-05-10 04:16:20 -06:00
|
|
|
if (len < 0)
|
|
|
|
return -1;
|
2006-11-25 13:07:29 -07:00
|
|
|
|
2015-05-10 04:16:20 -06:00
|
|
|
if (len < sizeof(buf))
|
|
|
|
{
|
|
|
|
*ret = strdup(buf);
|
2006-11-25 13:07:29 -07:00
|
|
|
}
|
2015-05-10 04:16:20 -06:00
|
|
|
else
|
|
|
|
{
|
|
|
|
*ret = malloc(len + 1); /* snprintf doesn't count trailing '\0' */
|
|
|
|
if (*ret != NULL)
|
|
|
|
{
|
|
|
|
va_start(ap, format);
|
|
|
|
len = vsnprintf(*ret, len + 1, format, ap);
|
|
|
|
va_end(ap);
|
|
|
|
if (len < 0) {
|
|
|
|
free(*ret);
|
|
|
|
*ret = NULL;
|
|
|
|
}
|
|
|
|
}
|
2006-11-25 13:07:29 -07:00
|
|
|
}
|
|
|
|
|
2015-05-10 04:16:20 -06:00
|
|
|
if (*ret == NULL)
|
|
|
|
return -1;
|
2006-11-25 13:07:29 -07:00
|
|
|
|
2015-05-10 04:16:20 -06:00
|
|
|
return len;
|
|
|
|
}
|
|
|
|
#endif /* HAVE_ASPRINTF */
|