📄 kwqassertions.cpp
字号:
/* * Copyright (C) 2003 Apple Computer, Inc. All rights reserved. * * Redistribution and use in source and binary forms, with or without * modification, are permitted provided that the following conditions * are met: * 1. Redistributions of source code must retain the above copyright * notice, this list of conditions and the following disclaimer. * 2. Redistributions in binary form must reproduce the above copyright * notice, this list of conditions and the following disclaimer in the * documentation and/or other materials provided with the distribution. * * THIS SOFTWARE IS PROVIDED BY APPLE COMPUTER, INC. ``AS IS'' AND ANY * EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL APPLE COMPUTER, INC. OR * CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR * PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY * OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. */#include "KWQAssertions.h"#ifndef NDEBUG#include <stdio.h>#include <stdlib.h>#include <stdarg.h>#include <string.h>#if 0 // remove warnings --psalmistatic int (* vfprintf_no_warning)(FILE *, const char *, va_list) = vfprintf;#endifvoid KWQReportAssertionFailure(const char *file, int line, const char *function, const char *assertion){ if (assertion) { fprintf(stderr, "=================\nASSERTION FAILED: %s (%s:%d %s)\n=================\n", assertion, file, line, function); } else { fprintf(stderr, "=================\nSHOULD NEVER BE REACHED (%s:%d %s)\n=================\n", file, line, function); }}void KWQReportAssertionFailureWithMessage(const char *file, int line, const char *function, const char *assertion, const char *format, ...){ fprintf(stderr, "=================\nASSERTION FAILED: "); va_list args; va_start(args, format); vfprintf(stderr,format, args); va_end(args); fprintf(stderr, "\n%s (%s:%d %s)\n=================\n", assertion, file, line, function);}void KWQReportArgumentAssertionFailure(const char *file, int line, const char *function, const char *argName, const char *assertion){ fprintf(stderr, "=================\nARGUMENT BAD: %s, %s (%s:%d %s)\n=================\n", argName, assertion, file, line, function);}void KWQReportFatalError(const char *file, int line, const char *function, const char *format, ...){ fprintf(stderr, "=================\nFATAL ERROR: "); va_list args; va_start(args, format); vfprintf(stderr,format, args); va_end(args); fprintf(stderr, "\n(%s:%d %s)\n=================\n", file, line, function);}void KWQReportError(const char *file, int line, const char *function, const char *format, ...){ fprintf(stderr, "=================\nERROR: "); va_list args; va_start(args, format); vfprintf(stderr,format, args); va_end(args); fprintf(stderr, "\n(%s:%d %s)\n=================\n", file, line, function);}void KWQLog(const char *file, int line, const char *function, KWQLogChannel *channel, const char *format, ...){// if (channel->state == KWQLogChannelUninitialized) {// channel->state = KWQLogChannelOff;// NSString *logLevelString = [[NSUserDefaults standardUserDefaults] objectForKey:[NSString stringWithCString:channel->defaultName]];// if (logLevelString) {// unsigned logLevel;// if (![[NSScanner scannerWithString:logLevelString] scanHexInt:&logLevel]) {// NSLog(@"unable to parse hex value for %s (%@), logging is off", channel->defaultName, logLevelString);// }// if ((logLevel & channel->mask) == channel->mask) {// channel->state = KWQLogChannelOn;// }// }// } // if (channel->state != KWQLogChannelOn) {// return;// } fprintf(stderr, "- %s:%d %s - ", file, line, function); va_list args; va_start(args, format); vfprintf(stderr,format, args); va_end(args); if (format[strlen(format) - 1] != '\n') putc('\n', stderr);}#endif
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -