mirror of
https://github.com/php/php-src.git
synced 2025-08-16 05:58:45 +02:00
PHP 4.0
This commit is contained in:
parent
d94f3e22ae
commit
aceaabceff
189 changed files with 43488 additions and 0 deletions
128
win32/wsyslog.c
Normal file
128
win32/wsyslog.c
Normal file
|
@ -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 */
|
||||
}
|
Loading…
Add table
Add a link
Reference in a new issue