You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
120 lines
3.0 KiB
120 lines
3.0 KiB
13 years ago
|
// This is the SIP interface definition for QKeySequence.
|
||
|
//
|
||
|
// Copyright (c) 2007
|
||
|
// Riverbank Computing Limited <info@riverbankcomputing.co.uk>
|
||
|
//
|
||
|
// This file is part of PyQt.
|
||
|
//
|
||
|
// This copy of PyQt 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.
|
||
|
//
|
||
|
// PyQt 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
|
||
|
// PyQt; 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>QKeySequence (Qt v3+)</Title>
|
||
|
<Para>
|
||
|
<Literal>QKeySequence</Literal> is fully implemented including the operators
|
||
|
<Literal>==</Literal>, <Literal>!=</Literal>, <Literal>QString()</Literal> and
|
||
|
<Literal>int()</Literal>. A <Literal>QString</Literal> instance or a Python
|
||
|
integer may be used whenever a <Literal>QKeySequence</Literal> can be used.
|
||
|
</Para>
|
||
|
</Sect2>
|
||
|
%End
|
||
|
|
||
|
|
||
|
%If (Qt_3_0_0 -)
|
||
|
|
||
|
class QKeySequence : Qt
|
||
|
{
|
||
|
%TypeHeaderCode
|
||
|
#include <qkeysequence.h>
|
||
|
%End
|
||
|
|
||
|
public:
|
||
|
QKeySequence();
|
||
|
QKeySequence(const QString &);
|
||
|
QKeySequence(int);
|
||
|
%If (Qt_3_1_0 -)
|
||
|
QKeySequence(int,int,int = 0,int = 0);
|
||
|
|
||
|
bool operator==(const QKeySequence &) const;
|
||
|
bool operator!=(const QKeySequence &) const;
|
||
|
|
||
|
uint count() const;
|
||
|
bool isEmpty() const;
|
||
|
Qt::SequenceMatch matches(const QKeySequence &) const;
|
||
|
%End
|
||
|
|
||
|
int __int__() const;
|
||
|
|
||
|
%ConvertToTypeCode
|
||
|
// Allow a QString or a Python integer whenever a QKeySequence is
|
||
|
// expected.
|
||
|
|
||
|
if (sipIsErr == NULL)
|
||
|
{
|
||
|
if (sipCanConvertToInstance(sipPy,sipClass_QKeySequence,SIP_NO_CONVERTORS))
|
||
|
return 1;
|
||
|
|
||
|
if (sipCanConvertToInstance(sipPy,sipClass_QString,0))
|
||
|
return 1;
|
||
|
|
||
|
PyErr_Clear();
|
||
|
|
||
|
PyInt_AsLong(sipPy);
|
||
|
|
||
|
return !PyErr_Occurred();
|
||
|
}
|
||
|
|
||
|
// We do this case before the int case because, otherwise,
|
||
|
// PyInt_AsLong() would achieve the same result but less efficiently.
|
||
|
|
||
|
if (sipCanConvertToInstance(sipPy,sipClass_QKeySequence,SIP_NO_CONVERTORS))
|
||
|
{
|
||
|
*sipCppPtr = reinterpret_cast<QKeySequence *>(sipConvertToInstance(sipPy,sipClass_QKeySequence,sipTransferObj,SIP_NO_CONVERTORS,0,sipIsErr));
|
||
|
|
||
|
return 0;
|
||
|
}
|
||
|
|
||
|
if (sipCanConvertToInstance(sipPy,sipClass_QString,0))
|
||
|
{
|
||
|
int state;
|
||
|
QString *s = reinterpret_cast<QString *>(sipConvertToInstance(sipPy,sipClass_QString,0,0,&state,sipIsErr));
|
||
|
|
||
|
if (*sipIsErr)
|
||
|
{
|
||
|
sipReleaseInstance(s,sipClass_QString,state);
|
||
|
return 0;
|
||
|
}
|
||
|
|
||
|
Py_BEGIN_ALLOW_THREADS
|
||
|
*sipCppPtr = new QKeySequence(*s);
|
||
|
Py_END_ALLOW_THREADS
|
||
|
|
||
|
sipReleaseInstance(s,sipClass_QString,state);
|
||
|
|
||
|
return sipGetState(sipTransferObj);
|
||
|
}
|
||
|
|
||
|
int key = PyInt_AsLong(sipPy);
|
||
|
|
||
|
Py_BEGIN_ALLOW_THREADS
|
||
|
*sipCppPtr = new QKeySequence(key);
|
||
|
Py_END_ALLOW_THREADS
|
||
|
|
||
|
return sipGetState(sipTransferObj);
|
||
|
%End
|
||
|
};
|
||
|
|
||
|
%End
|