"GTK" warning for Native QFileDialog under Linux
-
wrote on 15 Dec 2017, 10:54 last edited by JonB
The following question will need a Qt expert who is prepared to look at the Qt source code!
- It definitely happens under Linux Ubuntu with GNOME desktop.
- I do not know whether it happens under Linux with other desktops.
- I do not know whether it happens under Windows.
Someone will have to be kind enough to try and see!
If you open the Native (not Qt)
QFileDialog
(e.g.QFileDialog.getOpenFileName(parent, caption, directory, filter, initialFilter, options)
), you always get a warning:Gtk-Message: GtkDialog mapped without a transient parent. This is discouraged.
This is explained (to some extent) in, say, https://stackoverflow.com/questions/44392504/run-python-gtk3-dialog-or-message-dialog-without-no-transient-parent-warning or https://stackoverflow.com/questions/29883211/gtkdialog-mapped-without-a-transient-parent
Note that this warning still occurs whatever widget I pass as
parent
toQFileDialog
, I have tried the calling Dialog widget, the Main Window and NULL/None to no effect.The warning does not matter so much inside a debugger, but it appears in the output from my application, e.g. in a terminal window if I invoke it from there. If you are an expert you will know why running my app with
2>/dev/null
is not a good solution!If I understand those posts (especially https://stackoverflow.com/questions/44392504/run-python-gtk3-dialog-or-message-dialog-without-no-transient-parent-warning) correctly, it's down to how Qt source code --- which I take to be using GTK --- actually invokes the native file dialog. You would have thought it was passing the parent I give to
QFileDialog
, but maybe not?Can anyone see what's going on in the source for this? Given that, is there any possible workaround for me?
-
@mrjj Yes, the native dialog is GTK, but there is no other GTK window to use as parent, right?
wrote on 20 Dec 2017, 09:25 last edited by JonB@jsulm , @mrjj
Ah, now it is beginning to become clearer! I think you're saying:- The native file dialog is a special kind of window: a "GTK" window. (This applies to Linux/X11? Ubuntu? Unity desktop only?)
- It would like another GTK window as its parent.
- But the Qt window which is its parent in
QFileDialog
is not a GTK window. - So the code passes
0
/NULL
for the parent, and that causes the warning.
Right?
-
Hi,
From a quick look, it doesn't seem there's anything that can be done currently see here.
-
Hi,
From a quick look, it doesn't seem there's anything that can be done currently see here.
wrote on 19 Dec 2017, 08:25 last edited by@SGaist
Thank you for that. I note that the call seems to be:gtk_file_chooser_dialog_new("", 0, ...)
That
0
is forparent
, which I understand to be the cause of the warning. Seems strange that the "parent" we pass toQFileDialog
function does not get passed down to native dialog call? -
@SGaist
Thank you for that. I note that the call seems to be:gtk_file_chooser_dialog_new("", 0, ...)
That
0
is forparent
, which I understand to be the cause of the warning. Seems strange that the "parent" we pass toQFileDialog
function does not get passed down to native dialog call?@JNBarchan said in "GTK" warning for Native QFileDialog under Linux:
Seems strange that the "parent" we pass to QFileDialog function does not get passed down to native dialog call?
Because it can't. GTK does not know anything about any Qt classes - so it cannot use Qt classes as parents.
-
@JNBarchan said in "GTK" warning for Native QFileDialog under Linux:
Seems strange that the "parent" we pass to QFileDialog function does not get passed down to native dialog call?
Because it can't. GTK does not know anything about any Qt classes - so it cannot use Qt classes as parents.
-
@jsulm
Sorry, yes, I meant, when we pass a Qt parent widget as parent to QFileDialog it would pass the corresponding native window onto GTK level as parent. But I don't know anything about GTK!@JNBarchan But since it is a Qt application there is no native GTK window. Qt does not use GTK on Linux - as far as I know it draws by itself.
-
@JNBarchan But since it is a Qt application there is no native GTK window. Qt does not use GTK on Linux - as far as I know it draws by itself.
@jsulm
But a native QFileDialog might be GTK ? -
@mrjj Yes, the native dialog is GTK, but there is no other GTK window to use as parent, right?
-
@mrjj Yes, the native dialog is GTK, but there is no other GTK window to use as parent, right?
@jsulm
Ah in that way. yes that would be hard to have in plain Qt app. -
@mrjj Yes, the native dialog is GTK, but there is no other GTK window to use as parent, right?
wrote on 20 Dec 2017, 09:25 last edited by JonB@jsulm , @mrjj
Ah, now it is beginning to become clearer! I think you're saying:- The native file dialog is a special kind of window: a "GTK" window. (This applies to Linux/X11? Ubuntu? Unity desktop only?)
- It would like another GTK window as its parent.
- But the Qt window which is its parent in
QFileDialog
is not a GTK window. - So the code passes
0
/NULL
for the parent, and that causes the warning.
Right?
-
@jsulm , @mrjj
Ah, now it is beginning to become clearer! I think you're saying:- The native file dialog is a special kind of window: a "GTK" window. (This applies to Linux/X11? Ubuntu? Unity desktop only?)
- It would like another GTK window as its parent.
- But the Qt window which is its parent in
QFileDialog
is not a GTK window. - So the code passes
0
/NULL
for the parent, and that causes the warning.
Right?
@JonB Yes, if you use native dialogs on Linux then Qt simply uses GTK dialogs (GTK is isn't related to Unity, see https://www.gtk.org/). Yes, as GTK does not know anything about Qt it is not possible to pass a parent to GTK dialogs from a Qt app.
-
@JonB Yes, if you use native dialogs on Linux then Qt simply uses GTK dialogs (GTK is isn't related to Unity, see https://www.gtk.org/). Yes, as GTK does not know anything about Qt it is not possible to pass a parent to GTK dialogs from a Qt app.
1/12