diff options
| author | Lassebq <lassebq.mine@gmail.com> | 2023-10-15 13:00:14 +0300 | 
|---|---|---|
| committer | Geronymos <gero@gmx.de> | 2023-10-16 17:14:36 +0200 | 
| commit | b9be0581e48c9adcc0b4f19be31e1df511555fd5 (patch) | |
| tree | a21fd34e1e0aff91a481fa57f3b47926c4455911 | |
| parent | f807b553a31322a4d5269e7c532be96fa51acb92 (diff) | |
Clean up last commit
| -rw-r--r-- | README.md | 1 | ||||
| -rw-r--r-- | dicons.c | 38 | 
2 files changed, 19 insertions, 20 deletions
| @@ -9,6 +9,7 @@  - [X] Start default application for the active file  - [X] Update the Icons on changes to the directory (added/removed files)  - [X] Drag and Drop Files from/to the Desktop +- [X] Launching Apps from the Desktop  - [ ] Multi-Monitor Support  - [ ] Thumbnails for Images/Documents  - [ ] Sort Rows of List Store based on Name/Type/Date @@ -43,32 +43,29 @@ void append_row_from_file(GtkListStore *store, GFile *file)  {      GtkTreeIter iter;      GFileInfo *file_info; +    GdkPixbuf *pixbuf; +    GAppInfo *app;      const gchar *display_name = NULL; -    GdkPixbuf *pixbuf = NULL; +    GdkPixbuf *icon = NULL;      GKeyFile *keyfile = g_key_file_new ();      file_info = g_file_query_info(file, "standard::*,ownser::user", 0, 0, 0);      if (g_key_file_load_from_file (keyfile, g_file_get_path(file), G_KEY_FILE_NONE, NULL))      { -        GAppInfo* app = (GAppInfo*)g_desktop_app_info_new_from_keyfile (keyfile); -        if(app) { +        app = (GAppInfo*)g_desktop_app_info_new_from_keyfile (keyfile); +        if (app) {              display_name = g_app_info_get_display_name(app); -            pixbuf = gtk_icon_info_load_icon( -                    gtk_icon_theme_lookup_by_gicon( -                        theme, -                        g_app_info_get_icon(app), -                        48, 0), 0); +            icon = g_app_info_get_icon(app);          }      } -    if(!display_name) +    if (!display_name)          display_name = g_file_info_get_display_name(file_info); -    if(!pixbuf) -        pixbuf = gtk_icon_info_load_icon( -                gtk_icon_theme_lookup_by_gicon( -                    theme, -                    g_file_info_get_icon(file_info), -                    48, 0), 0); +    if (!icon) +        icon = g_file_info_get_icon(file_info); + +    pixbuf = gtk_icon_info_load_icon( +            gtk_icon_theme_lookup_by_gicon(theme, icon, 48, 0), 0);      gtk_list_store_append(store, &iter);      gtk_list_store_set(store, &iter, @@ -171,19 +168,20 @@ static GtkListStore *create_desktop_list(void)      return GTK_LIST_STORE(store);  } -static void launch_desktop_shortcut(GFile *desktop_file) { +static void launch_default_or_app_for_file(GFile *desktop_file) { +    GAppInfo *app;      GKeyFile *keyfile = g_key_file_new ();      if (g_key_file_load_from_file (keyfile, g_file_get_path(desktop_file), G_KEY_FILE_NONE, NULL))      { -        GAppInfo* app = (GAppInfo*)g_desktop_app_info_new_from_keyfile (keyfile); -        if(app) { +        app = (GAppInfo*)g_desktop_app_info_new_from_keyfile (keyfile); +        if (app) {              GAppLaunchContext* app_context = g_app_launch_context_new ();              g_app_info_launch(app, NULL, app_context, NULL);              g_clear_object (&app_context);              return;          }      } -    // Not a .desktop, trying xdg open +    // Not a .desktop, falling back to xdg open      char* file_uri = g_file_get_uri(desktop_file);      g_app_info_launch_default_for_uri(file_uri, 0, 0);  } @@ -199,7 +197,7 @@ static void activate_cb(GtkIconView *icon_view, GtkTreePath *tree_path, gpointer      gtk_tree_model_get (GTK_TREE_MODEL (store), &iter, COL_FILE, &file, -1); -    launch_desktop_shortcut(file); +    launch_default_or_app_for_file(file);  }  static void activate (GtkApplication* app, gpointer user_data) | 
