Add wxWindowPtr smart pointer.
git-svn-id: https://svn.wxwidgets.org/svn/wx/wxWidgets/trunk@74774 c3d73ce0-8a6f-49c7-b76d-6d57e0e08775
This commit is contained in:
parent
4852df90e2
commit
c80d4c1e20
@ -4159,6 +4159,7 @@ COND_USE_GUI_1_ALL_GUI_HEADERS = \
|
||||
wx/valnum.h \
|
||||
wx/window.h \
|
||||
wx/windowid.h \
|
||||
wx/windowptr.h \
|
||||
wx/withimages.h \
|
||||
wx/wrapsizer.h \
|
||||
wx/wupdlock.h \
|
||||
|
@ -907,6 +907,7 @@ IMPORTANT: please read docs/tech/tn0016.txt before modifying this file!
|
||||
wx/valnum.h
|
||||
wx/window.h
|
||||
wx/windowid.h
|
||||
wx/windowptr.h
|
||||
wx/withimages.h
|
||||
wx/wrapsizer.h
|
||||
wx/wupdlock.h
|
||||
|
@ -3304,6 +3304,10 @@ SOURCE=..\..\include\wx\windowid.h
|
||||
# End Source File
|
||||
# Begin Source File
|
||||
|
||||
SOURCE=..\..\include\wx\windowptr.h
|
||||
# End Source File
|
||||
# Begin Source File
|
||||
|
||||
SOURCE=..\..\include\wx\withimages.h
|
||||
# End Source File
|
||||
# Begin Source File
|
||||
|
@ -1234,6 +1234,7 @@
|
||||
<ClInclude Include="..\..\include\wx\persist\window.h" />
|
||||
<ClInclude Include="..\..\include\wx\window.h" />
|
||||
<ClInclude Include="..\..\include\wx\windowid.h" />
|
||||
<ClInclude Include="..\..\include\wx\windowptr.h" />
|
||||
<ClInclude Include="..\..\include\wx\withimages.h" />
|
||||
<ClInclude Include="..\..\include\wx\wizard.h" />
|
||||
<ClInclude Include="..\..\include\wx\wrapsizer.h" />
|
||||
|
@ -2524,6 +2524,9 @@
|
||||
<ClInclude Include="..\..\include\wx\xpmhand.h">
|
||||
<Filter>Common Headers</Filter>
|
||||
</ClInclude>
|
||||
<ClInclude Include="..\..\include\wx\windowptr.h">
|
||||
<Filter>Common Headers</Filter>
|
||||
</ClInclude>
|
||||
</ItemGroup>
|
||||
<ItemGroup>
|
||||
<CustomBuild Include="..\..\include\wx\msw\setup.h">
|
||||
|
@ -2663,6 +2663,9 @@
|
||||
<File
|
||||
RelativePath="..\..\include\wx\windowid.h">
|
||||
</File>
|
||||
<File
|
||||
RelativePath="..\..\include\wx\windowptr.h">
|
||||
</File>
|
||||
<File
|
||||
RelativePath="..\..\include\wx\withimages.h">
|
||||
</File>
|
||||
|
@ -3559,6 +3559,10 @@
|
||||
RelativePath="..\..\include\wx\windowid.h"
|
||||
>
|
||||
</File>
|
||||
<File
|
||||
RelativePath="..\..\include\wx\windowptr.h"
|
||||
>
|
||||
</File>
|
||||
<File
|
||||
RelativePath="..\..\include\wx\withimages.h"
|
||||
>
|
||||
|
@ -3557,6 +3557,10 @@
|
||||
RelativePath="..\..\include\wx\windowid.h"
|
||||
>
|
||||
</File>
|
||||
<File
|
||||
RelativePath="..\..\include\wx\windowptr.h"
|
||||
>
|
||||
</File>
|
||||
<File
|
||||
RelativePath="..\..\include\wx\withimages.h"
|
||||
>
|
||||
|
63
include/wx/windowptr.h
Normal file
63
include/wx/windowptr.h
Normal file
@ -0,0 +1,63 @@
|
||||
/////////////////////////////////////////////////////////////////////////////
|
||||
// Name: wx/windowptr.h
|
||||
// Purpose: smart pointer for holding wxWindow instances
|
||||
// Author: Vaclav Slavik
|
||||
// Created: 2013-09-01
|
||||
// Copyright: (c) 2013 Vaclav Slavik
|
||||
// Licence: wxWindows licence
|
||||
/////////////////////////////////////////////////////////////////////////////
|
||||
|
||||
#ifndef _WX_WINDOWPTR_H_
|
||||
#define _WX_WINDOWPTR_H_
|
||||
|
||||
#include "wx/sharedptr.h"
|
||||
|
||||
// ----------------------------------------------------------------------------
|
||||
// wxWindowPtr: A smart pointer with correct wxWindow destruction.
|
||||
// ----------------------------------------------------------------------------
|
||||
|
||||
namespace wxPrivate
|
||||
{
|
||||
|
||||
struct wxWindowDeleter
|
||||
{
|
||||
void operator()(wxWindow *win)
|
||||
{
|
||||
win->Destroy();
|
||||
}
|
||||
};
|
||||
|
||||
} // namespace wxPrivate
|
||||
|
||||
template<typename T>
|
||||
class wxWindowPtr : public wxSharedPtr<T>
|
||||
{
|
||||
public:
|
||||
typedef T element_type;
|
||||
|
||||
wxEXPLICIT wxWindowPtr(element_type* win)
|
||||
: wxSharedPtr<T>(win, wxPrivate::wxWindowDeleter())
|
||||
{
|
||||
}
|
||||
|
||||
wxWindowPtr() {}
|
||||
wxWindowPtr(const wxWindowPtr& tocopy) : wxSharedPtr<T>(tocopy) {}
|
||||
|
||||
wxWindowPtr& operator=(const wxWindowPtr& tocopy)
|
||||
{
|
||||
wxSharedPtr<T>::operator=(tocopy);
|
||||
return *this;
|
||||
}
|
||||
|
||||
wxWindowPtr& operator=(element_type* win)
|
||||
{
|
||||
return operator=(wxWindowPtr(win));
|
||||
}
|
||||
|
||||
void reset(T* ptr = NULL)
|
||||
{
|
||||
wxSharedPtr<T>::reset(ptr, wxPrivate::wxWindowDeleter());
|
||||
}
|
||||
};
|
||||
|
||||
#endif // _WX_WINDOWPTR_H_
|
82
interface/wx/windowptr.h
Normal file
82
interface/wx/windowptr.h
Normal file
@ -0,0 +1,82 @@
|
||||
///////////////////////////////////////////////////////////////////////////////
|
||||
// Name: interface/wx/windowptr.h
|
||||
// Purpose: wxWindowPtr<T> class documentation.
|
||||
// Author: Vaclav Slavik
|
||||
// Created: 2013-09-02
|
||||
// Copyright: (c) 2013 Vaclav Slavik <vslavik@fastmail.fm>
|
||||
// Licence: wxWindows licence
|
||||
///////////////////////////////////////////////////////////////////////////////
|
||||
|
||||
/**
|
||||
A reference-counted smart pointer for holding wxWindow instances.
|
||||
|
||||
This specialization of wxSharedPtr<T> is useful for holding
|
||||
wxWindow-derived objects. Unlike wxSharedPtr<T> or @c std::shared_ptr<>, it
|
||||
doesn't use the delete operator to destroy the value when reference count
|
||||
drops to zero, but calls wxWindow::Destroy() to safely destroy the window.
|
||||
|
||||
The template parameter T must be wxWindow or a class derived from it.
|
||||
|
||||
@library{wxcore}
|
||||
@category{smartpointers}
|
||||
|
||||
@since 3.0
|
||||
|
||||
@see wxSharedPtr<T>
|
||||
*/
|
||||
template<typename T>
|
||||
class wxWindowPtr<T> : public wxSharedPtr<T>
|
||||
{
|
||||
public:
|
||||
/// Default constructor.
|
||||
wxWindowPtr();
|
||||
|
||||
/**
|
||||
Constructor.
|
||||
|
||||
Creates shared pointer from the raw pointer @a ptr and takes ownership
|
||||
of it.
|
||||
*/
|
||||
explicit wxWindowPtr(T* ptr);
|
||||
|
||||
/**
|
||||
Constructor.
|
||||
|
||||
Creates shared pointer from the raw pointer @a ptr and deleter @a d
|
||||
and takes ownership of it.
|
||||
|
||||
@param ptr The raw pointer.
|
||||
@param d Deleter - a functor that is called instead of delete to
|
||||
free the @a ptr raw pointer when its reference count drops to
|
||||
zero.
|
||||
|
||||
*/
|
||||
template<typename Deleter>
|
||||
explicit wxWindowPtr(T* ptr, Deleter d);
|
||||
|
||||
/// Copy constructor.
|
||||
wxWindowPtr(const wxWindowPtr<T>& tocopy);
|
||||
|
||||
/**
|
||||
Assignment operator.
|
||||
|
||||
Releases any previously held pointer and creates a reference to @a ptr.
|
||||
*/
|
||||
wxWindowPtr<T>& operator=(T* ptr);
|
||||
|
||||
/**
|
||||
Assignment operator.
|
||||
|
||||
Releases any previously held pointer and creates a reference to the
|
||||
same object as @a topcopy.
|
||||
*/
|
||||
wxWindowPtr<T>& operator=(const wxWindowPtr<T>& tocopy);
|
||||
|
||||
/**
|
||||
Reset pointer to @a ptr.
|
||||
|
||||
If the reference count of the previously owned pointer was 1 it will be deleted.
|
||||
*/
|
||||
void reset(T* ptr = NULL);
|
||||
};
|
||||
|
Loading…
Reference in New Issue
Block a user