mirror of
				https://github.com/pocoproject/poco.git
				synced 2025-11-04 12:17:37 +01:00 
			
		
		
		
	
		
			
				
	
	
		
			143 lines
		
	
	
		
			4.3 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			143 lines
		
	
	
		
			4.3 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
//
 | 
						|
// UnWindows.h
 | 
						|
//
 | 
						|
// $Id: //poco/1.4/Foundation/include/Poco/UnWindows.h#1 $
 | 
						|
//
 | 
						|
// 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
 | 
						|
#if defined(_WIN32)
 | 
						|
	#if !defined(WIN32_LEAN_AND_MEAN) && !defined(POCO_BLOATED_WIN32)
 | 
						|
		#define WIN32_LEAN_AND_MEAN
 | 
						|
	#endif
 | 
						|
#endif
 | 
						|
 | 
						|
 | 
						|
// Microsoft Visual C++ includes copies of the Windows header files 
 | 
						|
// that were current at the time Visual C++ was released.
 | 
						|
// 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 
 | 
						|
// definitions.) For more information, see SdkDdkVer.h.
 | 
						|
 | 
						|
 | 
						|
#if defined(_WIN32_WINNT)
 | 
						|
	#if (_WIN32_WINNT < 0x0501)
 | 
						|
		#error Unsupported Windows version.
 | 
						|
	#endif
 | 
						|
#elif defined(NTDDI_VERSION)
 | 
						|
	#if (NTDDI_VERSION < 0x05010100)
 | 
						|
		#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 0x0501
 | 
						|
	#define NTDDI_VERSION 0x05010100
 | 
						|
#endif
 | 
						|
 | 
						|
 | 
						|
// 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.
 | 
						|
#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
 | 
						|
#endif // POCO_NO_UNWINDOWS
 | 
						|
 | 
						|
#endif // Foundation_UnWindows_INCLUDED
 |