summaryrefslogtreecommitdiffstats
path: root/sip/qt/qdialog.sip
blob: aa261969babd761c66518d5939784f29d6bca618 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
// This is the SIP interface definition for TQDialog.
//
// Copyright (c) 2007
// 	Riverbank Computing Limited <info@riverbankcomputing.co.uk>
// 
// This file is part of PyTQt.
// 
// This copy of PyTQt is free software; you can redistribute it and/or modify it
// under the terms of the GNU General Public License as published by the Free
// Software Foundation; either version 2, or (at your option) any later
// version.
// 
// PyTQt is supplied 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 General Public License for more
// details.
// 
// You should have received a copy of the GNU General Public License along with
// PyTQt; see the file LICENSE.  If not, write to the Free Software Foundation,
// Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.


%ExportedDoc
<Sect2><Title>TQDialog</Title>
<FuncSynopsis>
        <FuncDef>int <Function>exec</Function></FuncDef>
        <ParamDef></ParamDef>
</FuncSynopsis>
<Para>
This has been renamed to <Literal>exec_loop</Literal> in Python.
</Para>
<Para>
This method also causes ownership of the underlying C++ dialog to be transfered
to Python.  This means that the C++ dialog will be deleted when the Python
wrapper is garbage collected.  Although this is a little inconsistent, it
ensures that the dialog is deleted without having to explicity code it using
<Literal>TQObject.deleteLater()</Literal> or other techniques.
</Para>
</Sect2>
%End


class TQDialog : TQWidget
{
%TypeHeaderCode
#include <tqdialog.h>
%End

public:
	TQDialog(TQWidget * /TransferThis/ = 0,const char * = 0,bool = 0,WFlags = 0);

	enum DialogCode {
		Rejected,
		Accepted
	};

	int result() const;

	void show();
	void hide();
	void move(int,int);
	void move(const TQPoint &);
	void resize(int,int);
	void resize(const TQSize &);
	void setGeometry(int,int,int,int);
	void setGeometry(const TQRect &);

	void setOrientation(Orientation);
	Orientation orientation() const;

	void setExtension(TQWidget *);
	TQWidget *extension() const;

	TQSize sizeHint() const;
	TQSize minimumSizeHint() const;

	void setSizeGripEnabled(bool);
	bool isSizeGripEnabled() const;

	void setModal(bool);
	bool isModal() const;

public slots:
	int exec() /PyName=exec_loop, ReleaseGIL,
		    PreHook=__pyTQtPreEventLoopHook__,
		    PostHook=__pyTQtPostEventLoopHook__/;
%MethodCode
		// Transfer ownership back to Python (a modal dialog will
		// probably have the main window as it's parent).  This means
		// the TQt dialog will be deleted when the Python wrapper is
		// garbage collected.  Although this is a little inconsistent,
		// it saves having to code it explicitly to avoid the memory
		// leak.
		sipTransferBack(sipSelf);

		Py_BEGIN_ALLOW_THREADS
		sipRes = sipCpp->TQDialog::exec();
		Py_END_ALLOW_THREADS
%End

protected slots:
	virtual void done(int);
	virtual void accept();
	virtual void reject();

	void showExtension(bool);

protected:
	void setResult(int);
	void keyPressEvent(TQKeyEvent *);
	void closeEvent(TQCloseEvent *);
	void resizeEvent(TQResizeEvent *);
	void contextMenuEvent(TQContextMenuEvent *);
	bool eventFilter(TQObject *,TQEvent *);
	void adjustPosition(TQWidget *);

private:
	TQDialog(const TQDialog &);
};