Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

[bug] Dialog plugin causing Aborted (core dumped) on Linux when exiting the app #2255

Closed
SergeFan opened this issue Jan 3, 2025 · 9 comments
Labels
bug Something isn't working platform: linux Linux specific issues plugin: dialog

Comments

@SergeFan
Copy link

SergeFan commented Jan 3, 2025

Describe the bug

As the title implied, using the tauri dialog plugin to open a file system dialog will cause Aborted (core dumped) when exiting the app. This seems to only happen to Linux.

Reproduction

This a code snip from my project, I have a button from frontend to trigger this command and it will open the file select dialog.

use directories::UserDirs;
use tauri_plugin_dialog::DialogExt;

#[tauri::command]
async fn select_path(app_handle: tauri::AppHandle) -> String {
    if let Some(user_dirs) = UserDirs::new() {
        let file_path = app_handle
            .dialog()
            .file()
            .set_directory(user_dirs.home_dir())
            .blocking_pick_folder();

...

#[cfg_attr(mobile, tauri::mobile_entry_point)]
pub fn run() {
    tauri::Builder::default()
        .plugin(tauri_plugin_dialog::init())
        .plugin(tauri_plugin_fs::init())
        .plugin(tauri_plugin_shell::init())
        .invoke_handler(tauri::generate_handler![
            ...
            select_path,
            ...
        ])
        .run(tauri::generate_context!())
        .expect("error while running tauri application");
}

If I don't open the dialog and exit the app, it will close normally. But if I open the dialog (even just close the dialog and select nothing), it will give the Aborted (core dumped) error on exiting the app.

Aborted (core dumped)

Expected behavior

Opening file select dialog should not causing any core dumped error.

Full tauri info output

[✔] Environment
    - OS: Manjaro 24.2.1 x86_64 (X64)
    ✔ webkit2gtk-4.1: 2.46.4
    ✔ rsvg2: 2.59.2
    ✔ rustc: 1.83.0 (90b35a623 2024-11-26)
    ✔ cargo: 1.83.0 (5ffbef321 2024-10-29)
    ✔ rustup: 1.27.1 (2024-05-07)
    ✔ Rust toolchain: stable-x86_64-unknown-linux-gnu (environment override by RUSTUP_TOOLCHAIN)
    - node: 23.4.0
    - pnpm: 9.12.3
    - yarn: 1.22.22
    - npm: 10.9.2

[-] Packages
    - tauri 🦀: 2.1.1
    - tauri-build 🦀: 2.0.3
    - wry 🦀: 0.47.2
    - tao 🦀: 0.30.8
    - tauri-cli 🦀: 2.0.4

[-] Plugins
    - tauri-plugin-shell 🦀: 2.2.0
    - tauri-plugin-fs 🦀: 2.2.0
    - tauri-plugin-dialog 🦀: 2.2.0

[-] App
    - build-type: bundle
    - CSP: unset
    - frontendDist: ../dist
    - devUrl: http://localhost:1420/

Stack trace

No response

Additional context

No response

@TheComputerGuy96
Copy link

I get that behavior when making a dialog command function async (this also happens with rfd's GTK 3 backend which the Dialog plugin uses on Linux so maybe it should be reported upstream?)

But if I don't make it async then the whole program hangs (which could be the same issue as PolyMeilex/rfd#198)

@SergeFan
Copy link
Author

SergeFan commented Jan 4, 2025

@TheComputerGuy96

I have to use async since I'm using the blocking_pick_folder() and according to the doc this cannot be use on the main thread. As you mentioned the whole program hangs if I remove async.

And I test rfd's file pick dialog, both sync and async one with tokio, they work normally. But rfd with tauri, core dumped.

@TheComputerGuy96
Copy link

And I test rfd's file pick dialog, both sync and async one with tokio, they work normally.

I think that's because rfd uses the xdg-portal backend by default (it's in the default features) instead of gtk3 that tauri_plugin_dialog explicitly specifies in its rfd dependency

TheComputerGuy96 added a commit to TheComputerGuy96/arnis that referenced this issue Jan 6, 2025
The GTK 3 backend of rfd is relatively problematic (it causes
a whole app freeze when the command function isn't async and
a SIGABRT on app exit when it is async: tauri-apps/plugins-workspace#2255)
so use the better-working xdg-portal backend instead (this will
also help with Flatpak compatibility)

This also removes the unused tauri-plugin-dialog dependency
(which conflicts with our rfd features)
TheComputerGuy96 added a commit to TheComputerGuy96/arnis that referenced this issue Jan 6, 2025
The GTK 3 backend of rfd is relatively problematic (it causes
a whole app freeze when the command function isn't async and
a SIGABRT on app exit when it is async: tauri-apps/plugins-workspace#2255)
so use the better-working xdg-portal backend instead (this will
also help with Flatpak compatibility)

This also removes the unused tauri-plugin-dialog dependency
(which conflicts with our rfd features)
@SergeFan
Copy link
Author

SergeFan commented Jan 8, 2025

@TheComputerGuy96

I actually disabled default features in my cargo.toml.

rfd = {version = "0.15", default-features = false, features = ["gtk3"]}

And this is what I have tried, they all exits normally. (Even on Wayland session, I will metion at below.)

# main.rs

fn main() {
    # Async with std
    async_std::task::block_on(rfd::AsyncFileDialog::new().pick_folder());

    # Sync
    rfd::FileDialog::new().pick_folder();
}

#[tokio::main]
async fn main() {
    # Async with tokio
    rfd::AsyncFileDialog::new().pick_folder().await;
}

I think that's because rfd uses the xdg-portal backend by default (it's in the default features) instead of gtk3 that tauri_plugin_dialog explicitly specifies in its rfd dependency

Well I also tired X11 today and my app exited normally, so this error seems only happen to Wayland. Just asking, are you using Wayland session?

@FabianLars
Copy link
Member

Your example code is not a good comparison imo. The 2 things that come to mind are that 1) Tauri also spawns a gtk event loop (which rfd does internally as well) and 2) Tauri exits via std::process::exit so rfd's Drop implementation does not run.

At first i thought 1) is the issue but after a bit of testing it seems like it's 2) and if rfd could expose a way to shutdown the thread at runtime we could fix this issue here.

