1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
|
/*
* This file is part of gedit
*
* Copyright (C) 2005 - Paolo Maggi
* Copyright (C) 2014 - Paolo Borelli
* Copyright (C) 2014 - Jesse van den Kieboom
* Copyright (C) 2022 - Sébastien Wilmet
*
* This program is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation; either version 2 of the License, or
* (at your option) any later version.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with this program; if not, see <http://www.gnu.org/licenses/>.
*/
#include "gedit-recent.h"
void
gedit_recent_add_document (GeditDocument *document)
{
TeplFile *file;
GFile *location;
GtkRecentManager *recent_manager;
GtkRecentData *recent_data;
gchar *uri;
g_return_if_fail (GEDIT_IS_DOCUMENT (document));
file = tepl_buffer_get_file (TEPL_BUFFER (document));
location = tepl_file_get_location (file);
if (location == NULL)
{
return;
}
recent_manager = gtk_recent_manager_get_default ();
/* Ensures to initialize the whole struct to 0's. Useful if the struct
* is extended.
*/
recent_data = g_new0 (GtkRecentData, 1);
/* We use gtk_recent_manager_add_full() because GeditDocument's mime
* type is more accurate. The other fields are normally set to the same
* values as what gtk_recent_manager_add_item() does.
*/
recent_data->mime_type = gedit_document_get_mime_type (document);
recent_data->app_name = (gchar *) g_get_application_name ();
recent_data->app_exec = g_strjoin (" ", g_get_prgname (), "%u", NULL);
uri = g_file_get_uri (location);
if (!gtk_recent_manager_add_full (recent_manager, uri, recent_data))
{
g_warning ("Failed to add uri '%s' to the recent manager.", uri);
}
g_free (recent_data->mime_type);
g_free (recent_data->app_exec);
g_free (recent_data);
g_free (uri);
}
/* If a file is local, chances are that if load/save fails the file has been
* removed and the failure is permanent so we remove it from the list of recent
* files. For remote files the failure may be just transitory and we keep the
* file in the list.
*
* FIXME: for files coming from external disks, USB keys etc, if the external
* storage device is not mounted, do not remove the file from the list. On the
* other hand, if the external storage device is mounted and the file isn't
* there, remove it from the list.
*
* FIXME: for remote files, perhaps do the same as for external storage devices,
* IF the connection to the server succeeds (the directory is there).
*
* FIXME: for the above FIXMEs, we should probably rely (in part) on the GError
* we receive.
* And if it was a file loading, a useful information to have is whether the
* file was opened from the list of recent files. If it was *not*, the user can
* also just navigate again through the file hierarchy to re-open it later if
* the file comes back.
*
* IDEA: or just never remove files from the recent list, and call it the
* Recent History or something like that.
*/
void
gedit_recent_remove_if_local (GFile *location)
{
g_return_if_fail (G_IS_FILE (location));
if (g_file_has_uri_scheme (location, "file"))
{
GtkRecentManager *recent_manager;
gchar *uri;
recent_manager = gtk_recent_manager_get_default ();
uri = g_file_get_uri (location);
gtk_recent_manager_remove_item (recent_manager, uri, NULL);
g_free (uri);
}
}
/* ex:set ts=8 noet: */
|