openalbridge/errlib.c
author smxx
Thu, 04 Feb 2010 14:48:49 +0000
changeset 2745 11fce231f24a
parent 2529 51e5df1c8462
permissions -rw-r--r--
Engine: + Split PlaySound into PlaySound and LoopSound + Added overloaded versions of PlaySound/LoopSound that won't require voicepack parameter + LoopSound now allows multiple copies of the same sound to play looped and returns the channel used for playback (to stop them later) + StopSound now allows either a specific sound (single playback) or channel (single playback as well as looped playback) to be stopped + SoundChannel attribute for Gears to be used when looping sounds

/*
 
 module: errlib.c
 
 purpose: library of error functions
 
 reference: Stevens, Unix network programming (2ed), p.922
 
 */

#include "errlib.h"


#define MAXLINE 4095

#ifdef __CPLUSPLUS
extern "C" {
#endif 
        
        int daemon_proc = 0; /* set to 0 if stdout/stderr available, else set to 1 */
        
        static void err_doit (int errnoflag, int level, const char *fmt, va_list ap)
        {
                int errno_save = errno, n;
                char buf[MAXLINE+1];
                
                vsnprintf (buf, MAXLINE, fmt, ap);
                n = strlen(buf);
                if (errnoflag)
                        snprintf (buf+n, MAXLINE-n, ": %s", strerror(errno_save));
                strcat (buf, "\n");
                
                if (daemon_proc)
                        syslog (level, buf);
                else {
                        fflush (stdout);
                        fprintf (stderr, buf);
                        fflush (stderr);
                }
                
                return;
        }
        
        void err_ret (const char *fmt, ...)
        {
                va_list ap;
                
                va_start (ap, fmt);
                err_doit (1, LOG_INFO, fmt, ap);
                va_end (ap);
                return;
        }
        
        void err_sys (const char *fmt, ...)
        {
                va_list ap;
                
                va_start (ap, fmt);
                err_doit (1, LOG_ERR, fmt, ap);
                va_end (ap);
                exit (1);
        }
        
        void err_msg (const char *fmt, ...)
        {
                va_list ap;
                
                va_start (ap, fmt);
                err_doit (0, LOG_INFO, fmt, ap);
                va_end (ap);
                return;
        }
        
        void err_quit (const char *fmt, ...)
        {
                va_list ap;
                
                va_start (ap, fmt);
                err_doit (0, LOG_ERR, fmt, ap);
                va_end (ap);
                exit (1);
        }
        
        void err_dump (const char *fmt, ...)
        {
                va_list ap;
                
                va_start (ap, fmt);
                err_doit (1, LOG_ERR, fmt, ap);
                va_end (ap);
                abort();
        }
        
#ifdef __CPLUSPLUS
}
#endif