Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Submit feedback
Contribute to GitLab
Sign in
Toggle navigation
V
vmj-qt
Project
Project
Details
Activity
Releases
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
Kulya
vmj-qt
Commits
2e3865b5
Commit
2e3865b5
authored
Aug 04, 2016
by
Dan Pascu
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Allow run_in_gui_thread to wait for the function to finish
parent
07fca1ea
Changes
1
Show whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
47 additions
and
10 deletions
+47
-10
util.py
blink/util.py
+47
-10
No files found.
blink/util.py
View file @
2e3865b5
...
@@ -3,6 +3,9 @@ from PyQt4.QtCore import QObject, QThread, QTimer
...
@@ -3,6 +3,9 @@ from PyQt4.QtCore import QObject, QThread, QTimer
from
PyQt4.QtGui
import
QApplication
from
PyQt4.QtGui
import
QApplication
from
application.python.decorator
import
decorator
,
preserve_signature
from
application.python.decorator
import
decorator
,
preserve_signature
from
application.python.types
import
Singleton
from
application.python.types
import
Singleton
from
functools
import
partial
from
threading
import
Event
from
sys
import
exc_info
from
blink.event
import
CallFunctionEvent
from
blink.event
import
CallFunctionEvent
...
@@ -17,7 +20,7 @@ class QSingleton(Singleton, type(QObject)):
...
@@ -17,7 +20,7 @@ class QSingleton(Singleton, type(QObject)):
def
call_in_gui_thread
(
function
,
*
args
,
**
kw
):
def
call_in_gui_thread
(
function
,
*
args
,
**
kw
):
application
=
QApplication
.
instance
()
application
=
QApplication
.
instance
()
if
application
.
thread
()
is
QThread
.
currentThread
():
if
application
.
thread
()
is
QThread
.
currentThread
():
function
(
*
args
,
**
kw
)
return
function
(
*
args
,
**
kw
)
else
:
else
:
application
.
postEvent
(
application
,
CallFunctionEvent
(
function
,
args
,
kw
))
application
.
postEvent
(
application
,
CallFunctionEvent
(
function
,
args
,
kw
))
...
@@ -26,15 +29,49 @@ def call_later(interval, function, *args, **kw):
...
@@ -26,15 +29,49 @@ def call_later(interval, function, *args, **kw):
QTimer
.
singleShot
(
int
(
interval
*
1000
),
lambda
:
function
(
*
args
,
**
kw
))
QTimer
.
singleShot
(
int
(
interval
*
1000
),
lambda
:
function
(
*
args
,
**
kw
))
class
FunctionExecutor
(
object
):
__slots__
=
'function'
,
'event'
,
'result'
,
'exception'
,
'traceback'
def
__init__
(
self
,
function
):
self
.
function
=
function
self
.
event
=
Event
()
self
.
result
=
None
self
.
exception
=
None
self
.
traceback
=
None
def
__call__
(
self
,
*
args
,
**
kw
):
try
:
self
.
result
=
self
.
function
(
*
args
,
**
kw
)
except
BaseException
as
exception
:
self
.
exception
=
exception
self
.
traceback
=
exc_info
()[
2
]
finally
:
self
.
event
.
set
()
def
wait
(
self
):
self
.
event
.
wait
()
if
self
.
exception
is
not
None
:
raise
type
(
self
.
exception
),
self
.
exception
,
self
.
traceback
else
:
return
self
.
result
@
decorator
@
decorator
def
run_in_gui_thread
(
function
):
def
run_in_gui_thread
(
function
=
None
,
wait
=
False
):
if
function
is
not
None
:
@
preserve_signature
(
function
)
@
preserve_signature
(
function
)
def
wrapper
(
*
args
,
**
kw
):
def
function_
wrapper
(
*
args
,
**
kw
):
application
=
QApplication
.
instance
()
application
=
QApplication
.
instance
()
if
application
.
thread
()
is
QThread
.
currentThread
():
if
application
.
thread
()
is
QThread
.
currentThread
():
function
(
*
args
,
**
kw
)
return
function
(
*
args
,
**
kw
)
else
:
if
wait
:
executor
=
FunctionExecutor
(
function
)
application
.
postEvent
(
application
,
CallFunctionEvent
(
executor
,
args
,
kw
))
return
executor
.
wait
()
else
:
else
:
application
.
postEvent
(
application
,
CallFunctionEvent
(
function
,
args
,
kw
))
application
.
postEvent
(
application
,
CallFunctionEvent
(
function
,
args
,
kw
))
return
wrapper
return
function_wrapper
else
:
return
partial
(
run_in_gui_thread
,
wait
=
wait
)
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment