2007-03-27 17:47:10 +00:00
|
|
|
/*
|
|
|
|
* CiderPress
|
|
|
|
* Copyright (C) 2007 by faddenSoft, LLC. All Rights Reserved.
|
|
|
|
* See the file LICENSE for distribution terms.
|
|
|
|
*/
|
|
|
|
/*
|
|
|
|
* My debug stuff.
|
|
|
|
*/
|
Large set of changes to restore CiderPress build.
CiderPress and MDC now compile, and execute far enough to open
their respective "about" boxes, but I doubt they'll do much
more than that.
* Switch from MBCS to UNICODE APIs
Microsoft switched to UTF-16 (by way of UCS-2) a long time ago,
and the support for MBCS seems to be getting phased out. So it's
time to switch to wide strings.
This is a bit awkward for CiderPress because it works with disk
and file archives with 8-bit filenames, and I want NufxLib and
DiskImgLib to continue to work on Linux (which has largely taken
the UTF-8 approach to Unicode). The libraries will continue to
work with 8-bit filenames, with CiderPress/MDC doing the
conversion at the appropriate point.
There were a couple of places where strings from a structure
handed back by one of the libraries were used directly in the UI,
or vice-versa, which is a problem because we have nowhere to
store the result of the conversion. These currently have fixed
place-holder "xyzzy" strings.
All UI strings are now wide.
Various format strings now use "%ls" and "%hs" to explicitly
specify wide and narrow. This doesn't play well with gcc, so
only the Windows-specific parts use those.
* Various updates to vcxproj files
The project-file conversion had some cruft that is now largely
gone. The build now has a common output directory for the EXEs
and libraries, avoiding the old post-build copy steps.
* Added zlib 1.2.8 and nufxlib 2.2.2 source snapshots
The old "prebuilts" directory is now gone. The libraries are now
built as part of building the apps.
I added a minimal set of files for zlib, and a full set for nufxlib.
The Linux-specific nufxlib goodies are included for the benefit of
the Linux utilities, which are currently broken (don't build).
* Replace symbols used for include guards
Symbols with a leading "__" are reserved.
2014-11-10 23:32:55 +00:00
|
|
|
#ifndef UTIL_MYDEBUG_H
|
|
|
|
#define UTIL_MYDEBUG_H
|
2007-03-27 17:47:10 +00:00
|
|
|
|
2014-11-18 01:54:34 +00:00
|
|
|
#include "PathName.h"
|
|
|
|
#include "FaddenStd.h"
|
2014-11-19 22:54:24 +00:00
|
|
|
#include <sal.h>
|
2007-03-27 17:47:10 +00:00
|
|
|
|
2014-11-18 01:54:34 +00:00
|
|
|
/*
|
|
|
|
* Debug log output.
|
|
|
|
*
|
|
|
|
* Generally an application will only want one instance of this, which will be
|
|
|
|
* accessed through a global variable by log macros.
|
|
|
|
*/
|
|
|
|
class DebugLog {
|
|
|
|
public:
|
|
|
|
/*
|
|
|
|
* Pass in the log file name, or NULL if logging to a file is not
|
|
|
|
* desired. If the log file cannot be opened, no error is reported,
|
|
|
|
* but the Log call will do nothing.
|
|
|
|
*/
|
|
|
|
DebugLog(const WCHAR* logFile);
|
|
|
|
|
|
|
|
~DebugLog();
|
|
|
|
|
|
|
|
typedef enum {
|
|
|
|
LOG_UNKNOWN=0, LOG_VERBOSE=1, LOG_DEBUG=2,
|
2014-11-19 01:10:23 +00:00
|
|
|
LOG_INFO=3, LOG_WARN=4, LOG_ERROR=5
|
2014-11-18 01:54:34 +00:00
|
|
|
} LogSeverity;
|
|
|
|
|
|
|
|
/*
|
|
|
|
* Write a message to the log file.
|
|
|
|
*
|
2014-11-18 21:05:15 +00:00
|
|
|
* The format string should not end with a newline. Each log message
|
|
|
|
* will appear on its own line, possibly with a prefix.
|
2014-11-18 01:54:34 +00:00
|
|
|
*/
|
|
|
|
void Log(LogSeverity severity, const char* file, int line,
|
2014-11-19 22:54:24 +00:00
|
|
|
_Printf_format_string_ const char* format, ...);
|
2014-11-18 01:54:34 +00:00
|
|
|
|
|
|
|
private:
|
|
|
|
DECLARE_COPY_AND_OPEQ(DebugLog)
|
|
|
|
|
|
|
|
const int kStaleLog = 8 * 60 * 60; // 8 hours
|
2007-03-27 17:47:10 +00:00
|
|
|
|
2014-11-18 01:54:34 +00:00
|
|
|
FILE* fLogFp;
|
|
|
|
int fPid;
|
|
|
|
};
|
2007-03-27 17:47:10 +00:00
|
|
|
|
2014-11-18 01:54:34 +00:00
|
|
|
extern DebugLog* gDebugLog; // declare and allocate in app
|
|
|
|
|
|
|
|
|
|
|
|
/* send the message to the log file (if open) and the CRT debug mechanism */
|
|
|
|
#define LOG_BASE(severity, file, line, format, ...) \
|
2014-11-18 21:05:15 +00:00
|
|
|
{ gDebugLog->Log((severity), (file), (line), (format), __VA_ARGS__); }
|
2014-11-18 01:54:34 +00:00
|
|
|
|
|
|
|
/*
|
|
|
|
* Log macros, with priority specifier. The output will be written to the
|
|
|
|
* log file, if one is open, and to the debugger output window, if available.
|
|
|
|
*
|
2014-12-02 06:07:39 +00:00
|
|
|
* The verbose-level debugging should be enabled on a file-by-file basis
|
|
|
|
* with a compile-time define, but that doesn't seem to work (pre-compiled
|
|
|
|
* header interference, maybe?).
|
2014-11-18 01:54:34 +00:00
|
|
|
*/
|
2014-12-02 06:07:39 +00:00
|
|
|
//#ifdef SHOW_LOGV
|
2014-11-18 01:54:34 +00:00
|
|
|
# define LOGV(format, ...) \
|
|
|
|
LOG_BASE(DebugLog::LOG_VERBOSE, __FILE__, __LINE__, format, __VA_ARGS__)
|
2014-12-02 06:07:39 +00:00
|
|
|
//#else
|
|
|
|
//# define LOGV(format, ...) ((void)0)
|
|
|
|
//#endif
|
|
|
|
|
2014-11-18 01:54:34 +00:00
|
|
|
#define LOGD(format, ...) \
|
|
|
|
LOG_BASE(DebugLog::LOG_DEBUG, __FILE__, __LINE__, format, __VA_ARGS__)
|
|
|
|
#define LOGI(format, ...) \
|
|
|
|
LOG_BASE(DebugLog::LOG_INFO, __FILE__, __LINE__, format, __VA_ARGS__)
|
|
|
|
#define LOGW(format, ...) \
|
|
|
|
LOG_BASE(DebugLog::LOG_WARN, __FILE__, __LINE__, format, __VA_ARGS__)
|
|
|
|
#define LOGE(format, ...) \
|
|
|
|
LOG_BASE(DebugLog::LOG_ERROR, __FILE__, __LINE__, format, __VA_ARGS__)
|
2007-03-27 17:47:10 +00:00
|
|
|
|
|
|
|
/* make the memory leak test output more interesting */
|
|
|
|
#ifdef _DEBUG
|
|
|
|
# define new DEBUG_NEW
|
|
|
|
#endif
|
|
|
|
|
|
|
|
/* retain some level of assertion with the non-debug MFC libs */
|
|
|
|
#if !defined(_DEBUG) && !defined(NDEBUG)
|
|
|
|
# undef ASSERT
|
|
|
|
# define ASSERT assert
|
|
|
|
#endif
|
|
|
|
|
|
|
|
/* put this in to break on interesting events when built debug */
|
|
|
|
#if defined(_DEBUG)
|
2014-11-18 01:54:34 +00:00
|
|
|
# define DebugBreak() { _CrtDbgBreak(); }
|
2007-03-27 17:47:10 +00:00
|
|
|
#else
|
|
|
|
# define DebugBreak() ((void) 0)
|
|
|
|
#endif
|
|
|
|
|
Large set of changes to restore CiderPress build.
CiderPress and MDC now compile, and execute far enough to open
their respective "about" boxes, but I doubt they'll do much
more than that.
* Switch from MBCS to UNICODE APIs
Microsoft switched to UTF-16 (by way of UCS-2) a long time ago,
and the support for MBCS seems to be getting phased out. So it's
time to switch to wide strings.
This is a bit awkward for CiderPress because it works with disk
and file archives with 8-bit filenames, and I want NufxLib and
DiskImgLib to continue to work on Linux (which has largely taken
the UTF-8 approach to Unicode). The libraries will continue to
work with 8-bit filenames, with CiderPress/MDC doing the
conversion at the appropriate point.
There were a couple of places where strings from a structure
handed back by one of the libraries were used directly in the UI,
or vice-versa, which is a problem because we have nowhere to
store the result of the conversion. These currently have fixed
place-holder "xyzzy" strings.
All UI strings are now wide.
Various format strings now use "%ls" and "%hs" to explicitly
specify wide and narrow. This doesn't play well with gcc, so
only the Windows-specific parts use those.
* Various updates to vcxproj files
The project-file conversion had some cruft that is now largely
gone. The build now has a common output directory for the EXEs
and libraries, avoiding the old post-build copy steps.
* Added zlib 1.2.8 and nufxlib 2.2.2 source snapshots
The old "prebuilts" directory is now gone. The libraries are now
built as part of building the apps.
I added a minimal set of files for zlib, and a full set for nufxlib.
The Linux-specific nufxlib goodies are included for the benefit of
the Linux utilities, which are currently broken (don't build).
* Replace symbols used for include guards
Symbols with a leading "__" are reserved.
2014-11-10 23:32:55 +00:00
|
|
|
#endif /*UTIL_MYDEBUG_H*/
|