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
|
// qthread.sip generated by MetaSIP
//
// This file is part of the QtCore Python extension module.
//
// Copyright (c) 2018 Riverbank Computing Limited <info@riverbankcomputing.com>
//
// This file is part of PyQt5.
//
// This file may be used under the terms of the GNU General Public License
// version 3.0 as published by the Free Software Foundation and appearing in
// the file LICENSE included in the packaging of this file. Please review the
// following information to ensure the GNU General Public License version 3.0
// requirements will be met: http://www.gnu.org/copyleft/gpl.html.
//
// If you do not wish to use this file under the terms of the GPL version 3.0
// then you may purchase a commercial license. For more information contact
// info@riverbankcomputing.com.
//
// This file is provided AS IS with NO WARRANTY OF ANY KIND, INCLUDING THE
// WARRANTY OF DESIGN, MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE.
class QThread : QObject
{
%TypeHeaderCode
#include <qthread.h>
%End
public:
static QThread *currentThread();
static Qt::HANDLE currentThreadId();
static int idealThreadCount();
static void yieldCurrentThread() /ReleaseGIL/;
explicit QThread(QObject *parent /TransferThis/ = 0);
virtual ~QThread();
enum Priority
{
IdlePriority,
LowestPriority,
LowPriority,
NormalPriority,
HighPriority,
HighestPriority,
TimeCriticalPriority,
InheritPriority,
};
bool isFinished() const;
bool isRunning() const;
void setPriority(QThread::Priority priority);
QThread::Priority priority() const;
void setStackSize(uint stackSize);
uint stackSize() const;
void exit(int returnCode = 0) /ReleaseGIL/;
public slots:
void start(QThread::Priority priority = QThread::InheritPriority) /ReleaseGIL/;
void terminate();
void quit();
public:
bool wait(unsigned long msecs = ULONG_MAX) /ReleaseGIL/;
signals:
void started();
void finished();
protected:
virtual void run() /NewThread/;
int exec() /PyName=exec_,ReleaseGIL/;
%If (Py_v3)
int exec() /ReleaseGIL/;
%End
static void setTerminationEnabled(bool enabled = true);
public:
virtual bool event(QEvent *event);
static void sleep(unsigned long) /ReleaseGIL/;
static void msleep(unsigned long) /ReleaseGIL/;
static void usleep(unsigned long) /ReleaseGIL/;
QAbstractEventDispatcher *eventDispatcher() const;
void setEventDispatcher(QAbstractEventDispatcher *eventDispatcher /Transfer/);
%If (Qt_5_2_0 -)
void requestInterruption();
%End
%If (Qt_5_2_0 -)
bool isInterruptionRequested() const;
%End
%If (Qt_5_5_0 -)
int loopLevel() const;
%End
};
|