2009-09-09 10:30:24 +0200 fs r275970 : #i100127# provided by rene: check whether system-boost's function.hpp compiles without exception support 2009-09-04 21:58:00 +0200 fs r275832 : indention 2009-09-04 21:57:10 +0200 fs r275831 : #i10000# type in boost/spirit check. Thanks to thb 2009-09-04 10:58:54 +0200 fs r275787 : #i100127# provided by tono@openoffice.org: mingw needs using directives for std::min/max 2009-09-04 10:31:54 +0200 fs r275782 : #i100127# (approved by hjs) on Solaris, set GNUTAR to /usr/sfw/bin/gtar, this is available on baseline machines (Solaris 10.x), but not necessarily available in LD_LIBRARY_PATH 2009-08-19 21:47:55 +0200 rene r275161 : #i10000# check for the header actually used now 2009-08-17 21:55:31 +0200 fs r275073 : CWS-TOOLING: rebase CWS boost134 to trunk@275001 (milestone: DEV300:m55) 2009-07-16 09:39:25 +0200 fs r274031 : #i100127# extract download/% with GNUTAR instead of TAR 2009-07-14 09:18:15 +0200 fs r273960 : CWS-TOOLING: rebase CWS boost134 to trunk@273858 (milestone: DEV300:m52) 2009-07-13 09:55:14 +0200 fs r273919 : #i100127# use boost 1.39, not 1.34 2009-07-13 09:45:57 +0200 fs r273918 : use GNUTAR when extracting download/%.tar.gz, not TAR (necessary with boost 1.39 tarball) 2009-07-10 21:10:52 +0200 fs r273905 : #i100127# spirit now part of boost 2009-07-06 12:12:13 +0200 fs r273732 : #i10000# lngconvex, used in src/wizards, is built in shell => added missing module dependency 2009-07-02 15:34:51 +0200 fs r273660 : #i100127# 2009-07-02 13:35:24 +0200 fs r273645 : #i100127# MSVC needs some hinting when using boost::bind on (some) member functions 2009-07-02 10:33:59 +0200 fs r273625 : removed unused include (lead to an internal compiler error with MSVC and boost 1.34+) 2009-07-02 09:44:35 +0200 fs r273619 : change some include orders, prevents 'internal compiler errors' with MSVC 2009-07-01 09:19:25 +0200 fs r273547 : #i100127# who the heck is defining max as something unusable? 2009-07-01 09:17:28 +0200 fs r273546 : #i100127# defining min/max is causing trouble now 2009-07-01 09:15:40 +0200 fs r273545 : #i100127# reverted previous patch, and properly fixed the problem by defining BOOST_MEM_FN_ENABLE_CDECL, and disabling warning 4180 2009-07-01 09:14:23 +0200 fs r273544 : #i100127# re-disable warning 4180, still needed for some files 2009-07-01 09:07:33 +0200 fs r273543 : #i100127# reverted previous patch, and properly fixed the problem by defining BOOST_MEM_FN_ENABLE_CDECL 2009-06-24 11:00:32 +0200 fs r273319 : oops, re-introduced some inc locations 2009-06-23 22:10:02 +0200 fs r273304 : #i100127# disable warning C4180 2009-06-23 22:08:36 +0200 fs r273303 : #i100127# disable warning C4180 2009-06-16 12:26:49 +0200 fs r273015 : #i10000# (provided by mst@openoffice.org) 2009-06-15 09:10:27 +0200 fs r272962 : #i10000# use -r instead of -a when copying the include files, this prevents the spurious 'failed to preserve ownership' errors 2009-06-11 23:55:06 +0200 fs r272902 : #i100127# 2009-06-11 23:54:47 +0200 fs r272901 : #i100127# 2009-06-11 23:54:05 +0200 fs r272900 : make compile on unxsol[i|s]4 2009-06-10 10:12:22 +0200 fs r272798 : #i100127# don't deliver from within unxlngi6/misc/build/boost, but from a 'normalized' location unxlngi6/inc 2009-06-10 09:48:00 +0200 fs r272795 : #i100127# use 1.34.1 unconditionally on all platforms
223 lines
5.9 KiB
C++
Executable File
223 lines
5.9 KiB
C++
Executable File
/*************************************************************************
|
|
*
|
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
|
*
|
|
* Copyright 2008 by Sun Microsystems, Inc.
|
|
*
|
|
* OpenOffice.org - a multi-platform office productivity suite
|
|
*
|
|
* $RCSfile: dx_winstuff.hxx,v $
|
|
* $Revision: 1.3 $
|
|
*
|
|
* This file is part of OpenOffice.org.
|
|
*
|
|
* OpenOffice.org is free software: you can redistribute it and/or modify
|
|
* it under the terms of the GNU Lesser General Public License version 3
|
|
* only, as published by the Free Software Foundation.
|
|
*
|
|
* OpenOffice.org is distributed in the hope that it will be useful,
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
* GNU Lesser General Public License version 3 for more details
|
|
* (a copy is included in the LICENSE file that accompanied this code).
|
|
*
|
|
* You should have received a copy of the GNU Lesser General Public License
|
|
* version 3 along with OpenOffice.org. If not, see
|
|
* <http://www.openoffice.org/license.html>
|
|
* for a copy of the LGPLv3 License.
|
|
*
|
|
************************************************************************/
|
|
|
|
#ifndef _DXCANVAS_WINSTUFF_HXX
|
|
#define _DXCANVAS_WINSTUFF_HXX
|
|
|
|
#include <algorithm>
|
|
|
|
#include <boost/shared_ptr.hpp>
|
|
|
|
#include <basegfx/numeric/ftools.hxx>
|
|
|
|
#ifdef _WINDOWS_
|
|
#error someone else included <windows.h>
|
|
#endif
|
|
|
|
// Enabling Direct3D Debug Information Further more, with registry key
|
|
// \\HKEY_LOCAL_MACHINE\\SOFTWARE\\Microsoft\\Direct3D\D3D9Debugging\\EnableCreationStack
|
|
// set to 1, sets a backtrace each time an object is created to the
|
|
// following global variable: LPCWSTR CreationCallStack
|
|
#if OSL_DEBUG_LEVEL > 0
|
|
# define D3D_DEBUG_INFO
|
|
#endif
|
|
|
|
#ifndef DIRECTX_VERSION
|
|
#error please define for which directx version we should compile
|
|
#endif
|
|
|
|
#if defined _MSC_VER
|
|
#pragma warning(push,1)
|
|
#endif
|
|
|
|
|
|
#define BOOL win32BOOL
|
|
#define INT32 win32INT32
|
|
#define UINT32 win32UINT32
|
|
#define GradientStyle_RECT win32GradientStyle_RECT
|
|
#define Polygon win32Polygon
|
|
#define PolyPolygon win32PolyPolygon
|
|
#undef WB_LEFT
|
|
#undef WB_RIGHT
|
|
|
|
#define WIN32_LEAN_AND_MEAN
|
|
#include <windows.h> // TODO(Q1): extract minimal set of required headers for gdiplus
|
|
|
|
#if DIRECTX_VERSION < 0x0900
|
|
|
|
#include <multimon.h>
|
|
|
|
// Be compatible with directdraw 3.0. Lets see how far this takes us
|
|
#define DIRECTDRAW_VERSION 0x0300
|
|
#include <ddraw.h>
|
|
|
|
// Be compatible with direct3d 5.0. Lets see how far this takes us
|
|
#define DIRECT3D_VERSION 0x0500
|
|
#define D3D_OVERLOADS
|
|
#include <d3d.h>
|
|
|
|
typedef IDirectDrawSurface surface_type;
|
|
|
|
#else
|
|
|
|
#include <d3d9.h>
|
|
#include <d3dx9.h>
|
|
#include <dxerr9.h>
|
|
|
|
typedef IDirect3DSurface9 surface_type;
|
|
|
|
#endif
|
|
|
|
#undef DrawText
|
|
|
|
#ifdef __MINGW32__
|
|
using ::std::max;
|
|
using ::std::min;
|
|
#endif
|
|
|
|
#include <gdiplus.h>
|
|
|
|
#ifdef min
|
|
# undef min
|
|
#endif
|
|
#ifdef max
|
|
# undef max
|
|
#endif
|
|
|
|
namespace dxcanvas
|
|
{
|
|
// some shared pointer typedefs to Gdiplus objects
|
|
typedef ::boost::shared_ptr< Gdiplus::Graphics > GraphicsSharedPtr;
|
|
typedef ::boost::shared_ptr< Gdiplus::GraphicsPath > GraphicsPathSharedPtr;
|
|
typedef ::boost::shared_ptr< Gdiplus::Bitmap > BitmapSharedPtr;
|
|
typedef ::boost::shared_ptr< Gdiplus::CachedBitmap > CachedBitmapSharedPtr;
|
|
typedef ::boost::shared_ptr< Gdiplus::Font > FontSharedPtr;
|
|
typedef ::boost::shared_ptr< Gdiplus::Brush > BrushSharedPtr;
|
|
typedef ::boost::shared_ptr< Gdiplus::TextureBrush > TextureBrushSharedPtr;
|
|
|
|
/** COM object RAII wrapper
|
|
|
|
This template wraps a Windows COM object, transparently
|
|
handling lifetime issues the C++ way (i.e. releasing the
|
|
reference when the object is destroyed)
|
|
*/
|
|
template< typename T > class COMReference
|
|
{
|
|
public:
|
|
typedef T Wrappee;
|
|
|
|
COMReference() :
|
|
mp( NULL )
|
|
{
|
|
}
|
|
|
|
/** Create from raw pointer
|
|
|
|
@attention This constructor assumes the interface is
|
|
already acquired (unless p is NULL), no additional AddRef
|
|
is called here.
|
|
|
|
This caters e.g. for all DirectX factory methods, which
|
|
return the created interfaces pre-acquired, into a raw
|
|
pointer. Simply pass the pointer to this class, but don't
|
|
call Release manually on it!
|
|
|
|
@example IDirectDrawSurface* pSurface;
|
|
pDD->CreateSurface(&aSurfaceDesc, &pSurface, NULL);
|
|
mpSurface = COMReference< IDirectDrawSurface >(pSurface);
|
|
|
|
*/
|
|
explicit COMReference( T* p ) :
|
|
mp( p )
|
|
{
|
|
}
|
|
|
|
COMReference( const COMReference& rNew ) :
|
|
mp( NULL )
|
|
{
|
|
if( rNew.mp == NULL )
|
|
return;
|
|
|
|
rNew.mp->AddRef(); // do that _before_ assigning the
|
|
// pointer. Just in case...
|
|
mp = rNew.mp;
|
|
}
|
|
|
|
COMReference& operator=( const COMReference& rRHS )
|
|
{
|
|
COMReference aTmp(rRHS);
|
|
::std::swap( mp, aTmp.mp );
|
|
|
|
return *this;
|
|
}
|
|
|
|
~COMReference()
|
|
{
|
|
reset();
|
|
}
|
|
|
|
int reset()
|
|
{
|
|
int refcount = 0;
|
|
if( mp )
|
|
refcount = mp->Release();
|
|
|
|
mp = NULL;
|
|
return refcount;
|
|
}
|
|
|
|
bool is() const { return mp != NULL; }
|
|
T* get() const { return mp; }
|
|
T* operator->() const { return mp; }
|
|
T& operator*() const { return *mp; }
|
|
|
|
private:
|
|
T* mp;
|
|
};
|
|
|
|
// get_pointer() enables boost::mem_fn to recognize COMReference
|
|
template<class T> inline T * get_pointer(COMReference<T> const& p)
|
|
{
|
|
return p.get();
|
|
}
|
|
}
|
|
|
|
#if defined _MSC_VER
|
|
#pragma warning(pop)
|
|
#endif
|
|
|
|
#undef DELETE
|
|
#undef BOOL
|
|
#undef INT32
|
|
#undef UINT32
|
|
#undef PolyPolygon
|
|
|
|
#endif /* _DXCANVAS_WINSTUFF_HXX */
|