123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116 |
- /*
- +----------------------------------------------------------------------+
- | Zend OPcache |
- +----------------------------------------------------------------------+
- | Copyright (c) The PHP Group |
- +----------------------------------------------------------------------+
- | This source file is subject to version 3.01 of the PHP license, |
- | that is bundled with this package in the file LICENSE, and is |
- | available through the world-wide-web at the following url: |
- | https://www.php.net/license/3_01.txt |
- | If you did not receive a copy of the PHP license and are unable to |
- | obtain it through the world-wide-web, please send a note to |
- | license@php.net so we can mail you a copy immediately. |
- +----------------------------------------------------------------------+
- | Authors: Andi Gutmans <andi@php.net> |
- | Zeev Suraski <zeev@php.net> |
- | Stanislav Malyshev <stas@zend.com> |
- | Dmitry Stogov <dmitry@php.net> |
- +----------------------------------------------------------------------+
- */
- #include <stdio.h>
- #include <stdlib.h>
- #include <stdarg.h>
- #include <time.h>
- #ifdef ZEND_WIN32
- # include <process.h>
- #endif
- #include "ZendAccelerator.h"
- static void zend_accel_error_va_args(int type, const char *format, va_list args)
- {
- time_t timestamp;
- char *time_string;
- FILE * fLog = NULL;
- if (type <= ZCG(accel_directives).log_verbosity_level) {
- timestamp = time(NULL);
- time_string = asctime(localtime(×tamp));
- time_string[24] = 0;
- if (!ZCG(accel_directives).error_log ||
- !*ZCG(accel_directives).error_log ||
- strcmp(ZCG(accel_directives).error_log, "stderr") == 0) {
- fLog = stderr;
- } else {
- fLog = fopen(ZCG(accel_directives).error_log, "a");
- if (!fLog) {
- fLog = stderr;
- }
- }
- #ifdef ZTS
- fprintf(fLog, "%s (" ZEND_ULONG_FMT "): ", time_string, (zend_ulong)tsrm_thread_id());
- #else
- fprintf(fLog, "%s (%d): ", time_string, getpid());
- #endif
- switch (type) {
- case ACCEL_LOG_FATAL:
- fprintf(fLog, "Fatal Error ");
- break;
- case ACCEL_LOG_ERROR:
- fprintf(fLog, "Error ");
- break;
- case ACCEL_LOG_WARNING:
- fprintf(fLog, "Warning ");
- break;
- case ACCEL_LOG_INFO:
- fprintf(fLog, "Message ");
- break;
- case ACCEL_LOG_DEBUG:
- fprintf(fLog, "Debug ");
- break;
- }
- vfprintf(fLog, format, args);
- fprintf(fLog, "\n");
- fflush(fLog);
- if (fLog != stderr) {
- fclose(fLog);
- }
- }
- /* perform error handling even without logging the error */
- switch (type) {
- case ACCEL_LOG_ERROR:
- zend_bailout();
- break;
- case ACCEL_LOG_FATAL:
- exit(-2);
- break;
- }
- }
- void zend_accel_error(int type, const char *format, ...)
- {
- va_list args;
- va_start(args, format);
- zend_accel_error_va_args(type, format, args);
- va_end(args);
- }
- ZEND_NORETURN void zend_accel_error_noreturn(int type, const char *format, ...)
- {
- va_list args;
- va_start(args, format);
- ZEND_ASSERT(type == ACCEL_LOG_FATAL || type == ACCEL_LOG_ERROR);
- zend_accel_error_va_args(type, format, args);
- va_end(args);
- /* Should never reach this. */
- abort();
- }
|