annotate src/filefilter.c @ 586:905688aa2317

split filelist.c to filefilter.c and filedata.c
author nadvornik
date Mon, 05 May 2008 19:11:12 +0000
parents src/filelist.c@9dc0513837b5
children 5963c394ba53
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
1
b3e0e515fabf Initial revision
gqview
parents:
diff changeset
1 /*
196
f6e307c7bad6 rename GQview -> Geeqie over the code
nadvornik
parents: 188
diff changeset
2 * Geeqie
79
528e3432e0c0 Thu Oct 19 07:23:37 2006 John Ellis <johne@verizon.net>
gqview
parents: 53
diff changeset
3 * (C) 2006 John Ellis
475
48c8e49b571c updated copyright in source files
nadvornik
parents: 442
diff changeset
4 * Copyright (C) 2008 The Geeqie Team
1
b3e0e515fabf Initial revision
gqview
parents:
diff changeset
5 *
b3e0e515fabf Initial revision
gqview
parents:
diff changeset
6 * Author: John Ellis
b3e0e515fabf Initial revision
gqview
parents:
diff changeset
7 *
9
d907d608745f Sync to GQview 1.5.9 release.
gqview
parents: 3
diff changeset
8 * This software is released under the GNU General Public License (GNU GPL).
d907d608745f Sync to GQview 1.5.9 release.
gqview
parents: 3
diff changeset
9 * Please read the included file COPYING for more information.
d907d608745f Sync to GQview 1.5.9 release.
gqview
parents: 3
diff changeset
10 * This software comes with no warranty of any kind, use at your own risk!
1
b3e0e515fabf Initial revision
gqview
parents:
diff changeset
11 */
b3e0e515fabf Initial revision
gqview
parents:
diff changeset
12
b3e0e515fabf Initial revision
gqview
parents:
diff changeset
13
281
9995c5fb202a gqview.h -> main.h
zas_
parents: 277
diff changeset
14 #include "main.h"
586
905688aa2317 split filelist.c to filefilter.c and filedata.c
nadvornik
parents: 576
diff changeset
15 #include "filefilter.h"
1
b3e0e515fabf Initial revision
gqview
parents:
diff changeset
16
9
d907d608745f Sync to GQview 1.5.9 release.
gqview
parents: 3
diff changeset
17 #include "cache.h"
507
135570a8bd96 Move debug macros from main.h to new debug.h.
zas_
parents: 506
diff changeset
18 #include "debug.h"
9
d907d608745f Sync to GQview 1.5.9 release.
gqview
parents: 3
diff changeset
19 #include "rcfile.h"
307
667e49f52168 Move secure save code to its own files: secure_save.{c,h}.
zas_
parents: 283
diff changeset
20 #include "secure_save.h"
79
528e3432e0c0 Thu Oct 19 07:23:37 2006 John Ellis <johne@verizon.net>
gqview
parents: 53
diff changeset
21 #include "thumb_standard.h"
9
d907d608745f Sync to GQview 1.5.9 release.
gqview
parents: 3
diff changeset
22 #include "ui_fileops.h"
1
b3e0e515fabf Initial revision
gqview
parents:
diff changeset
23
b3e0e515fabf Initial revision
gqview
parents:
diff changeset
24
b3e0e515fabf Initial revision
gqview
parents:
diff changeset
25 /*
b3e0e515fabf Initial revision
gqview
parents:
diff changeset
26 *-----------------------------------------------------------------------------
b3e0e515fabf Initial revision
gqview
parents:
diff changeset
27 * file filtering
b3e0e515fabf Initial revision
gqview
parents:
diff changeset
28 *-----------------------------------------------------------------------------
b3e0e515fabf Initial revision
gqview
parents:
diff changeset
29 */
b3e0e515fabf Initial revision
gqview
parents:
diff changeset
30
9
d907d608745f Sync to GQview 1.5.9 release.
gqview
parents: 3
diff changeset
31 static GList *filter_list = NULL;
d907d608745f Sync to GQview 1.5.9 release.
gqview
parents: 3
diff changeset
32 static GList *extension_list = NULL;
145
8be2cc687304 fixed grouping sidecar files and made it configurable via config file
nadvornik
parents: 143
diff changeset
33 static GList *sidecar_ext_list = NULL;
9
d907d608745f Sync to GQview 1.5.9 release.
gqview
parents: 3
diff changeset
34
212
c7021159079d differentiate among normal image, raw image and metadata
nadvornik
parents: 202
diff changeset
35 static GList *file_class_extension_list[FILE_FORMAT_CLASSES];
c7021159079d differentiate among normal image, raw image and metadata
nadvornik
parents: 202
diff changeset
36
c7021159079d differentiate among normal image, raw image and metadata
nadvornik
parents: 202
diff changeset
37
9
d907d608745f Sync to GQview 1.5.9 release.
gqview
parents: 3
diff changeset
38 gint ishidden(const gchar *name)
1
b3e0e515fabf Initial revision
gqview
parents:
diff changeset
39 {
b3e0e515fabf Initial revision
gqview
parents:
diff changeset
40 if (name[0] != '.') return FALSE;
b3e0e515fabf Initial revision
gqview
parents:
diff changeset
41 if (name[1] == '\0' || (name[1] == '.' && name[2] == '\0')) return FALSE;
b3e0e515fabf Initial revision
gqview
parents:
diff changeset
42 return TRUE;
b3e0e515fabf Initial revision
gqview
parents:
diff changeset
43 }
b3e0e515fabf Initial revision
gqview
parents:
diff changeset
44
9
d907d608745f Sync to GQview 1.5.9 release.
gqview
parents: 3
diff changeset
45 static FilterEntry *filter_entry_new(const gchar *key, const gchar *description,
212
c7021159079d differentiate among normal image, raw image and metadata
nadvornik
parents: 202
diff changeset
46 const gchar *extensions, FileFormatClass file_class, gint enabled)
9
d907d608745f Sync to GQview 1.5.9 release.
gqview
parents: 3
diff changeset
47 {
d907d608745f Sync to GQview 1.5.9 release.
gqview
parents: 3
diff changeset
48 FilterEntry *fe;
d907d608745f Sync to GQview 1.5.9 release.
gqview
parents: 3
diff changeset
49
d907d608745f Sync to GQview 1.5.9 release.
gqview
parents: 3
diff changeset
50 fe = g_new0(FilterEntry, 1);
d907d608745f Sync to GQview 1.5.9 release.
gqview
parents: 3
diff changeset
51 fe->key = g_strdup(key);
d907d608745f Sync to GQview 1.5.9 release.
gqview
parents: 3
diff changeset
52 fe->description = g_strdup(description);
d907d608745f Sync to GQview 1.5.9 release.
gqview
parents: 3
diff changeset
53 fe->extensions = g_strdup(extensions);
d907d608745f Sync to GQview 1.5.9 release.
gqview
parents: 3
diff changeset
54 fe->enabled = enabled;
212
c7021159079d differentiate among normal image, raw image and metadata
nadvornik
parents: 202
diff changeset
55 fe->file_class = file_class;
442
4b2d7f9af171 Big whitespaces cleanup:
zas_
parents: 425
diff changeset
56
9
d907d608745f Sync to GQview 1.5.9 release.
gqview
parents: 3
diff changeset
57 return fe;
d907d608745f Sync to GQview 1.5.9 release.
gqview
parents: 3
diff changeset
58 }
d907d608745f Sync to GQview 1.5.9 release.
gqview
parents: 3
diff changeset
59
d907d608745f Sync to GQview 1.5.9 release.
gqview
parents: 3
diff changeset
60 static void filter_entry_free(FilterEntry *fe)
d907d608745f Sync to GQview 1.5.9 release.
gqview
parents: 3
diff changeset
61 {
d907d608745f Sync to GQview 1.5.9 release.
gqview
parents: 3
diff changeset
62 if (!fe) return;
d907d608745f Sync to GQview 1.5.9 release.
gqview
parents: 3
diff changeset
63
d907d608745f Sync to GQview 1.5.9 release.
gqview
parents: 3
diff changeset
64 g_free(fe->key);
d907d608745f Sync to GQview 1.5.9 release.
gqview
parents: 3
diff changeset
65 g_free(fe->description);
d907d608745f Sync to GQview 1.5.9 release.
gqview
parents: 3
diff changeset
66 g_free(fe->extensions);
d907d608745f Sync to GQview 1.5.9 release.
gqview
parents: 3
diff changeset
67 g_free(fe);
d907d608745f Sync to GQview 1.5.9 release.
gqview
parents: 3
diff changeset
68 }
d907d608745f Sync to GQview 1.5.9 release.
gqview
parents: 3
diff changeset
69
d907d608745f Sync to GQview 1.5.9 release.
gqview
parents: 3
diff changeset
70 GList *filter_get_list(void)
d907d608745f Sync to GQview 1.5.9 release.
gqview
parents: 3
diff changeset
71 {
d907d608745f Sync to GQview 1.5.9 release.
gqview
parents: 3
diff changeset
72 return filter_list;
d907d608745f Sync to GQview 1.5.9 release.
gqview
parents: 3
diff changeset
73 }
d907d608745f Sync to GQview 1.5.9 release.
gqview
parents: 3
diff changeset
74
d907d608745f Sync to GQview 1.5.9 release.
gqview
parents: 3
diff changeset
75 void filter_remove_entry(FilterEntry *fe)
d907d608745f Sync to GQview 1.5.9 release.
gqview
parents: 3
diff changeset
76 {
d907d608745f Sync to GQview 1.5.9 release.
gqview
parents: 3
diff changeset
77 if (!g_list_find(filter_list, fe)) return;
d907d608745f Sync to GQview 1.5.9 release.
gqview
parents: 3
diff changeset
78
d907d608745f Sync to GQview 1.5.9 release.
gqview
parents: 3
diff changeset
79 filter_list = g_list_remove(filter_list, fe);
d907d608745f Sync to GQview 1.5.9 release.
gqview
parents: 3
diff changeset
80 filter_entry_free(fe);
d907d608745f Sync to GQview 1.5.9 release.
gqview
parents: 3
diff changeset
81 }
d907d608745f Sync to GQview 1.5.9 release.
gqview
parents: 3
diff changeset
82
d907d608745f Sync to GQview 1.5.9 release.
gqview
parents: 3
diff changeset
83 static gint filter_key_exists(const gchar *key)
d907d608745f Sync to GQview 1.5.9 release.
gqview
parents: 3
diff changeset
84 {
d907d608745f Sync to GQview 1.5.9 release.
gqview
parents: 3
diff changeset
85 GList *work;
d907d608745f Sync to GQview 1.5.9 release.
gqview
parents: 3
diff changeset
86
d907d608745f Sync to GQview 1.5.9 release.
gqview
parents: 3
diff changeset
87 if (!key) return FALSE;
d907d608745f Sync to GQview 1.5.9 release.
gqview
parents: 3
diff changeset
88
d907d608745f Sync to GQview 1.5.9 release.
gqview
parents: 3
diff changeset
89 work = filter_list;
d907d608745f Sync to GQview 1.5.9 release.
gqview
parents: 3
diff changeset
90 while (work)
d907d608745f Sync to GQview 1.5.9 release.
gqview
parents: 3
diff changeset
91 {
d907d608745f Sync to GQview 1.5.9 release.
gqview
parents: 3
diff changeset
92 FilterEntry *fe = work->data;
d907d608745f Sync to GQview 1.5.9 release.
gqview
parents: 3
diff changeset
93 work = work->next;
d907d608745f Sync to GQview 1.5.9 release.
gqview
parents: 3
diff changeset
94
d907d608745f Sync to GQview 1.5.9 release.
gqview
parents: 3
diff changeset
95 if (strcmp(fe->key, key) == 0) return TRUE;
d907d608745f Sync to GQview 1.5.9 release.
gqview
parents: 3
diff changeset
96 }
d907d608745f Sync to GQview 1.5.9 release.
gqview
parents: 3
diff changeset
97
d907d608745f Sync to GQview 1.5.9 release.
gqview
parents: 3
diff changeset
98 return FALSE;
d907d608745f Sync to GQview 1.5.9 release.
gqview
parents: 3
diff changeset
99 }
d907d608745f Sync to GQview 1.5.9 release.
gqview
parents: 3
diff changeset
100
212
c7021159079d differentiate among normal image, raw image and metadata
nadvornik
parents: 202
diff changeset
101 void filter_add(const gchar *key, const gchar *description, const gchar *extensions, FileFormatClass file_class, gint enabled)
9
d907d608745f Sync to GQview 1.5.9 release.
gqview
parents: 3
diff changeset
102 {
212
c7021159079d differentiate among normal image, raw image and metadata
nadvornik
parents: 202
diff changeset
103 filter_list = g_list_append(filter_list, filter_entry_new(key, description, extensions, file_class, enabled));
9
d907d608745f Sync to GQview 1.5.9 release.
gqview
parents: 3
diff changeset
104 }
d907d608745f Sync to GQview 1.5.9 release.
gqview
parents: 3
diff changeset
105
212
c7021159079d differentiate among normal image, raw image and metadata
nadvornik
parents: 202
diff changeset
106 void filter_add_unique(const gchar *description, const gchar *extensions, FileFormatClass file_class, gint enabled)
9
d907d608745f Sync to GQview 1.5.9 release.
gqview
parents: 3
diff changeset
107 {
d907d608745f Sync to GQview 1.5.9 release.
gqview
parents: 3
diff changeset
108 gchar *key;
d907d608745f Sync to GQview 1.5.9 release.
gqview
parents: 3
diff changeset
109 gint n;
d907d608745f Sync to GQview 1.5.9 release.
gqview
parents: 3
diff changeset
110
d907d608745f Sync to GQview 1.5.9 release.
gqview
parents: 3
diff changeset
111 key = g_strdup("user0");
d907d608745f Sync to GQview 1.5.9 release.
gqview
parents: 3
diff changeset
112 n = 1;
d907d608745f Sync to GQview 1.5.9 release.
gqview
parents: 3
diff changeset
113 while (filter_key_exists(key))
d907d608745f Sync to GQview 1.5.9 release.
gqview
parents: 3
diff changeset
114 {
d907d608745f Sync to GQview 1.5.9 release.
gqview
parents: 3
diff changeset
115 g_free(key);
d907d608745f Sync to GQview 1.5.9 release.
gqview
parents: 3
diff changeset
116 if (n > 999) return;
d907d608745f Sync to GQview 1.5.9 release.
gqview
parents: 3
diff changeset
117 key = g_strdup_printf("user%d", n);
d907d608745f Sync to GQview 1.5.9 release.
gqview
parents: 3
diff changeset
118 n++;
d907d608745f Sync to GQview 1.5.9 release.
gqview
parents: 3
diff changeset
119 }
d907d608745f Sync to GQview 1.5.9 release.
gqview
parents: 3
diff changeset
120
212
c7021159079d differentiate among normal image, raw image and metadata
nadvornik
parents: 202
diff changeset
121 filter_add(key, description, extensions, file_class, enabled);
9
d907d608745f Sync to GQview 1.5.9 release.
gqview
parents: 3
diff changeset
122 g_free(key);
d907d608745f Sync to GQview 1.5.9 release.
gqview
parents: 3
diff changeset
123 }
d907d608745f Sync to GQview 1.5.9 release.
gqview
parents: 3
diff changeset
124
212
c7021159079d differentiate among normal image, raw image and metadata
nadvornik
parents: 202
diff changeset
125 static void filter_add_if_missing(const gchar *key, const gchar *description, const gchar *extensions, FileFormatClass file_class, gint enabled)
9
d907d608745f Sync to GQview 1.5.9 release.
gqview
parents: 3
diff changeset
126 {
d907d608745f Sync to GQview 1.5.9 release.
gqview
parents: 3
diff changeset
127 GList *work;
d907d608745f Sync to GQview 1.5.9 release.
gqview
parents: 3
diff changeset
128
d907d608745f Sync to GQview 1.5.9 release.
gqview
parents: 3
diff changeset
129 if (!key) return;
d907d608745f Sync to GQview 1.5.9 release.
gqview
parents: 3
diff changeset
130
d907d608745f Sync to GQview 1.5.9 release.
gqview
parents: 3
diff changeset
131 work = filter_list;
d907d608745f Sync to GQview 1.5.9 release.
gqview
parents: 3
diff changeset
132 while (work)
d907d608745f Sync to GQview 1.5.9 release.
gqview
parents: 3
diff changeset
133 {
d907d608745f Sync to GQview 1.5.9 release.
gqview
parents: 3
diff changeset
134 FilterEntry *fe = work->data;
d907d608745f Sync to GQview 1.5.9 release.
gqview
parents: 3
diff changeset
135 work = work->next;
212
c7021159079d differentiate among normal image, raw image and metadata
nadvornik
parents: 202
diff changeset
136 if (fe->key && strcmp(fe->key, key) == 0)
c7021159079d differentiate among normal image, raw image and metadata
nadvornik
parents: 202
diff changeset
137 {
c7021159079d differentiate among normal image, raw image and metadata
nadvornik
parents: 202
diff changeset
138 if (fe->file_class == FORMAT_CLASS_UNKNOWN)
c7021159079d differentiate among normal image, raw image and metadata
nadvornik
parents: 202
diff changeset
139 fe->file_class = file_class; /* for compatibility */
c7021159079d differentiate among normal image, raw image and metadata
nadvornik
parents: 202
diff changeset
140 return;
c7021159079d differentiate among normal image, raw image and metadata
nadvornik
parents: 202
diff changeset
141 }
9
d907d608745f Sync to GQview 1.5.9 release.
gqview
parents: 3
diff changeset
142 }
d907d608745f Sync to GQview 1.5.9 release.
gqview
parents: 3
diff changeset
143
212
c7021159079d differentiate among normal image, raw image and metadata
nadvornik
parents: 202
diff changeset
144 filter_add(key, description, extensions, file_class, enabled);
9
d907d608745f Sync to GQview 1.5.9 release.
gqview
parents: 3
diff changeset
145 }
d907d608745f Sync to GQview 1.5.9 release.
gqview
parents: 3
diff changeset
146
d907d608745f Sync to GQview 1.5.9 release.
gqview
parents: 3
diff changeset
147 void filter_reset(void)
1
b3e0e515fabf Initial revision
gqview
parents:
diff changeset
148 {
b3e0e515fabf Initial revision
gqview
parents:
diff changeset
149 GList *work;
9
d907d608745f Sync to GQview 1.5.9 release.
gqview
parents: 3
diff changeset
150
d907d608745f Sync to GQview 1.5.9 release.
gqview
parents: 3
diff changeset
151 work = filter_list;
d907d608745f Sync to GQview 1.5.9 release.
gqview
parents: 3
diff changeset
152 while (work)
d907d608745f Sync to GQview 1.5.9 release.
gqview
parents: 3
diff changeset
153 {
d907d608745f Sync to GQview 1.5.9 release.
gqview
parents: 3
diff changeset
154 FilterEntry *fe = work->data;
d907d608745f Sync to GQview 1.5.9 release.
gqview
parents: 3
diff changeset
155 work = work->next;
d907d608745f Sync to GQview 1.5.9 release.
gqview
parents: 3
diff changeset
156 filter_entry_free(fe);
d907d608745f Sync to GQview 1.5.9 release.
gqview
parents: 3
diff changeset
157 }
d907d608745f Sync to GQview 1.5.9 release.
gqview
parents: 3
diff changeset
158
d907d608745f Sync to GQview 1.5.9 release.
gqview
parents: 3
diff changeset
159 g_list_free(filter_list);
d907d608745f Sync to GQview 1.5.9 release.
gqview
parents: 3
diff changeset
160 filter_list = NULL;
d907d608745f Sync to GQview 1.5.9 release.
gqview
parents: 3
diff changeset
161 }
d907d608745f Sync to GQview 1.5.9 release.
gqview
parents: 3
diff changeset
162
d907d608745f Sync to GQview 1.5.9 release.
gqview
parents: 3
diff changeset
163 void filter_add_defaults(void)
d907d608745f Sync to GQview 1.5.9 release.
gqview
parents: 3
diff changeset
164 {
d907d608745f Sync to GQview 1.5.9 release.
gqview
parents: 3
diff changeset
165 GSList *list, *work;
d907d608745f Sync to GQview 1.5.9 release.
gqview
parents: 3
diff changeset
166
d907d608745f Sync to GQview 1.5.9 release.
gqview
parents: 3
diff changeset
167 list = gdk_pixbuf_get_formats();
d907d608745f Sync to GQview 1.5.9 release.
gqview
parents: 3
diff changeset
168 work = list;
d907d608745f Sync to GQview 1.5.9 release.
gqview
parents: 3
diff changeset
169 while (work)
d907d608745f Sync to GQview 1.5.9 release.
gqview
parents: 3
diff changeset
170 {
d907d608745f Sync to GQview 1.5.9 release.
gqview
parents: 3
diff changeset
171 GdkPixbufFormat *format;
d907d608745f Sync to GQview 1.5.9 release.
gqview
parents: 3
diff changeset
172 gchar *name;
d907d608745f Sync to GQview 1.5.9 release.
gqview
parents: 3
diff changeset
173 gchar *desc;
d907d608745f Sync to GQview 1.5.9 release.
gqview
parents: 3
diff changeset
174 gchar **extensions;
d907d608745f Sync to GQview 1.5.9 release.
gqview
parents: 3
diff changeset
175 GString *filter = NULL;
d907d608745f Sync to GQview 1.5.9 release.
gqview
parents: 3
diff changeset
176 gint i;
442
4b2d7f9af171 Big whitespaces cleanup:
zas_
parents: 425
diff changeset
177
9
d907d608745f Sync to GQview 1.5.9 release.
gqview
parents: 3
diff changeset
178 format = work->data;
d907d608745f Sync to GQview 1.5.9 release.
gqview
parents: 3
diff changeset
179 work = work->next;
d907d608745f Sync to GQview 1.5.9 release.
gqview
parents: 3
diff changeset
180
d907d608745f Sync to GQview 1.5.9 release.
gqview
parents: 3
diff changeset
181 name = gdk_pixbuf_format_get_name(format);
d907d608745f Sync to GQview 1.5.9 release.
gqview
parents: 3
diff changeset
182 desc = gdk_pixbuf_format_get_description(format);
d907d608745f Sync to GQview 1.5.9 release.
gqview
parents: 3
diff changeset
183 extensions = gdk_pixbuf_format_get_extensions(format);
d907d608745f Sync to GQview 1.5.9 release.
gqview
parents: 3
diff changeset
184
d907d608745f Sync to GQview 1.5.9 release.
gqview
parents: 3
diff changeset
185 i = 0;
d907d608745f Sync to GQview 1.5.9 release.
gqview
parents: 3
diff changeset
186 while (extensions[i])
d907d608745f Sync to GQview 1.5.9 release.
gqview
parents: 3
diff changeset
187 {
d907d608745f Sync to GQview 1.5.9 release.
gqview
parents: 3
diff changeset
188 if (!filter)
d907d608745f Sync to GQview 1.5.9 release.
gqview
parents: 3
diff changeset
189 {
d907d608745f Sync to GQview 1.5.9 release.
gqview
parents: 3
diff changeset
190 filter = g_string_new(".");
d907d608745f Sync to GQview 1.5.9 release.
gqview
parents: 3
diff changeset
191 filter = g_string_append(filter, extensions[i]);
d907d608745f Sync to GQview 1.5.9 release.
gqview
parents: 3
diff changeset
192 }
d907d608745f Sync to GQview 1.5.9 release.
gqview
parents: 3
diff changeset
193 else
d907d608745f Sync to GQview 1.5.9 release.
gqview
parents: 3
diff changeset
194 {
d907d608745f Sync to GQview 1.5.9 release.
gqview
parents: 3
diff changeset
195 filter = g_string_append(filter, ";.");
d907d608745f Sync to GQview 1.5.9 release.
gqview
parents: 3
diff changeset
196 filter = g_string_append(filter, extensions[i]);
d907d608745f Sync to GQview 1.5.9 release.
gqview
parents: 3
diff changeset
197 }
d907d608745f Sync to GQview 1.5.9 release.
gqview
parents: 3
diff changeset
198 i++;
d907d608745f Sync to GQview 1.5.9 release.
gqview
parents: 3
diff changeset
199 }
d907d608745f Sync to GQview 1.5.9 release.
gqview
parents: 3
diff changeset
200
506
fc9c8a3e1a8b Handle the newline in DEBUG_N() macro instead of adding one
zas_
parents: 495
diff changeset
201 DEBUG_1("loader reported [%s] [%s] [%s]", name, desc, filter->str);
9
d907d608745f Sync to GQview 1.5.9 release.
gqview
parents: 3
diff changeset
202
212
c7021159079d differentiate among normal image, raw image and metadata
nadvornik
parents: 202
diff changeset
203 filter_add_if_missing(name, desc, filter->str, FORMAT_CLASS_IMAGE, TRUE);
9
d907d608745f Sync to GQview 1.5.9 release.
gqview
parents: 3
diff changeset
204
d907d608745f Sync to GQview 1.5.9 release.
gqview
parents: 3
diff changeset
205 g_free(name);
d907d608745f Sync to GQview 1.5.9 release.
gqview
parents: 3
diff changeset
206 g_free(desc);
d907d608745f Sync to GQview 1.5.9 release.
gqview
parents: 3
diff changeset
207 g_strfreev(extensions);
d907d608745f Sync to GQview 1.5.9 release.
gqview
parents: 3
diff changeset
208 g_string_free(filter, TRUE);
d907d608745f Sync to GQview 1.5.9 release.
gqview
parents: 3
diff changeset
209 }
d907d608745f Sync to GQview 1.5.9 release.
gqview
parents: 3
diff changeset
210 g_slist_free(list);
1
b3e0e515fabf Initial revision
gqview
parents:
diff changeset
211
9
d907d608745f Sync to GQview 1.5.9 release.
gqview
parents: 3
diff changeset
212 /* add defaults even if gdk-pixbuf does not have them, but disabled */
212
c7021159079d differentiate among normal image, raw image and metadata
nadvornik
parents: 202
diff changeset
213 filter_add_if_missing("jpeg", "JPEG group", ".jpg;.jpeg;.jpe", FORMAT_CLASS_IMAGE, FALSE);
c7021159079d differentiate among normal image, raw image and metadata
nadvornik
parents: 202
diff changeset
214 filter_add_if_missing("png", "Portable Network Graphic", ".png", FORMAT_CLASS_IMAGE, FALSE);
c7021159079d differentiate among normal image, raw image and metadata
nadvornik
parents: 202
diff changeset
215 filter_add_if_missing("tiff", "Tiff", ".tif;.tiff", FORMAT_CLASS_IMAGE, FALSE);
c7021159079d differentiate among normal image, raw image and metadata
nadvornik
parents: 202
diff changeset
216 filter_add_if_missing("pnm", "Packed Pixel formats", ".pbm;.pgm;.pnm;.ppm", FORMAT_CLASS_IMAGE, FALSE);
c7021159079d differentiate among normal image, raw image and metadata
nadvornik
parents: 202
diff changeset
217 filter_add_if_missing("gif", "Graphics Interchange Format", ".gif", FORMAT_CLASS_IMAGE, FALSE);
c7021159079d differentiate among normal image, raw image and metadata
nadvornik
parents: 202
diff changeset
218 filter_add_if_missing("xbm", "X bitmap", ".xbm", FORMAT_CLASS_IMAGE, FALSE);
c7021159079d differentiate among normal image, raw image and metadata
nadvornik
parents: 202
diff changeset
219 filter_add_if_missing("xpm", "X pixmap", ".xpm", FORMAT_CLASS_IMAGE, FALSE);
c7021159079d differentiate among normal image, raw image and metadata
nadvornik
parents: 202
diff changeset
220 filter_add_if_missing("bmp", "Bitmap", ".bmp", FORMAT_CLASS_IMAGE, FALSE);
c7021159079d differentiate among normal image, raw image and metadata
nadvornik
parents: 202
diff changeset
221 filter_add_if_missing("ico", "Icon file", ".ico;.cur", FORMAT_CLASS_IMAGE, FALSE);
c7021159079d differentiate among normal image, raw image and metadata
nadvornik
parents: 202
diff changeset
222 filter_add_if_missing("ras", "Raster", ".ras", FORMAT_CLASS_IMAGE, FALSE);
c7021159079d differentiate among normal image, raw image and metadata
nadvornik
parents: 202
diff changeset
223 filter_add_if_missing("svg", "Scalable Vector Graphics", ".svg", FORMAT_CLASS_IMAGE, FALSE);
442
4b2d7f9af171 Big whitespaces cleanup:
zas_
parents: 425
diff changeset
224
202
f95654aeec4b added all possible raw extensions that I could find
nadvornik
parents: 196
diff changeset
225 /* non-image files that might be desirable to show */
212
c7021159079d differentiate among normal image, raw image and metadata
nadvornik
parents: 202
diff changeset
226 filter_add_if_missing("xmp", "XMP sidecar", ".xmp", FORMAT_CLASS_META, TRUE);
43
ee03f36e9e4b Sun May 15 21:40:26 2005 John Ellis <johne@verizon.net>
gqview
parents: 15
diff changeset
227
ee03f36e9e4b Sun May 15 21:40:26 2005 John Ellis <johne@verizon.net>
gqview
parents: 15
diff changeset
228 /* These are the raw camera formats with embedded jpeg/exif.
202
f95654aeec4b added all possible raw extensions that I could find
nadvornik
parents: 196
diff changeset
229 * (see format_raw.c and/or exiv2.cc)
43
ee03f36e9e4b Sun May 15 21:40:26 2005 John Ellis <johne@verizon.net>
gqview
parents: 15
diff changeset
230 */
212
c7021159079d differentiate among normal image, raw image and metadata
nadvornik
parents: 202
diff changeset
231 filter_add_if_missing("arw", "Sony raw format", ".arw;.srf;.sr2", FORMAT_CLASS_RAWIMAGE, TRUE);
c7021159079d differentiate among normal image, raw image and metadata
nadvornik
parents: 202
diff changeset
232 filter_add_if_missing("crw", "Canon raw format", ".crw;.cr2", FORMAT_CLASS_RAWIMAGE, TRUE);
c7021159079d differentiate among normal image, raw image and metadata
nadvornik
parents: 202
diff changeset
233 filter_add_if_missing("kdc", "Kodak raw format", ".kdc;.dcr", FORMAT_CLASS_RAWIMAGE, TRUE);
c7021159079d differentiate among normal image, raw image and metadata
nadvornik
parents: 202
diff changeset
234 filter_add_if_missing("raf", "Fujifilm raw format", ".raf", FORMAT_CLASS_RAWIMAGE, TRUE);
c7021159079d differentiate among normal image, raw image and metadata
nadvornik
parents: 202
diff changeset
235 filter_add_if_missing("mef", "Mamiya raw format", ".mef;.mos", FORMAT_CLASS_RAWIMAGE, TRUE);
c7021159079d differentiate among normal image, raw image and metadata
nadvornik
parents: 202
diff changeset
236 filter_add_if_missing("mrw", "Minolta raw format", ".mrw", FORMAT_CLASS_RAWIMAGE, TRUE);
c7021159079d differentiate among normal image, raw image and metadata
nadvornik
parents: 202
diff changeset
237 filter_add_if_missing("nef", "Nikon raw format", ".nef", FORMAT_CLASS_RAWIMAGE, TRUE);
c7021159079d differentiate among normal image, raw image and metadata
nadvornik
parents: 202
diff changeset
238 filter_add_if_missing("orf", "Olympus raw format", ".orf", FORMAT_CLASS_RAWIMAGE, TRUE);
277
9de0f88b2b91 Add support for some Samsung raw files (.pef).
zas_
parents: 276
diff changeset
239 filter_add_if_missing("pef", "Pentax or Samsung raw format", ".pef;.ptx", FORMAT_CLASS_RAWIMAGE, TRUE);
212
c7021159079d differentiate among normal image, raw image and metadata
nadvornik
parents: 202
diff changeset
240 filter_add_if_missing("dng", "Adobe Digital Negative raw format", ".dng", FORMAT_CLASS_RAWIMAGE, TRUE);
c7021159079d differentiate among normal image, raw image and metadata
nadvornik
parents: 202
diff changeset
241 filter_add_if_missing("x3f", "Sigma raw format", ".x3f", FORMAT_CLASS_RAWIMAGE, TRUE);
c7021159079d differentiate among normal image, raw image and metadata
nadvornik
parents: 202
diff changeset
242 filter_add_if_missing("raw", "Panasonic raw format", ".raw", FORMAT_CLASS_RAWIMAGE, TRUE);
c7021159079d differentiate among normal image, raw image and metadata
nadvornik
parents: 202
diff changeset
243 filter_add_if_missing("r3d", "Red raw format", ".r3d", FORMAT_CLASS_RAWIMAGE, TRUE);
c7021159079d differentiate among normal image, raw image and metadata
nadvornik
parents: 202
diff changeset
244 filter_add_if_missing("3fr", "Hasselblad raw format", ".3fr", FORMAT_CLASS_RAWIMAGE, TRUE);
c7021159079d differentiate among normal image, raw image and metadata
nadvornik
parents: 202
diff changeset
245 filter_add_if_missing("erf", "Epson raw format", ".erf", FORMAT_CLASS_RAWIMAGE, TRUE);
9
d907d608745f Sync to GQview 1.5.9 release.
gqview
parents: 3
diff changeset
246 }
d907d608745f Sync to GQview 1.5.9 release.
gqview
parents: 3
diff changeset
247
147
b2266996fa83 added possibility to specify prefered file type for external commands
nadvornik
parents: 146
diff changeset
248 GList *filter_to_list(const gchar *extensions)
9
d907d608745f Sync to GQview 1.5.9 release.
gqview
parents: 3
diff changeset
249 {
d907d608745f Sync to GQview 1.5.9 release.
gqview
parents: 3
diff changeset
250 GList *list = NULL;
d907d608745f Sync to GQview 1.5.9 release.
gqview
parents: 3
diff changeset
251 const gchar *p;
d907d608745f Sync to GQview 1.5.9 release.
gqview
parents: 3
diff changeset
252
d907d608745f Sync to GQview 1.5.9 release.
gqview
parents: 3
diff changeset
253 if (!extensions) return NULL;
d907d608745f Sync to GQview 1.5.9 release.
gqview
parents: 3
diff changeset
254
d907d608745f Sync to GQview 1.5.9 release.
gqview
parents: 3
diff changeset
255 p = extensions;
d907d608745f Sync to GQview 1.5.9 release.
gqview
parents: 3
diff changeset
256 while (*p != '\0')
d907d608745f Sync to GQview 1.5.9 release.
gqview
parents: 3
diff changeset
257 {
d907d608745f Sync to GQview 1.5.9 release.
gqview
parents: 3
diff changeset
258 const gchar *b;
d907d608745f Sync to GQview 1.5.9 release.
gqview
parents: 3
diff changeset
259 gint l = 0;
d907d608745f Sync to GQview 1.5.9 release.
gqview
parents: 3
diff changeset
260
d907d608745f Sync to GQview 1.5.9 release.
gqview
parents: 3
diff changeset
261 b = p;
d907d608745f Sync to GQview 1.5.9 release.
gqview
parents: 3
diff changeset
262 while (*p != '\0' && *p != ';')
d907d608745f Sync to GQview 1.5.9 release.
gqview
parents: 3
diff changeset
263 {
d907d608745f Sync to GQview 1.5.9 release.
gqview
parents: 3
diff changeset
264 p++;
d907d608745f Sync to GQview 1.5.9 release.
gqview
parents: 3
diff changeset
265 l++;
d907d608745f Sync to GQview 1.5.9 release.
gqview
parents: 3
diff changeset
266 }
d907d608745f Sync to GQview 1.5.9 release.
gqview
parents: 3
diff changeset
267 list = g_list_append(list, g_strndup(b, l));
d907d608745f Sync to GQview 1.5.9 release.
gqview
parents: 3
diff changeset
268 if (*p == ';') p++;
d907d608745f Sync to GQview 1.5.9 release.
gqview
parents: 3
diff changeset
269 }
d907d608745f Sync to GQview 1.5.9 release.
gqview
parents: 3
diff changeset
270
d907d608745f Sync to GQview 1.5.9 release.
gqview
parents: 3
diff changeset
271 return list;
d907d608745f Sync to GQview 1.5.9 release.
gqview
parents: 3
diff changeset
272 }
d907d608745f Sync to GQview 1.5.9 release.
gqview
parents: 3
diff changeset
273
d907d608745f Sync to GQview 1.5.9 release.
gqview
parents: 3
diff changeset
274 void filter_rebuild(void)
d907d608745f Sync to GQview 1.5.9 release.
gqview
parents: 3
diff changeset
275 {
d907d608745f Sync to GQview 1.5.9 release.
gqview
parents: 3
diff changeset
276 GList *work;
212
c7021159079d differentiate among normal image, raw image and metadata
nadvornik
parents: 202
diff changeset
277 gint i;
9
d907d608745f Sync to GQview 1.5.9 release.
gqview
parents: 3
diff changeset
278
212
c7021159079d differentiate among normal image, raw image and metadata
nadvornik
parents: 202
diff changeset
279 string_list_free(extension_list);
9
d907d608745f Sync to GQview 1.5.9 release.
gqview
parents: 3
diff changeset
280 extension_list = NULL;
d907d608745f Sync to GQview 1.5.9 release.
gqview
parents: 3
diff changeset
281
212
c7021159079d differentiate among normal image, raw image and metadata
nadvornik
parents: 202
diff changeset
282 for (i = 0; i < FILE_FORMAT_CLASSES; i++)
c7021159079d differentiate among normal image, raw image and metadata
nadvornik
parents: 202
diff changeset
283 {
c7021159079d differentiate among normal image, raw image and metadata
nadvornik
parents: 202
diff changeset
284 string_list_free(file_class_extension_list[i]);
c7021159079d differentiate among normal image, raw image and metadata
nadvornik
parents: 202
diff changeset
285 file_class_extension_list[i] = NULL;
c7021159079d differentiate among normal image, raw image and metadata
nadvornik
parents: 202
diff changeset
286 }
c7021159079d differentiate among normal image, raw image and metadata
nadvornik
parents: 202
diff changeset
287
9
d907d608745f Sync to GQview 1.5.9 release.
gqview
parents: 3
diff changeset
288 work = filter_list;
d907d608745f Sync to GQview 1.5.9 release.
gqview
parents: 3
diff changeset
289 while (work)
d907d608745f Sync to GQview 1.5.9 release.
gqview
parents: 3
diff changeset
290 {
d907d608745f Sync to GQview 1.5.9 release.
gqview
parents: 3
diff changeset
291 FilterEntry *fe;
d907d608745f Sync to GQview 1.5.9 release.
gqview
parents: 3
diff changeset
292
d907d608745f Sync to GQview 1.5.9 release.
gqview
parents: 3
diff changeset
293 fe = work->data;
d907d608745f Sync to GQview 1.5.9 release.
gqview
parents: 3
diff changeset
294 work = work->next;
d907d608745f Sync to GQview 1.5.9 release.
gqview
parents: 3
diff changeset
295
d907d608745f Sync to GQview 1.5.9 release.
gqview
parents: 3
diff changeset
296 if (fe->enabled)
d907d608745f Sync to GQview 1.5.9 release.
gqview
parents: 3
diff changeset
297 {
d907d608745f Sync to GQview 1.5.9 release.
gqview
parents: 3
diff changeset
298 GList *ext;
d907d608745f Sync to GQview 1.5.9 release.
gqview
parents: 3
diff changeset
299
d907d608745f Sync to GQview 1.5.9 release.
gqview
parents: 3
diff changeset
300 ext = filter_to_list(fe->extensions);
d907d608745f Sync to GQview 1.5.9 release.
gqview
parents: 3
diff changeset
301 if (ext) extension_list = g_list_concat(extension_list, ext);
442
4b2d7f9af171 Big whitespaces cleanup:
zas_
parents: 425
diff changeset
302
212
c7021159079d differentiate among normal image, raw image and metadata
nadvornik
parents: 202
diff changeset
303 if (fe->file_class >= 0 && fe->file_class < FILE_FORMAT_CLASSES)
c7021159079d differentiate among normal image, raw image and metadata
nadvornik
parents: 202
diff changeset
304 {
c7021159079d differentiate among normal image, raw image and metadata
nadvornik
parents: 202
diff changeset
305 ext = filter_to_list(fe->extensions);
c7021159079d differentiate among normal image, raw image and metadata
nadvornik
parents: 202
diff changeset
306 if (ext) file_class_extension_list[fe->file_class] = g_list_concat(file_class_extension_list[fe->file_class], ext);
c7021159079d differentiate among normal image, raw image and metadata
nadvornik
parents: 202
diff changeset
307 }
c7021159079d differentiate among normal image, raw image and metadata
nadvornik
parents: 202
diff changeset
308 else
c7021159079d differentiate among normal image, raw image and metadata
nadvornik
parents: 202
diff changeset
309 {
c7021159079d differentiate among normal image, raw image and metadata
nadvornik
parents: 202
diff changeset
310 printf("WARNING: invalid file class %d\n", fe->file_class);
c7021159079d differentiate among normal image, raw image and metadata
nadvornik
parents: 202
diff changeset
311 }
9
d907d608745f Sync to GQview 1.5.9 release.
gqview
parents: 3
diff changeset
312 }
d907d608745f Sync to GQview 1.5.9 release.
gqview
parents: 3
diff changeset
313 }
d907d608745f Sync to GQview 1.5.9 release.
gqview
parents: 3
diff changeset
314 }
d907d608745f Sync to GQview 1.5.9 release.
gqview
parents: 3
diff changeset
315
d907d608745f Sync to GQview 1.5.9 release.
gqview
parents: 3
diff changeset
316 gint filter_name_exists(const gchar *name)
d907d608745f Sync to GQview 1.5.9 release.
gqview
parents: 3
diff changeset
317 {
d907d608745f Sync to GQview 1.5.9 release.
gqview
parents: 3
diff changeset
318 GList *work;
215
f2b439c7f973 Move strlen() calls outside the while loop.
zas_
parents: 212
diff changeset
319 gint ln;
f2b439c7f973 Move strlen() calls outside the while loop.
zas_
parents: 212
diff changeset
320
332
3c4bad726e98 Rename file filtering options.
zas_
parents: 318
diff changeset
321 if (!extension_list || options->file_filter.disable) return TRUE;
9
d907d608745f Sync to GQview 1.5.9 release.
gqview
parents: 3
diff changeset
322
215
f2b439c7f973 Move strlen() calls outside the while loop.
zas_
parents: 212
diff changeset
323 ln = strlen(name);
9
d907d608745f Sync to GQview 1.5.9 release.
gqview
parents: 3
diff changeset
324 work = extension_list;
1
b3e0e515fabf Initial revision
gqview
parents:
diff changeset
325 while (work)
b3e0e515fabf Initial revision
gqview
parents:
diff changeset
326 {
b3e0e515fabf Initial revision
gqview
parents:
diff changeset
327 gchar *filter = work->data;
b3e0e515fabf Initial revision
gqview
parents:
diff changeset
328 gint lf = strlen(filter);
215
f2b439c7f973 Move strlen() calls outside the while loop.
zas_
parents: 212
diff changeset
329
1
b3e0e515fabf Initial revision
gqview
parents:
diff changeset
330 if (ln >= lf)
b3e0e515fabf Initial revision
gqview
parents:
diff changeset
331 {
b3e0e515fabf Initial revision
gqview
parents:
diff changeset
332 if (strncasecmp(name + ln - lf, filter, lf) == 0) return TRUE;
b3e0e515fabf Initial revision
gqview
parents:
diff changeset
333 }
b3e0e515fabf Initial revision
gqview
parents:
diff changeset
334 work = work->next;
b3e0e515fabf Initial revision
gqview
parents:
diff changeset
335 }
b3e0e515fabf Initial revision
gqview
parents:
diff changeset
336
b3e0e515fabf Initial revision
gqview
parents:
diff changeset
337 return FALSE;
b3e0e515fabf Initial revision
gqview
parents:
diff changeset
338 }
b3e0e515fabf Initial revision
gqview
parents:
diff changeset
339
212
c7021159079d differentiate among normal image, raw image and metadata
nadvornik
parents: 202
diff changeset
340 gint filter_file_class(const gchar *name, FileFormatClass file_class)
c7021159079d differentiate among normal image, raw image and metadata
nadvornik
parents: 202
diff changeset
341 {
c7021159079d differentiate among normal image, raw image and metadata
nadvornik
parents: 202
diff changeset
342 GList *work;
215
f2b439c7f973 Move strlen() calls outside the while loop.
zas_
parents: 212
diff changeset
343 gint ln;
212
c7021159079d differentiate among normal image, raw image and metadata
nadvornik
parents: 202
diff changeset
344
c7021159079d differentiate among normal image, raw image and metadata
nadvornik
parents: 202
diff changeset
345 if (file_class < 0 || file_class >= FILE_FORMAT_CLASSES)
c7021159079d differentiate among normal image, raw image and metadata
nadvornik
parents: 202
diff changeset
346 {
c7021159079d differentiate among normal image, raw image and metadata
nadvornik
parents: 202
diff changeset
347 printf("WARNING: invalid file class %d\n", file_class);
c7021159079d differentiate among normal image, raw image and metadata
nadvornik
parents: 202
diff changeset
348 return FALSE;
c7021159079d differentiate among normal image, raw image and metadata
nadvornik
parents: 202
diff changeset
349 }
c7021159079d differentiate among normal image, raw image and metadata
nadvornik
parents: 202
diff changeset
350
215
f2b439c7f973 Move strlen() calls outside the while loop.
zas_
parents: 212
diff changeset
351 ln = strlen(name);
212
c7021159079d differentiate among normal image, raw image and metadata
nadvornik
parents: 202
diff changeset
352 work = file_class_extension_list[file_class];
c7021159079d differentiate among normal image, raw image and metadata
nadvornik
parents: 202
diff changeset
353 while (work)
c7021159079d differentiate among normal image, raw image and metadata
nadvornik
parents: 202
diff changeset
354 {
c7021159079d differentiate among normal image, raw image and metadata
nadvornik
parents: 202
diff changeset
355 gchar *filter = work->data;
c7021159079d differentiate among normal image, raw image and metadata
nadvornik
parents: 202
diff changeset
356 gint lf = strlen(filter);
215
f2b439c7f973 Move strlen() calls outside the while loop.
zas_
parents: 212
diff changeset
357
212
c7021159079d differentiate among normal image, raw image and metadata
nadvornik
parents: 202
diff changeset
358 if (ln >= lf)
c7021159079d differentiate among normal image, raw image and metadata
nadvornik
parents: 202
diff changeset
359 {
c7021159079d differentiate among normal image, raw image and metadata
nadvornik
parents: 202
diff changeset
360 if (strncasecmp(name + ln - lf, filter, lf) == 0) return TRUE;
c7021159079d differentiate among normal image, raw image and metadata
nadvornik
parents: 202
diff changeset
361 }
c7021159079d differentiate among normal image, raw image and metadata
nadvornik
parents: 202
diff changeset
362 work = work->next;
c7021159079d differentiate among normal image, raw image and metadata
nadvornik
parents: 202
diff changeset
363 }
c7021159079d differentiate among normal image, raw image and metadata
nadvornik
parents: 202
diff changeset
364
c7021159079d differentiate among normal image, raw image and metadata
nadvornik
parents: 202
diff changeset
365 return FALSE;
c7021159079d differentiate among normal image, raw image and metadata
nadvornik
parents: 202
diff changeset
366 }
c7021159079d differentiate among normal image, raw image and metadata
nadvornik
parents: 202
diff changeset
367
276
4f526d436873 Implement secure rc file saving.
zas_
parents: 248
diff changeset
368 void filter_write_list(SecureSaveInfo *ssi)
1
b3e0e515fabf Initial revision
gqview
parents:
diff changeset
369 {
9
d907d608745f Sync to GQview 1.5.9 release.
gqview
parents: 3
diff changeset
370 GList *work;
d907d608745f Sync to GQview 1.5.9 release.
gqview
parents: 3
diff changeset
371
d907d608745f Sync to GQview 1.5.9 release.
gqview
parents: 3
diff changeset
372 work = filter_list;
d907d608745f Sync to GQview 1.5.9 release.
gqview
parents: 3
diff changeset
373 while (work)
d907d608745f Sync to GQview 1.5.9 release.
gqview
parents: 3
diff changeset
374 {
d907d608745f Sync to GQview 1.5.9 release.
gqview
parents: 3
diff changeset
375 FilterEntry *fe = work->data;
d907d608745f Sync to GQview 1.5.9 release.
gqview
parents: 3
diff changeset
376 work = work->next;
442
4b2d7f9af171 Big whitespaces cleanup:
zas_
parents: 425
diff changeset
377
217
5bdab7ed4bcd use quoted_value everywhere
nadvornik
parents: 215
diff changeset
378 gchar *extensions = escquote_value(fe->extensions);
5bdab7ed4bcd use quoted_value everywhere
nadvornik
parents: 215
diff changeset
379 gchar *description = escquote_value(fe->description);
9
d907d608745f Sync to GQview 1.5.9 release.
gqview
parents: 3
diff changeset
380
370
1eaea84877ce save file_class to config file
nadvornik
parents: 356
diff changeset
381 secure_fprintf(ssi, "file_filter.ext: \"%s%s\" %s %s %d\n",
276
4f526d436873 Implement secure rc file saving.
zas_
parents: 248
diff changeset
382 (fe->enabled) ? "" : "#",
370
1eaea84877ce save file_class to config file
nadvornik
parents: 356
diff changeset
383 fe->key, extensions, description, fe->file_class);
217
5bdab7ed4bcd use quoted_value everywhere
nadvornik
parents: 215
diff changeset
384 g_free(extensions);
5bdab7ed4bcd use quoted_value everywhere
nadvornik
parents: 215
diff changeset
385 g_free(description);
9
d907d608745f Sync to GQview 1.5.9 release.
gqview
parents: 3
diff changeset
386 }
1
b3e0e515fabf Initial revision
gqview
parents:
diff changeset
387 }
b3e0e515fabf Initial revision
gqview
parents:
diff changeset
388
9
d907d608745f Sync to GQview 1.5.9 release.
gqview
parents: 3
diff changeset
389 void filter_parse(const gchar *text)
1
b3e0e515fabf Initial revision
gqview
parents:
diff changeset
390 {
9
d907d608745f Sync to GQview 1.5.9 release.
gqview
parents: 3
diff changeset
391 const gchar *p;
d907d608745f Sync to GQview 1.5.9 release.
gqview
parents: 3
diff changeset
392 gchar *key;
d907d608745f Sync to GQview 1.5.9 release.
gqview
parents: 3
diff changeset
393 gchar *ext;
d907d608745f Sync to GQview 1.5.9 release.
gqview
parents: 3
diff changeset
394 gchar *desc;
d907d608745f Sync to GQview 1.5.9 release.
gqview
parents: 3
diff changeset
395 gint enabled = TRUE;
370
1eaea84877ce save file_class to config file
nadvornik
parents: 356
diff changeset
396 gint file_class;
9
d907d608745f Sync to GQview 1.5.9 release.
gqview
parents: 3
diff changeset
397
d907d608745f Sync to GQview 1.5.9 release.
gqview
parents: 3
diff changeset
398 if (!text || text[0] != '"') return;
d907d608745f Sync to GQview 1.5.9 release.
gqview
parents: 3
diff changeset
399
217
5bdab7ed4bcd use quoted_value everywhere
nadvornik
parents: 215
diff changeset
400 key = quoted_value(text, &p);
9
d907d608745f Sync to GQview 1.5.9 release.
gqview
parents: 3
diff changeset
401 if (!key) return;
d907d608745f Sync to GQview 1.5.9 release.
gqview
parents: 3
diff changeset
402
217
5bdab7ed4bcd use quoted_value everywhere
nadvornik
parents: 215
diff changeset
403 ext = quoted_value(p, &p);
5bdab7ed4bcd use quoted_value everywhere
nadvornik
parents: 215
diff changeset
404 desc = quoted_value(p, &p);
442
4b2d7f9af171 Big whitespaces cleanup:
zas_
parents: 425
diff changeset
405
370
1eaea84877ce save file_class to config file
nadvornik
parents: 356
diff changeset
406 file_class = strtol(p, NULL, 10);
442
4b2d7f9af171 Big whitespaces cleanup:
zas_
parents: 425
diff changeset
407
370
1eaea84877ce save file_class to config file
nadvornik
parents: 356
diff changeset
408 if (file_class < 0 || file_class >= FILE_FORMAT_CLASSES) file_class = FORMAT_CLASS_UNKNOWN;
9
d907d608745f Sync to GQview 1.5.9 release.
gqview
parents: 3
diff changeset
409
d907d608745f Sync to GQview 1.5.9 release.
gqview
parents: 3
diff changeset
410 if (key && key[0] == '#')
d907d608745f Sync to GQview 1.5.9 release.
gqview
parents: 3
diff changeset
411 {
d907d608745f Sync to GQview 1.5.9 release.
gqview
parents: 3
diff changeset
412 gchar *tmp;
d907d608745f Sync to GQview 1.5.9 release.
gqview
parents: 3
diff changeset
413 tmp = g_strdup(key + 1);
d907d608745f Sync to GQview 1.5.9 release.
gqview
parents: 3
diff changeset
414 g_free(key);
d907d608745f Sync to GQview 1.5.9 release.
gqview
parents: 3
diff changeset
415 key = tmp;
d907d608745f Sync to GQview 1.5.9 release.
gqview
parents: 3
diff changeset
416
d907d608745f Sync to GQview 1.5.9 release.
gqview
parents: 3
diff changeset
417 enabled = FALSE;
1
b3e0e515fabf Initial revision
gqview
parents:
diff changeset
418 }
b3e0e515fabf Initial revision
gqview
parents:
diff changeset
419
370
1eaea84877ce save file_class to config file
nadvornik
parents: 356
diff changeset
420 if (key && strlen(key) > 0 && ext) filter_add(key, desc, ext, file_class, enabled);
9
d907d608745f Sync to GQview 1.5.9 release.
gqview
parents: 3
diff changeset
421
d907d608745f Sync to GQview 1.5.9 release.
gqview
parents: 3
diff changeset
422 g_free(key);
d907d608745f Sync to GQview 1.5.9 release.
gqview
parents: 3
diff changeset
423 g_free(ext);
d907d608745f Sync to GQview 1.5.9 release.
gqview
parents: 3
diff changeset
424 g_free(desc);
d907d608745f Sync to GQview 1.5.9 release.
gqview
parents: 3
diff changeset
425 }
1
b3e0e515fabf Initial revision
gqview
parents:
diff changeset
426
145
8be2cc687304 fixed grouping sidecar files and made it configurable via config file
nadvornik
parents: 143
diff changeset
427 /*
8be2cc687304 fixed grouping sidecar files and made it configurable via config file
nadvornik
parents: 143
diff changeset
428 *-----------------------------------------------------------------------------
8be2cc687304 fixed grouping sidecar files and made it configurable via config file
nadvornik
parents: 143
diff changeset
429 * sidecar extension list
8be2cc687304 fixed grouping sidecar files and made it configurable via config file
nadvornik
parents: 143
diff changeset
430 *-----------------------------------------------------------------------------
8be2cc687304 fixed grouping sidecar files and made it configurable via config file
nadvornik
parents: 143
diff changeset
431 */
8be2cc687304 fixed grouping sidecar files and made it configurable via config file
nadvornik
parents: 143
diff changeset
432
586
905688aa2317 split filelist.c to filefilter.c and filedata.c
nadvornik
parents: 576
diff changeset
433 GList *sidecar_ext_get_list(void)
145
8be2cc687304 fixed grouping sidecar files and made it configurable via config file
nadvornik
parents: 143
diff changeset
434 {
8be2cc687304 fixed grouping sidecar files and made it configurable via config file
nadvornik
parents: 143
diff changeset
435 return sidecar_ext_list;
8be2cc687304 fixed grouping sidecar files and made it configurable via config file
nadvornik
parents: 143
diff changeset
436 }
8be2cc687304 fixed grouping sidecar files and made it configurable via config file
nadvornik
parents: 143
diff changeset
437
170
9a56e3d13e67 basic sidecar files configuration via preferences dialog
nadvornik
parents: 167
diff changeset
438 void sidecar_ext_parse(const gchar *text, gint quoted)
145
8be2cc687304 fixed grouping sidecar files and made it configurable via config file
nadvornik
parents: 143
diff changeset
439 {
8be2cc687304 fixed grouping sidecar files and made it configurable via config file
nadvornik
parents: 143
diff changeset
440 GList *work;
8be2cc687304 fixed grouping sidecar files and made it configurable via config file
nadvornik
parents: 143
diff changeset
441 gchar *value;
8be2cc687304 fixed grouping sidecar files and made it configurable via config file
nadvornik
parents: 143
diff changeset
442
8be2cc687304 fixed grouping sidecar files and made it configurable via config file
nadvornik
parents: 143
diff changeset
443 work = sidecar_ext_list;
8be2cc687304 fixed grouping sidecar files and made it configurable via config file
nadvornik
parents: 143
diff changeset
444 while (work)
8be2cc687304 fixed grouping sidecar files and made it configurable via config file
nadvornik
parents: 143
diff changeset
445 {
8be2cc687304 fixed grouping sidecar files and made it configurable via config file
nadvornik
parents: 143
diff changeset
446 gchar *ext = work->data;
8be2cc687304 fixed grouping sidecar files and made it configurable via config file
nadvornik
parents: 143
diff changeset
447 work = work->next;
8be2cc687304 fixed grouping sidecar files and made it configurable via config file
nadvornik
parents: 143
diff changeset
448 g_free(ext);
8be2cc687304 fixed grouping sidecar files and made it configurable via config file
nadvornik
parents: 143
diff changeset
449 }
8be2cc687304 fixed grouping sidecar files and made it configurable via config file
nadvornik
parents: 143
diff changeset
450 g_list_free(sidecar_ext_list);
8be2cc687304 fixed grouping sidecar files and made it configurable via config file
nadvornik
parents: 143
diff changeset
451 sidecar_ext_list = NULL;
442
4b2d7f9af171 Big whitespaces cleanup:
zas_
parents: 425
diff changeset
452
170
9a56e3d13e67 basic sidecar files configuration via preferences dialog
nadvornik
parents: 167
diff changeset
453 if (quoted)
217
5bdab7ed4bcd use quoted_value everywhere
nadvornik
parents: 215
diff changeset
454 value = quoted_value(text, NULL);
170
9a56e3d13e67 basic sidecar files configuration via preferences dialog
nadvornik
parents: 167
diff changeset
455 else
9a56e3d13e67 basic sidecar files configuration via preferences dialog
nadvornik
parents: 167
diff changeset
456 value = g_strdup(text);
145
8be2cc687304 fixed grouping sidecar files and made it configurable via config file
nadvornik
parents: 143
diff changeset
457
8be2cc687304 fixed grouping sidecar files and made it configurable via config file
nadvornik
parents: 143
diff changeset
458 if (value == NULL) return;
8be2cc687304 fixed grouping sidecar files and made it configurable via config file
nadvornik
parents: 143
diff changeset
459
8be2cc687304 fixed grouping sidecar files and made it configurable via config file
nadvornik
parents: 143
diff changeset
460 sidecar_ext_list = filter_to_list(value);
442
4b2d7f9af171 Big whitespaces cleanup:
zas_
parents: 425
diff changeset
461
145
8be2cc687304 fixed grouping sidecar files and made it configurable via config file
nadvornik
parents: 143
diff changeset
462 g_free(value);
8be2cc687304 fixed grouping sidecar files and made it configurable via config file
nadvornik
parents: 143
diff changeset
463 }
8be2cc687304 fixed grouping sidecar files and made it configurable via config file
nadvornik
parents: 143
diff changeset
464
276
4f526d436873 Implement secure rc file saving.
zas_
parents: 248
diff changeset
465 void sidecar_ext_write(SecureSaveInfo *ssi)
145
8be2cc687304 fixed grouping sidecar files and made it configurable via config file
nadvornik
parents: 143
diff changeset
466 {
347
6dc0eaa0fcea sidecar_ext -> sidecar.ext
zas_
parents: 332
diff changeset
467 secure_fprintf(ssi, "sidecar.ext: \"%s\"\n", sidecar_ext_to_string());
170
9a56e3d13e67 basic sidecar files configuration via preferences dialog
nadvornik
parents: 167
diff changeset
468 }
9a56e3d13e67 basic sidecar files configuration via preferences dialog
nadvornik
parents: 167
diff changeset
469
9a56e3d13e67 basic sidecar files configuration via preferences dialog
nadvornik
parents: 167
diff changeset
470 char *sidecar_ext_to_string()
9a56e3d13e67 basic sidecar files configuration via preferences dialog
nadvornik
parents: 167
diff changeset
471 {
9a56e3d13e67 basic sidecar files configuration via preferences dialog
nadvornik
parents: 167
diff changeset
472 GList *work;
9a56e3d13e67 basic sidecar files configuration via preferences dialog
nadvornik
parents: 167
diff changeset
473 GString *str = g_string_new("");
9a56e3d13e67 basic sidecar files configuration via preferences dialog
nadvornik
parents: 167
diff changeset
474
145
8be2cc687304 fixed grouping sidecar files and made it configurable via config file
nadvornik
parents: 143
diff changeset
475 work = sidecar_ext_list;
8be2cc687304 fixed grouping sidecar files and made it configurable via config file
nadvornik
parents: 143
diff changeset
476 while (work)
8be2cc687304 fixed grouping sidecar files and made it configurable via config file
nadvornik
parents: 143
diff changeset
477 {
8be2cc687304 fixed grouping sidecar files and made it configurable via config file
nadvornik
parents: 143
diff changeset
478 gchar *ext = work->data;
8be2cc687304 fixed grouping sidecar files and made it configurable via config file
nadvornik
parents: 143
diff changeset
479 work = work->next;
170
9a56e3d13e67 basic sidecar files configuration via preferences dialog
nadvornik
parents: 167
diff changeset
480 g_string_append(str, ext);
9a56e3d13e67 basic sidecar files configuration via preferences dialog
nadvornik
parents: 167
diff changeset
481 if (work) g_string_append(str, ";");
145
8be2cc687304 fixed grouping sidecar files and made it configurable via config file
nadvornik
parents: 143
diff changeset
482 }
170
9a56e3d13e67 basic sidecar files configuration via preferences dialog
nadvornik
parents: 167
diff changeset
483 return g_string_free(str, FALSE);
145
8be2cc687304 fixed grouping sidecar files and made it configurable via config file
nadvornik
parents: 143
diff changeset
484 }
8be2cc687304 fixed grouping sidecar files and made it configurable via config file
nadvornik
parents: 143
diff changeset
485
8be2cc687304 fixed grouping sidecar files and made it configurable via config file
nadvornik
parents: 143
diff changeset
486 void sidecar_ext_add_defaults()
8be2cc687304 fixed grouping sidecar files and made it configurable via config file
nadvornik
parents: 143
diff changeset
487 {
188
0584cb78aa14 write comment and keywords to xmp, sidecars are used if exist
nadvornik
parents: 172
diff changeset
488 sidecar_ext_parse(".jpg;.cr2;.nef;.crw;.xmp", FALSE);
145
8be2cc687304 fixed grouping sidecar files and made it configurable via config file
nadvornik
parents: 143
diff changeset
489 }