Remove whitespace, update email addresses and URLs.
[kodak.git] / trace.cpp
1 //+----------------------------------------------------------------------------
2 //
3 // File:     trace.cpp
4 //
5 // Module:   Digital Camera Program
6 //
7 // Synopsis: Tracing routine.
8 //
9 // Copyright (c) 1999 Scott Gasch 
10 // All rights reserved.
11 //
12 // Redistribution and use in source and binary forms, with or without
13 // modification, are permitted provided that the following conditions
14 // are met:
15 // 1. Redistributions of source code must retain the above copyright
16 //    notice, this list of conditions and the following disclaimer.
17 // 2. Redistributions in binary form must reproduce the above copyright
18 //    notice, this list of conditions and the following disclaimer in the
19 //    documentation and/or other materials provided with the distribution.
20 //
21 // THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND
22 // ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
23 // IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
24 // ARE DISCLAIMED.  IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE
25 // FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
26 // DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
27 // OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
28 // HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
29 // LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
30 // OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
31 // SUCH DAMAGE.
32 //
33 //  $Id: trace.cpp,v 1.2 1999/06/23 05:28:04 scott Exp scott $
34 //
35 // Author:       sgasch
36 //
37 // Created    4 Jun 1999
38 //
39 //+----------------------------------------------------------------------------
40
41 #include <stdlib.h>
42 #include <stdio.h>
43 #include <syslog.h>
44 #include <stdarg.h>
45
46 #include "trace.h"
47
48 //+----------------------------------------------------------------------------
49 //
50 // Function:  Trace
51 //
52 // Synopsis:  This function either logs a message to either stderr (if this
53 //            is a checked build) or to the system log.  It takes a variable
54 //            number of arguments.  Like printf, the first argument is a
55 //            format string.  Any subsequent parameters are replacements
56 //            interpolated into the format string in place of variables.
57 //
58 // Arguments: char *szMessage - the format string (or whole message w/o subs)
59 //            ... - subsequent arguments are interpolated into message.
60 //
61 // Returns:   void
62 //
63 // History:   sgasch Created Header    22 Jun 1999
64 //
65 //+----------------------------------------------------------------------------
66
67 void Trace(char *szMessage, ... )
68 {
69         va_list ap;                            // Variable argument list
70
71         va_start(ap, szMessage);
72 #ifdef DEBUG
73         vfprintf(stderr, szMessage, ap);
74 #else
75         char buf[1024];
76         (void) vsnprintf(buf, 1024, szMessage, ap);
77         syslog(LOG_INFO, buf);
78 #endif
79         va_end(ap);
80
81 }
82
83
84