]> git.saurik.com Git - wxWidgets.git/blame - interface/wx/windowid.h
Fixed bug: wxPropertyGridInterface::SetPropertyReadOnly() with wxPG_DONT_RECURSE...
[wxWidgets.git] / interface / wx / windowid.h
CommitLineData
23324ae1
FM
1/////////////////////////////////////////////////////////////////////////////
2// Name: windowid.h
e54c96f1 3// Purpose: interface of wxIdManager
23324ae1
FM
4// Author: wxWidgets team
5// RCS-ID: $Id$
6// Licence: wxWindows license
7/////////////////////////////////////////////////////////////////////////////
8
d4bb7c93
FM
9/**
10 The type of unique identifiers (ID) used for wxWindow-derived classes.
11*/
12typedef int wxWindowID;
13
23324ae1
FM
14/**
15 @class wxIdManager
7c913512 16
f41d6c8c
FM
17 wxIdManager is responsible for allocating and releasing window IDs.
18 It is used by wxWindow::NewControlId() and wxWindow::UnreserveControlId(),
19 and can also be used be used directly.
7c913512 20
23324ae1 21 @library{wxcore}
3c99e2fd 22 @category{cfg}
7c913512 23
f41d6c8c
FM
24 @see wxWindow::NewControlId(), wxWindow::UnreserveControlId(),
25 @ref overview_windowids
23324ae1 26*/
7c913512 27class wxIdManager
23324ae1
FM
28{
29public:
30 /**
f41d6c8c
FM
31 Called directly by wxWindow::NewControlId(), this function will create
32 a new ID or range of IDs.
33 The IDs will be reserved until assigned to a wxWindowIDRef() or unreserved
34 with UnreserveControlId().
35 Only ID values that are not assigned to a wxWindowIDRef() need to be unreserved.
3c4f71cc 36
7c913512 37 @param count
4cc4bfaf 38 The number of sequential IDs to reserve.
3c4f71cc 39
d29a9a8a 40 @return The value of the first ID in the sequence, or wxID_NONE.
23324ae1
FM
41 */
42 static wxWindowID ReserveControlId(int count = 1);
f41d6c8c
FM
43
44 /**
45 Called directly by wxWindow::UnreserveControlId(), this function will
46 unreserve an ID or range of IDs that is currently reserved.
47 This should only be called for IDs returned by ReserveControlId() that
48 have NOT been assigned to a wxWindowIDRef (see @ref overview_windowids).
49
50 @param id
51 The first of the range of IDs to unreserve.
52 @param count
53 The number of sequential IDs to unreserve.
54
55 @return The value of the first ID in the sequence, or wxID_NONE.
56 */
57 static wxWindowID UnreserveControlId(wxWindowID id, int count = 1);
23324ae1 58};
e54c96f1 59