diff options
Diffstat (limited to 'win32/wsyslog.c')
-rw-r--r-- | win32/wsyslog.c | 128 |
1 files changed, 128 insertions, 0 deletions
diff --git a/win32/wsyslog.c b/win32/wsyslog.c new file mode 100644 index 0000000000..4207370dbf --- /dev/null +++ b/win32/wsyslog.c @@ -0,0 +1,128 @@ +/* + * This file modified from sources for imap4 for use + * in PHP 3 + */ +/* + * Program: Unix compatibility routines + * + * Author: Mark Crispin + * Networks and Distributed Computing + * Computing & Communications + * University of Washington + * Administration Building, AG-44 + * Seattle, WA 98195 + * Internet: MRC@CAC.Washington.EDU + * + * Date: 14 September 1996 + * Last Edited: 22 October 1996 + * + * Copyright 1996 by the University of Washington + * + * 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 appears in all copies and that both the + * above copyright notice and this permission notice appear in supporting + * documentation, and that the name of the University of Washington not be + * used in advertising or publicity pertaining to distribution of the software + * without specific, written prior permission. This software is made available + * "as is", and + * THE UNIVERSITY OF WASHINGTON DISCLAIMS ALL WARRANTIES, EXPRESS OR IMPLIED, + * WITH REGARD TO THIS SOFTWARE, INCLUDING WITHOUT LIMITATION ALL IMPLIED + * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE, AND IN + * NO EVENT SHALL THE UNIVERSITY OF WASHINGTON BE LIABLE FOR ANY SPECIAL, + * INDIRECT OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM + * LOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, TORT + * (INCLUDING NEGLIGENCE) OR STRICT LIABILITY, ARISING OUT OF OR IN CONNECTION + * WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. + * + */ + + +/* DEDICATION + + * This file is dedicated to my dog, Unix, also known as Yun-chan and + * Unix J. Terwilliker Jehosophat Aloysius Monstrosity Animal Beast. Unix + * passed away at the age of 11 1/2 on September 14, 1996, 12:18 PM PDT, after + * a two-month bout with cirrhosis of the liver. + * + * He was a dear friend, and I miss him terribly. + * + * Lift a leg, Yunie. Luv ya forever!!!! + */ + +#ifdef THREAD_SAFE +#include "tls.h" +#endif +#include "php.h" /*php specific */ +#include "syslog.h" +#include <stdio.h> +#include <fcntl.h> +#include <process.h> + +#ifndef THREAD_SAFE +static char *loghdr; /* log file header string */ +static HANDLE loghdl = NULL; /* handle of event source */ +#endif + +void closelog(void) +{ + TLS_VARS; + DeregisterEventSource(GLOBAL(loghdl)); + efree(GLOBAL(loghdr)); +} + +/* Emulator for BSD syslog() routine + * Accepts: priority + * message + * parameters + */ + +void syslog(int priority, const char *message,...) +{ + va_list args; + LPTSTR strs[2]; + char tmp[1024]; /* callers must be careful not to pop this */ + unsigned short etype; + TLS_VARS; + + /* default event source */ + if (!GLOBAL(loghdl)) + openlog("c-client", LOG_PID, LOG_MAIL); + switch (priority) { /* translate UNIX type into NT type */ + case LOG_ALERT: + etype = EVENTLOG_ERROR_TYPE; + break; + case LOG_INFO: + etype = EVENTLOG_INFORMATION_TYPE; + break; + default: + etype = EVENTLOG_WARNING_TYPE; + } + va_start(args, message); /* initialize vararg mechanism */ + vsprintf(tmp, message, args); /* build message */ + strs[0] = GLOBAL(loghdr); /* write header */ + strs[1] = tmp; /* then the message */ + /* report the event */ + ReportEvent(GLOBAL(loghdl), etype, (unsigned short) priority, 2000, NULL, 2, 0, strs, NULL); + va_end(args); +} + + +/* Emulator for BSD openlog() routine + * Accepts: identity + * options + * facility + */ + +void openlog(const char *ident, int logopt, int facility) +{ + char tmp[1024]; + TLS_VARS; + + if (GLOBAL(loghdl)) { + closelog(); + } + GLOBAL(loghdl) = RegisterEventSource(NULL, ident); + sprintf(tmp, (logopt & LOG_PID) ? "%s[%d]" : "%s", ident, getpid()); + GLOBAL(loghdr) = estrdup(tmp); /* save header for later */ +} |