I can't think of a good approach there though (in my testing i exposed a global static AtomicBool in rfd that i could change from iniside RunEvent::Exit) so maybe it makes more sense to test out the xdg portal implementation. It's file picker should work well enough for us, and imo it's fair to require zenity for the message dialogs. The less we directly depend on gtk the better imo. We're slowly moving away from it in tray-icon and if we end up completely replacing webkitgtk in favor of cef (instead of offering both) we could even get rid of gtk for the whole window.

@TheComputerGuy96
Copy link

if we end up completely replacing webkitgtk in favor of cef

I don't think this is a good idea right now though: chromiumembedded/cef#2804

@FabianLars
Copy link
Member

I don't think this issue is that relevant for us. Currently the AppImage is our main distribution format and it also has to force x11 to prevent gtk crashes. Also, i'm so tired of complains about webkitgtk that i wouldn't mind just getting rid of all our own windowing and let cef do it itself 😂
Our cef integration will take a bit of time anyway so this doesn't really matter in this discussion so let's keep it out of here.

@SergeFan
Copy link
Author

I did a dependency update today, and the error was gone. Not sure which package fixed it. Maybe tauri v2.2.2.

Updating crates.io index
     Locking 35 packages to latest compatible versions
    Updating bitflags v2.6.0 -> v2.7.0
    Updating cargo_toml v0.17.2 -> v0.21.0
    Updating cc v1.2.7 -> v1.2.9
    Updating js-sys v0.3.76 -> v0.3.77
    Updating leptos_i18n v0.5.3 -> v0.5.5
    Updating leptos_i18n_macro v0.5.3 -> v0.5.5
    Updating leptos_i18n_parser v0.5.3 -> v0.5.5
    Updating log v0.4.22 -> v0.4.25
    Updating miniz_oxide v0.8.2 -> v0.8.3
    Updating prettyplease v0.2.27 -> v0.2.29
    Updating proc-macro2 v1.0.92 -> v1.0.93
      Adding rustversion v1.0.19
    Updating syn v2.0.95 -> v2.0.96
    Updating tauri v2.2.0 -> v2.2.2
    Updating tauri-build v2.0.4 -> v2.0.5
    Updating thiserror v2.0.9 -> v2.0.11
    Updating thiserror-impl v2.0.9 -> v2.0.11
    Updating tokio v1.42.0 -> v1.43.0
    Updating tokio-macros v2.4.0 -> v2.5.0
    Updating uuid v1.11.0 -> v1.12.0
    Updating wasm-bindgen v0.2.99 -> v0.2.100
    Updating wasm-bindgen-backend v0.2.99 -> v0.2.100
    Updating wasm-bindgen-futures v0.4.49 -> v0.4.50
    Updating wasm-bindgen-macro v0.2.99 -> v0.2.100
    Updating wasm-bindgen-macro-support v0.2.99 -> v0.2.100
    Updating wasm-bindgen-shared v0.2.99 -> v0.2.100
    Updating web-sys v0.3.76 -> v0.3.77
    Updating winnow v0.6.22 -> v0.6.24
    Updating wry v0.48.0 -> v0.48.1
    Updating zbus v5.2.0 -> v5.3.0
    Updating zbus_macros v5.2.0 -> v5.3.0
    Updating zbus_names v4.1.0 -> v4.1.1
    Updating zvariant v5.1.0 -> v5.2.0
    Updating zvariant_derive v5.1.0 -> v5.2.0
    Updating zvariant_utils v3.0.2 -> v3.1.0

@FabianLars
Copy link
Member

That makes no sense to me but i can't reproduce it anymore either. With this i will close this issue but of course will re-open once someone spots it again.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
bug Something isn't working platform: linux Linux specific issues plugin: dialog
Projects
None yet
Development

No branches or pull requests

3 participants