2020-09-30 16:53:55 +02:00

151 lines
3.5 KiB
C++

// Copyright (c) 1997-1999 Microsoft Corporation
//
// core library header files
//
// 30 Nov 1999 sburns
#ifndef BLCORE_HPP_INCLUDED
#define BLCORE_HPP_INCLUDED
#if !defined(__cplusplus)
#error This module must be compiled as C++
#endif
#if !defined(UNICODE)
#error This module must be compiled UNICODE. (add -DUNICODE to C_DEFINES in sources file)
#endif
// Include system headers before the burnslib headers. This is necessary
// because the burnslib headers redefine things like operator new, which may
// appear in system headers. We don't want to change the behavior of code
// outside this library (and users of this library).
#ifdef BURNSLIB_HPP_INCLUDED
// This file is being included as part of burnslib.hpp, so include the
// full set of system headers
#include "sysfull.hpp"
#else
#include "syscore.hpp"
#endif
#include "PragmaWarning.hpp"
// include Assert.hpp after syscore.hpp, as it redefines ASSERT()
#include "Assert.hpp"
namespace Burnslib
{
// For an explanation of the initialization guard thing, see Meyers,
// Scott. "Effective C++ pp. 178-182 Addison-Wesley 1992. Basically, it
// guarantees that this library is properly initialized before any code
// that uses it is called.
class InitializationGuard
{
public:
InitializationGuard();
~InitializationGuard();
private:
static unsigned counter;
// not defined
InitializationGuard(const InitializationGuard&);
const InitializationGuard& operator=(const InitializationGuard&);
};
}
//lint -e(1502) ok that InitializationGuard has no members: we use it for
// the side effects of static initialization calling the ctor
static Burnslib::InitializationGuard guard;
// we put mem.hpp at the top of our header list, as it redefines new. If
// any project header includes code that calls new, that code will see the
// redefinition. For the same reason, we #include mem.hpp after all the
// system headers, as we are uninterested in calls to new that they might
// make.
#include "mem.hpp"
#include "string.hpp"
#include "stacktr.hpp"
#include "log.hpp"
#include "smartptr.hpp"
#include "comstuff.hpp"
#include "coreutil.hpp"
#include "coreres.h"
using namespace Burnslib;
// this is defined in init.cpp
extern const wchar_t* REG_ADMIN_RUNTIME_OPTIONS;
//
// Things you must define in your code:
//
// CODEWORK Putting these externs in a namespace seems to confuse the
// linker.
// namespace Burnslib
// {
// your DllMain or WinMain must set this to the HINSTANCE of the module
// containing all string and other resources. Without this, no function that
// loads a resource will operate correctly.
extern HINSTANCE hResourceModuleHandle;
// The name of the log file where LOG output is sent. This file is
// placed in the %systemroot%\debug directory. The extension will be ".log"
extern const wchar_t* RUNTIME_NAME;
// The default debugging control options to be used, unless overriden in the
// registry DWORD value LogFlags under the key
// HKLM\Software\Microsoft\Windows\CurrentVersion\AdminDebug\\ + RUNTIME_NAME.
// The LOWORD is a set of flag specifing output destinations, the HIWORD is
// the debugging output options in effect.
extern DWORD DEFAULT_LOGGING_OPTIONS;
// }; // namespace Burnslib
#endif // BLCORE_HPP_INCLUDED