<div dir="auto"><div><br><br><div class="gmail_quote"><div dir="ltr" class="gmail_attr">On Thu, 9 Feb 2023, 6:18 pm Richard Duivenvoorde via QGIS-Developer, <<a href="mailto:qgis-developer@lists.osgeo.org">qgis-developer@lists.osgeo.org</a>> wrote:<br></div><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">Ok after reading <a href="https://docs.qgis.org/3.28/en/docs/pyqgis_developer_cookbook/tasks.html" rel="noreferrer noreferrer" target="_blank">https://docs.qgis.org/3.28/en/docs/pyqgis_developer_cookbook/tasks.html</a> again, reading the warning:<br>
<br>
"Any background task (regardless of how it is created) must NEVER use any QObject that lives on the main thread, such as accessing QgsVectorLayer, QgsProject or perform any GUI based operations like creating new widgets or interacting with existing widgets. Qt widgets must only be accessed or modified from the main thread. Data that is used in a task must be copied before the task is started. Attempting to use them from background threads will result in crashes."<br></blockquote></div></div><div dir="auto"><br></div><div dir="auto">One thing you can do:</div><div dir="auto"><br></div><div dir="auto">From the thread which owns the object, when you've finished using that object in the thread, call object.moveToThread(QgsApplication.instance().thread())</div><div dir="auto"><br></div><div dir="auto">You're allowed to push objects which belong to the current thread to another thread, but never allowed to pull objects which belong to another thread over to the current thread.</div><div dir="auto"><br></div><div dir="auto">Nyall</div><div dir="auto"><br></div><div dir="auto"><br></div><div dir="auto"><div class="gmail_quote"><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">
<br>
Seems to make it pretty clear :-(<br>
<br>
Before rereading that, I even tried to pass a QgsMeshLayer-'reference' to the QgsTask, but that did not work either.<br>
<br>
I think I must conclude that I just have to wait for the load... :-)<br>
<br>
Regards,<br>
<br>
Richard Duivenvoorde<br>
<br>
<br>
<br>
On 2/8/23 21:40, Richard Duivenvoorde via QGIS-Developer wrote:<br>
> Hi,<br>
> <br>
> Having to juggle with rather large/long loading netcdf files, I thought to off load the loading to a QgsTask, so while the netcdf was loaded user could do other things...<br>
> <br>
> But I get "...is run from a different thread than the object  lives in ..." warnings.<br>
> <br>
> In short:<br>
> <br>
>      def run(self) -> bool:<br>
>          <a href="http://log.info" rel="noreferrer noreferrer" target="_blank">log.info</a>(f'LOADING... {self.netcdf_file}')<br>
>          try:<br>
>              self.layer = QgsMeshLayer(self.netcdf_file, 'PythonLoadedMeshLayer',  'mdal')<br>
>      ....<br>
> <br>
> BUT: while it looks like all is fine, I get a Qt warning in my messages, and on my terminal I get:<br>
> <br>
> [INFO] (Dummy-1   ) LOADING... /tmp/kees/aoi/aoi1/areaOfInterest1.nc<br>
> Warning: fileName (/home/richard/git/qgis/src/core/project/qgsproject.cpp:812) is run from a different thread than the object  lives in [0x5593004f1aa0 vs 0x5592ff7e6440]<br>
> Stacktrace (piped through c++filt):<br>
> /home/richard/bin/qgis_/master/debug/bin/qgis(+0xe26a)[0x5592fe9ba26a]<br>
> /home/richard/bin/qgis_/master/debug/bin/qgis(+0xea29)[0x5592fe9baa29]<br>
> /lib/x86_64-linux-gnu/libQt5Core.so.5(+0xc3b50)[0x7fc594ec3b50]<br>
> /lib/x86_64-linux-gnu/libQt5Core.so.5(qt_message_output(QtMsgType, QMessageLogContext const&, QString const&)+0xd)[0x7fc594ec50fd]<br>
> /lib/x86_64-linux-gnu/libQt5Core.so.5(QDebug::~QDebug()+0x68)[0x7fc594fc6fa8]<br>
> /home/richard/bin/qgis_/master/debug/lib/libqgis_core.so.3.29.0(QgsProject::fileName() const+0x267)[0x7fc592f1af2f]<br>
> /home/richard/bin/qgis_/master/debug/lib/libqgis_core.so.3.29.0(QgsMapLayer::loadNamedProperty(QString const&, QgsMapLayer::PropertyType, bool&, QFlags<QgsMapLayer::StyleCategory>)+0x752)[0x7fc592a215c0]<br>
> /home/richard/bin/qgis_/master/debug/lib/libqgis_core.so.3.29.0(QgsMapLayer::loadNamedStyle(QString const&, bool&, QFlags<QgsMapLayer::StyleCategory>)+0x2b1)[0x7fc592a20b8f]<br>
> /home/richard/bin/qgis_/master/debug/lib/libqgis_core.so.3.29.0(QgsMapLayer::loadDefaultStyle(bool&)+0x2dc)[0x7fc592a1f6ec]<br>
> /home/richard/bin/qgis_/master/debug/lib/libqgis_core.so.3.29.0(QgsMeshLayer::loadDefaultStyle(bool&)+0x685)[0x7fc5930a84bb]<br>
> /home/richard/bin/qgis_/master/debug/lib/libqgis_core.so.3.29.0(QgsMeshLayer::QgsMeshLayer(QString const&, QString const&, QString const&, QgsMeshLayer::LayerOptions const&)+0x2b9)[0x7fc5930a5ab1]<br>
> /home/richard/bin/qgis_/master/debug/share/qgis/python/qgis/_core.so(sipQgsMeshLayer::sipQgsMeshLayer(QString const&, QString const&, QString const&, QgsMeshLayer::LayerOptions const&)+0x3b)[0x7fc43040b9c7]<br>
> /home/richard/bin/qgis_/master/debug/share/qgis/python/qgis/_core.so(+0x121a0bc)[0x7fc43041a0bc]<br>
> /usr/lib/python3/dist-packages/PyQt5/<a href="http://sip.cpython-311-x86_64-linux-gnu.so" rel="noreferrer noreferrer" target="_blank">sip.cpython-311-x86_64-linux-gnu.so</a>(+0x19f60)[0x7fc4dc271f60]<br>
> /lib/x86_64-linux-gnu/libpython3.11.so.1.0(+0x1e02fe)[0x7fc47a5e02fe]<br>
> /lib/x86_64-linux-gnu/libpython3.11.so.1.0(_PyObject_MakeTpCall+0x7d)[0x7fc47a57baed]<br>
> /lib/x86_64-linux-gnu/libpython3.11.so.1.0(_PyEval_EvalFrameDefault+0x4a63)[0x7fc47a509c63]<br>
> /lib/x86_64-linux-gnu/libpython3.11.so.1.0(+0x26a6da)[0x7fc47a66a6da]<br>
> /lib/x86_64-linux-gnu/libpython3.11.so.1.0(+0x17f30c)[0x7fc47a57f30c]<br>
> /usr/lib/python3/dist-packages/PyQt5/<a href="http://sip.cpython-311-x86_64-linux-gnu.so" rel="noreferrer noreferrer" target="_blank">sip.cpython-311-x86_64-linux-gnu.so</a>(+0x1196c)[0x7fc4dc26996c]<br>
> [INFO] (MainThread) finished OK<br>
> <br>
> My Questions:<br>
> - should I NOT do this?<br>
> - or is the loading/construction of a QgsMeshLayer having pointers to places it should not?<br>
> <br>
> (mmm loading a QgsVectorLayer (shape via ogr) also results in about the same warnings...<br>
> so next question: is there another way to load these large netcdf's without blocking QGIS ?)<br>
> <br>
> Thanks for any info.<br>
> <br>
> Regards,<br>
> <br>
> Richard Duivenvoorde<br>
> _______________________________________________<br>
> QGIS-Developer mailing list<br>
> <a href="mailto:QGIS-Developer@lists.osgeo.org" target="_blank" rel="noreferrer">QGIS-Developer@lists.osgeo.org</a><br>
> List info: <a href="https://lists.osgeo.org/mailman/listinfo/qgis-developer" rel="noreferrer noreferrer" target="_blank">https://lists.osgeo.org/mailman/listinfo/qgis-developer</a><br>
> Unsubscribe: <a href="https://lists.osgeo.org/mailman/listinfo/qgis-developer" rel="noreferrer noreferrer" target="_blank">https://lists.osgeo.org/mailman/listinfo/qgis-developer</a><br>
<br>
_______________________________________________<br>
QGIS-Developer mailing list<br>
<a href="mailto:QGIS-Developer@lists.osgeo.org" target="_blank" rel="noreferrer">QGIS-Developer@lists.osgeo.org</a><br>
List info: <a href="https://lists.osgeo.org/mailman/listinfo/qgis-developer" rel="noreferrer noreferrer" target="_blank">https://lists.osgeo.org/mailman/listinfo/qgis-developer</a><br>
Unsubscribe: <a href="https://lists.osgeo.org/mailman/listinfo/qgis-developer" rel="noreferrer noreferrer" target="_blank">https://lists.osgeo.org/mailman/listinfo/qgis-developer</a><br>
</blockquote></div></div></div>