qthread.sip 3.32 KB
Newer Older
xuebingbing's avatar
xuebingbing committed
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 120 121 122
// qthread.sip generated by MetaSIP on Sun Jun 16 16:09:27 2013
//
// This file is part of the QtCore Python extension module.
//
// Copyright (c) 2013 Riverbank Computing Limited <info@riverbankcomputing.com>
// 
// This file is part of PyQt.
// 
// This file may be used under the terms of the GNU General Public
// License versions 2.0 or 3.0 as published by the Free Software
// Foundation and appearing in the files LICENSE.GPL2 and LICENSE.GPL3
// included in the packaging of this file.  Alternatively you may (at
// your option) use any later version of the GNU General Public
// License if such license has been publicly approved by Riverbank
// Computing Limited (or its successors, if any) and the KDE Free Qt
// Foundation. In addition, as a special exception, Riverbank gives you
// certain additional rights. These rights are described in the Riverbank
// GPL Exception version 1.1, which can be found in the file
// GPL_EXCEPTION.txt in this package.
// 
// If you are unsure which license is appropriate for your use, please
// contact the sales department at sales@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();
%If (Qt_4_3_0 -)
    static int idealThreadCount();
%End
%If (Qt_4_5_0 -)
    static void yieldCurrentThread() /ReleaseGIL/;
%End
    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();
%If (- Qt_5_0_0)
    void terminated();
%End

protected:
%If (- Qt_4_4_0)
    virtual void run() = 0 /NewThread/;
%End
%If (Qt_4_4_0 -)
    virtual void run() /NewThread/;
%End
    int exec() /PyName=exec_,ReleaseGIL/;
%If (Py_v3)
    int exec() /ReleaseGIL/;
%End
    static void setTerminationEnabled(bool enabled = true);
%If (- Qt_5_0_0)
    static void sleep(unsigned long) /ReleaseGIL/;
%End
%If (- Qt_5_0_0)
    static void msleep(unsigned long) /ReleaseGIL/;
%End
%If (- Qt_5_0_0)
    static void usleep(unsigned long) /ReleaseGIL/;
%End

public:
%If (Qt_5_0_0 -)
    virtual bool event(QEvent *event);
%End
%If (Qt_5_0_0 -)
    static void sleep(unsigned long) /ReleaseGIL/;
%End
%If (Qt_5_0_0 -)
    static void msleep(unsigned long) /ReleaseGIL/;
%End
%If (Qt_5_0_0 -)
    static void usleep(unsigned long) /ReleaseGIL/;
%End
%If (Qt_5_0_0 -)
    QAbstractEventDispatcher *eventDispatcher() const;
%End
%If (Qt_5_0_0 -)
    void setEventDispatcher(QAbstractEventDispatcher *eventDispatcher /Transfer/);
%End
};