<div dir="ltr">ok, it is defiantly related to PyOS_InputHook. <div><br></div><div>I think I have the rough outlines of this correct below, but may have some details/terminology wrong.<br><div><br></div><div>When using pyqt "interactively" the infinite loop of the terminal and the Qt event loop need to be interlaced. This is done (in plain python) via the PyOS_InputHook which is a c-function which is run while the terminal is waiting for the (slow) humans to type something. The terminal than handles the keystroke (including possibly running what ever python there is run) and the call the input hook again. On posix systems the Qt event loop is run forever and then file descriptors / sockets are used to interrupt the event loop when the user hits a key, however on windows we do not have that and instead the input hook runs the Qt event loop for a short period of time, checks if a key has been hit, and if not loops. </div></div><div><br></div><div>Modal windows in Qt work by blocking the event loop of their parent and the run their own event loop (which effectively freeze's their parents, but allows the modal window to be responsive). However, when the outer event loop is interrupted, the question window gets closed and `QtWidgets.QMessageBox.question(...) returns NoButton. In the case of MS Windows, this happens on some polling loop so the window just flashes. On linux (and I suspect OSX) you can get the same behavior by clicking on the button to pop up the question, but then typing into the terminal (any key will do) before you click on the question box.</div><div><br></div><div>Tom</div><div><br></div></div><br><div class="gmail_quote"><div dir="ltr" class="gmail_attr">On Thu, Jun 27, 2019 at 4:12 PM Thomas Caswell <<a href="mailto:tcaswell@gmail.com">tcaswell@gmail.com</a>> wrote:<br></div><blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left:1px solid rgb(204,204,204);padding-left:1ex"><div dir="ltr">I suspect, but can not prove, that this is related to PyOS_InputHook and may depend on exactly which terminal emulator you are using on windows.<div><br></div><div>Tom</div></div><br><div class="gmail_quote"><div dir="ltr" class="gmail_attr">On Thu, Jun 27, 2019 at 3:01 PM Kyle Altendorf <<a href="mailto:sda@fstab.net" target="_blank">sda@fstab.net</a>> wrote:<br></div><blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left:1px solid rgb(204,204,204);padding-left:1ex"><div style="font-size:10pt">
<p>Seems to work ok in 5.9.2 and 5.12.1 in Linux here. I get 16384 (Yes) and 65536 (No).</p>
<p>Though this is an odd program. I thought message boxes maybe ran their own event loop if needed but is showing a button and expecting it's signals to emit functionally really proper?</p>
<p>Cheers,</p>
<p>-kyle</p>
<p><br></p>
<p>On 2019-06-27 14:36, Luke Campagnola wrote:</p>
<blockquote type="cite" style="padding:0px 0.4em;border-left:2px solid rgb(16,16,255);margin:0px">
<div dir="ltr">
<div>Greetings,</div>
<div>I have found that when calling QMessageBox.question, the message box flashes up briefly before disappearing and the call returns NoButton. This behavior is present in both PyQt4 and PyQt5 (most recently tested on 5.9.2 from anaconda package), on windows (but not linux), and only if I have not called QApplication.exec_() because I am running in an interactive python shell. </div>
<div> </div>
<div>Code to reproduce (run with python -i):</div>
<div> </div>
<div style="margin-left:40px">import sys<br>#from PyQt4 import QtGui as QtWidgets<br>from PyQt5 import QtWidgets</div>
<div style="margin-left:40px"> </div>
<div style="margin-left:40px">app = QtWidgets.QApplication([])<br><br>def msg():<br> print(QtWidgets.QMessageBox.question(btn, "title", "message"))<br><br>btn = QtWidgets.QPushButton("show messagebox")<br>btn.clicked.connect(msg)<br>btn.show()<br><br></div>
<div style="margin-left:40px"># message box works if event loop is started</div>
<div style="margin-left:40px"># app.exec_()</div>
<div style="margin-left:40px"> </div>
<div> </div>
<div>Cheers,</div>
<div>Luke</div>
</div>
<br>
<div class="gmail-m_-3333754831937473440gmail-m_6485799613692692490pre" style="margin:0px;padding:0px;font-family:monospace">_______________________________________________<br> PyQt mailing list <a href="mailto:PyQt@riverbankcomputing.com" target="_blank">PyQt@riverbankcomputing.com</a><br><a href="https://www.riverbankcomputing.com/mailman/listinfo/pyqt" rel="noopener noreferrer" target="_blank">https://www.riverbankcomputing.com/mailman/listinfo/pyqt</a></div>
</blockquote>
</div>
_______________________________________________<br>
PyQt mailing list <a href="mailto:PyQt@riverbankcomputing.com" target="_blank">PyQt@riverbankcomputing.com</a><br>
<a href="https://www.riverbankcomputing.com/mailman/listinfo/pyqt" rel="noreferrer" target="_blank">https://www.riverbankcomputing.com/mailman/listinfo/pyqt</a><br>
</blockquote></div><br clear="all"><div><br></div>-- <br><div dir="ltr" class="gmail-m_-3333754831937473440gmail_signature">Thomas Caswell<br><a href="mailto:tcaswell@gmail.com" target="_blank">tcaswell@gmail.com</a></div>
</blockquote></div><br clear="all"><div><br></div>-- <br><div dir="ltr" class="gmail_signature">Thomas Caswell<br><a href="mailto:tcaswell@gmail.com" target="_blank">tcaswell@gmail.com</a></div>