2023-02-08 11:04:11 +00:00
|
|
|
//
|
|
|
|
// UnWindows.h
|
|
|
|
//
|
|
|
|
// Library: Foundation
|
|
|
|
// Package: Core
|
|
|
|
// Module: UnWindows
|
|
|
|
//
|
|
|
|
// A wrapper around the <windows.h> header file that #undef's some
|
|
|
|
// of the macros for function names defined by <windows.h> that
|
|
|
|
// are a frequent source of conflicts (e.g., GetUserName).
|
|
|
|
//
|
|
|
|
// Remember, that most of the WIN32 API functions come in two variants,
|
|
|
|
// an Unicode variant (e.g., GetUserNameA) and an ASCII variant (GetUserNameW).
|
|
|
|
// There is also a macro (GetUserName) that's either defined to be the Unicode
|
|
|
|
// name or the ASCII name, depending on whether the UNICODE macro is #define'd
|
|
|
|
// or not. POCO always calls the Unicode or ASCII functions directly (depending
|
|
|
|
// on whether POCO_WIN32_UTF8 is #define'd or not), so the macros are not ignored.
|
|
|
|
//
|
|
|
|
// These macro definitions are a frequent case of problems and naming conflicts,
|
|
|
|
// especially for C++ programmers. Say, you define a class with a member function named
|
|
|
|
// GetUserName. Depending on whether "Poco/UnWindows.h" has been included by a particular
|
|
|
|
// translation unit or not, this might be changed to GetUserNameA/GetUserNameW, or not.
|
|
|
|
// While, due to naming conventions used, this is less of a problem in POCO, some
|
|
|
|
// of the users of POCO might use a different naming convention where this can become
|
|
|
|
// a problem.
|
|
|
|
//
|
|
|
|
// To disable the #undef's, compile POCO with the POCO_NO_UNWINDOWS macro #define'd.
|
|
|
|
//
|
|
|
|
// Copyright (c) 2007, Applied Informatics Software Engineering GmbH.
|
|
|
|
// and Contributors.
|
|
|
|
//
|
|
|
|
// SPDX-License-Identifier: BSL-1.0
|
|
|
|
//
|
|
|
|
|
|
|
|
|
|
|
|
#ifndef Foundation_UnWindows_INCLUDED
|
|
|
|
#define Foundation_UnWindows_INCLUDED
|
|
|
|
|
|
|
|
|
|
|
|
// Reduce bloat
|
|
|
|
|
|
|
|
|
2023-02-13 09:22:33 +00:00
|
|
|
// Microsoft Visual C++ includes copies of the Windows header files
|
2023-02-08 11:04:11 +00:00
|
|
|
// that were current at the time Visual C++ was released.
|
2023-02-13 09:22:33 +00:00
|
|
|
// The Windows header files use macros to indicate which versions
|
|
|
|
// of Windows support many programming elements. Therefore, you must
|
|
|
|
// define these macros to use new functionality introduced in each
|
|
|
|
// major operating system release. (Individual header files may use
|
|
|
|
// different macros; therefore, if compilation problems occur, check
|
|
|
|
// the header file that contains the definition for conditional
|
2023-02-08 11:04:11 +00:00
|
|
|
// definitions.) For more information, see SdkDdkVer.h.
|
|
|
|
|
|
|
|
|
2023-02-13 09:22:33 +00:00
|
|
|
# if defined(_WIN32_WINNT)
|
|
|
|
# if (_WIN32_WINNT < 0x0502)
|
|
|
|
# error Unsupported Windows version.
|
|
|
|
# endif
|
|
|
|
# elif defined(NTDDI_VERSION)
|
|
|
|
# if (NTDDI_VERSION < 0x05020000)
|
|
|
|
# error Unsupported Windows version.
|
|
|
|
# endif
|
|
|
|
# elif !defined(_WIN32_WINNT)
|
|
|
|
// Define minimum supported version.
|
|
|
|
// This can be changed, if needed.
|
|
|
|
// If allowed (see POCO_MIN_WINDOWS_OS_SUPPORT
|
|
|
|
// below), Platform_WIN32.h will do its
|
|
|
|
// best to determine the appropriate values
|
|
|
|
// and may redefine these. See Platform_WIN32.h
|
|
|
|
// for details.
|
|
|
|
# define _WIN32_WINNT 0x0502
|
|
|
|
# define NTDDI_VERSION 0x05020000
|
|
|
|
# endif
|
2023-02-08 11:04:11 +00:00
|
|
|
|
|
|
|
|
|
|
|
// To prevent Platform_WIN32.h to modify version defines,
|
|
|
|
// uncomment this, otherwise versions will be automatically
|
|
|
|
// discovered in Platform_WIN32.h.
|
|
|
|
// #define POCO_FORCE_MIN_WINDOWS_OS_SUPPORT
|
|
|
|
|
|
|
|
|
|
|
|
#include <windows.h>
|
|
|
|
|
|
|
|
|
|
|
|
#if !defined(POCO_NO_UNWINDOWS)
|
|
|
|
// A list of annoying macros to #undef.
|
|
|
|
// Extend as required.
|
2023-02-13 09:22:33 +00:00
|
|
|
# undef GetBinaryType
|
|
|
|
# undef GetShortPathName
|
|
|
|
# undef GetLongPathName
|
|
|
|
# undef GetEnvironmentStrings
|
|
|
|
# undef SetEnvironmentStrings
|
|
|
|
# undef FreeEnvironmentStrings
|
|
|
|
# undef FormatMessage
|
|
|
|
# undef EncryptFile
|
|
|
|
# undef DecryptFile
|
|
|
|
# undef CreateMutex
|
|
|
|
# undef OpenMutex
|
|
|
|
# undef CreateEvent
|
|
|
|
# undef OpenEvent
|
|
|
|
# undef CreateSemaphore
|
|
|
|
# undef OpenSemaphore
|
|
|
|
# undef LoadLibrary
|
|
|
|
# undef GetModuleFileName
|
|
|
|
# undef CreateProcess
|
|
|
|
# undef GetCommandLine
|
|
|
|
# undef GetEnvironmentVariable
|
|
|
|
# undef SetEnvironmentVariable
|
|
|
|
# undef ExpandEnvironmentStrings
|
|
|
|
# undef OutputDebugString
|
|
|
|
# undef FindResource
|
|
|
|
# undef UpdateResource
|
|
|
|
# undef FindAtom
|
|
|
|
# undef AddAtom
|
|
|
|
# undef GetSystemDirectory
|
|
|
|
# undef GetTempPath
|
|
|
|
# undef GetTempFileName
|
|
|
|
# undef SetCurrentDirectory
|
|
|
|
# undef GetCurrentDirectory
|
|
|
|
# undef CreateDirectory
|
|
|
|
# undef RemoveDirectory
|
|
|
|
# undef CreateFile
|
|
|
|
# undef DeleteFile
|
|
|
|
# undef SearchPath
|
|
|
|
# undef CopyFile
|
|
|
|
# undef MoveFile
|
|
|
|
# undef ReplaceFile
|
|
|
|
# undef GetComputerName
|
|
|
|
# undef SetComputerName
|
|
|
|
# undef GetUserName
|
|
|
|
# undef LogonUser
|
|
|
|
# undef GetVersion
|
|
|
|
# undef GetObject
|
2023-02-08 11:04:11 +00:00
|
|
|
#endif // POCO_NO_UNWINDOWS
|
|
|
|
|
|
|
|
#endif // Foundation_UnWindows_INCLUDED
|