Mercurial > audlegacy
annotate src/audacious/util.c @ 4278:0a9e1d9eae7b
Fix some warnings.
author | William Pitcock <nenolod@atheme.org> |
---|---|
date | Mon, 11 Feb 2008 03:57:30 -0600 |
parents | a41fb6bc632a |
children | f493c456c77f |
rev | line source |
---|---|
2313 | 1 /* Audacious - Cross-platform multimedia player |
4259
92642f860860
- added template for src_flow
Eugene Zagidullin <e.asphyx@gmail.com>
parents:
4223
diff
changeset
|
2 * Copyright (C) 2005-2008 Audacious development team |
2313 | 3 * |
4 * Based on BMP: | |
5 * Copyright (C) 2003-2004 BMP development team. | |
6 * | |
7 * Based on XMMS: | |
8 * Copyright (C) 1998-2003 XMMS development team. | |
9 * | |
10 * This program is free software; you can redistribute it and/or modify | |
11 * it under the terms of the GNU General Public License as published by | |
3121
3b6d316f8b09
GPL3 relicensing.
William Pitcock <nenolod@atheme-project.org>
parents:
3103
diff
changeset
|
12 * the Free Software Foundation; under version 3 of the License. |
2313 | 13 * |
14 * This program is distributed in the hope that it will be useful, | |
15 * but WITHOUT ANY WARRANTY; without even the implied warranty of | |
16 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the | |
17 * GNU General Public License for more details. | |
18 * | |
19 * You should have received a copy of the GNU General Public License | |
3121
3b6d316f8b09
GPL3 relicensing.
William Pitcock <nenolod@atheme-project.org>
parents:
3103
diff
changeset
|
20 * along with this program. If not, see <http://www.gnu.org/licenses>. |
3123
f1c756f39e6c
Invoke "Plugins are not derived work" clause provided by GPL3.
William Pitcock <nenolod@atheme-project.org>
parents:
3122
diff
changeset
|
21 * |
f1c756f39e6c
Invoke "Plugins are not derived work" clause provided by GPL3.
William Pitcock <nenolod@atheme-project.org>
parents:
3122
diff
changeset
|
22 * The Audacious team does not consider modular code linking to |
f1c756f39e6c
Invoke "Plugins are not derived work" clause provided by GPL3.
William Pitcock <nenolod@atheme-project.org>
parents:
3122
diff
changeset
|
23 * Audacious or using our public API to be a derived work. |
2313 | 24 */ |
25 | |
4127 | 26 /*#define AUD_DEBUG*/ |
4070
040243a50bd3
- modified playlist_load_ins_file() and playlist_load_ins_file_tuple(). path builder and ext_hash checker
Yoshiki Yazawa <yaz@cc.rim.or.jp>
parents:
3993
diff
changeset
|
27 |
2313 | 28 #ifdef HAVE_CONFIG_H |
29 # include "config.h" | |
30 #endif | |
31 | |
32 #include "util.h" | |
33 | |
34 #include <glib.h> | |
35 #include <glib/gi18n.h> | |
36 #include <gtk/gtk.h> | |
37 #include <stdlib.h> | |
38 #include <string.h> | |
39 #include <ctype.h> | |
4267
a41fb6bc632a
- src stuff traveled to src_flow.c
Eugene Zagidullin <e.asphyx@gmail.com>
parents:
4259
diff
changeset
|
40 #include <math.h> |
2313 | 41 |
42 #include "platform/smartinclude.h" | |
43 #include <errno.h> | |
44 | |
45 #ifdef HAVE_FTS_H | |
3033 | 46 # include <sys/types.h> |
47 # include <sys/stat.h> | |
2313 | 48 # include <fts.h> |
49 #endif | |
50 | |
51 #include "input.h" | |
52 #include "main.h" | |
53 #include "playback.h" | |
2373
ad1d7687814c
[svn] made strings.h for existing strings.c, cleanups
mf0102
parents:
2365
diff
changeset
|
54 #include "strings.h" |
2313 | 55 #include "ui_playlist.h" |
4259
92642f860860
- added template for src_flow
Eugene Zagidullin <e.asphyx@gmail.com>
parents:
4223
diff
changeset
|
56 #include "libSAD.h" |
2313 | 57 |
58 #ifdef USE_CHARDET | |
3210
5939941ba48b
More librcd removal.
William Pitcock <nenolod@atheme-project.org>
parents:
3123
diff
changeset
|
59 #include "../libguess/libguess.h" |
2313 | 60 #ifdef HAVE_UDET |
61 #include <libudet_c.h> | |
62 #endif | |
63 #endif | |
64 | |
65 /* | |
66 * find <file> in directory <dirname> or subdirectories. return | |
67 * pointer to complete filename which has to be freed by calling | |
68 * "g_free()" after use. Returns NULL if file could not be found. | |
69 */ | |
70 | |
71 typedef struct { | |
72 const gchar *to_match; | |
73 gchar *match; | |
74 gboolean found; | |
75 } FindFileContext; | |
76 | |
4259
92642f860860
- added template for src_flow
Eugene Zagidullin <e.asphyx@gmail.com>
parents:
4223
diff
changeset
|
77 static const struct { |
92642f860860
- added template for src_flow
Eugene Zagidullin <e.asphyx@gmail.com>
parents:
4223
diff
changeset
|
78 AFormat afmt; |
92642f860860
- added template for src_flow
Eugene Zagidullin <e.asphyx@gmail.com>
parents:
4223
diff
changeset
|
79 SAD_sample_format sadfmt; |
92642f860860
- added template for src_flow
Eugene Zagidullin <e.asphyx@gmail.com>
parents:
4223
diff
changeset
|
80 } format_table[] = { |
92642f860860
- added template for src_flow
Eugene Zagidullin <e.asphyx@gmail.com>
parents:
4223
diff
changeset
|
81 {FMT_U8, SAD_SAMPLE_U8}, |
92642f860860
- added template for src_flow
Eugene Zagidullin <e.asphyx@gmail.com>
parents:
4223
diff
changeset
|
82 {FMT_S8, SAD_SAMPLE_S8}, |
92642f860860
- added template for src_flow
Eugene Zagidullin <e.asphyx@gmail.com>
parents:
4223
diff
changeset
|
83 |
92642f860860
- added template for src_flow
Eugene Zagidullin <e.asphyx@gmail.com>
parents:
4223
diff
changeset
|
84 {FMT_S16_LE, SAD_SAMPLE_S16_LE}, |
92642f860860
- added template for src_flow
Eugene Zagidullin <e.asphyx@gmail.com>
parents:
4223
diff
changeset
|
85 {FMT_S16_BE, SAD_SAMPLE_S16_BE}, |
92642f860860
- added template for src_flow
Eugene Zagidullin <e.asphyx@gmail.com>
parents:
4223
diff
changeset
|
86 {FMT_S16_NE, SAD_SAMPLE_S16}, |
92642f860860
- added template for src_flow
Eugene Zagidullin <e.asphyx@gmail.com>
parents:
4223
diff
changeset
|
87 |
92642f860860
- added template for src_flow
Eugene Zagidullin <e.asphyx@gmail.com>
parents:
4223
diff
changeset
|
88 {FMT_U16_LE, SAD_SAMPLE_U16_LE}, |
92642f860860
- added template for src_flow
Eugene Zagidullin <e.asphyx@gmail.com>
parents:
4223
diff
changeset
|
89 {FMT_U16_BE, SAD_SAMPLE_U16_BE}, |
92642f860860
- added template for src_flow
Eugene Zagidullin <e.asphyx@gmail.com>
parents:
4223
diff
changeset
|
90 {FMT_U16_NE, SAD_SAMPLE_U16}, |
92642f860860
- added template for src_flow
Eugene Zagidullin <e.asphyx@gmail.com>
parents:
4223
diff
changeset
|
91 |
92642f860860
- added template for src_flow
Eugene Zagidullin <e.asphyx@gmail.com>
parents:
4223
diff
changeset
|
92 {FMT_S24_LE, SAD_SAMPLE_S24_LE}, |
92642f860860
- added template for src_flow
Eugene Zagidullin <e.asphyx@gmail.com>
parents:
4223
diff
changeset
|
93 {FMT_S24_BE, SAD_SAMPLE_S24_BE}, |
92642f860860
- added template for src_flow
Eugene Zagidullin <e.asphyx@gmail.com>
parents:
4223
diff
changeset
|
94 {FMT_S24_NE, SAD_SAMPLE_S24}, |
92642f860860
- added template for src_flow
Eugene Zagidullin <e.asphyx@gmail.com>
parents:
4223
diff
changeset
|
95 |
92642f860860
- added template for src_flow
Eugene Zagidullin <e.asphyx@gmail.com>
parents:
4223
diff
changeset
|
96 {FMT_U24_LE, SAD_SAMPLE_U24_LE}, |
92642f860860
- added template for src_flow
Eugene Zagidullin <e.asphyx@gmail.com>
parents:
4223
diff
changeset
|
97 {FMT_U24_BE, SAD_SAMPLE_U24_BE}, |
92642f860860
- added template for src_flow
Eugene Zagidullin <e.asphyx@gmail.com>
parents:
4223
diff
changeset
|
98 {FMT_U24_NE, SAD_SAMPLE_U24}, |
92642f860860
- added template for src_flow
Eugene Zagidullin <e.asphyx@gmail.com>
parents:
4223
diff
changeset
|
99 |
92642f860860
- added template for src_flow
Eugene Zagidullin <e.asphyx@gmail.com>
parents:
4223
diff
changeset
|
100 {FMT_S32_LE, SAD_SAMPLE_S32_LE}, |
92642f860860
- added template for src_flow
Eugene Zagidullin <e.asphyx@gmail.com>
parents:
4223
diff
changeset
|
101 {FMT_S32_BE, SAD_SAMPLE_S32_BE}, |
92642f860860
- added template for src_flow
Eugene Zagidullin <e.asphyx@gmail.com>
parents:
4223
diff
changeset
|
102 {FMT_S32_NE, SAD_SAMPLE_S32}, |
92642f860860
- added template for src_flow
Eugene Zagidullin <e.asphyx@gmail.com>
parents:
4223
diff
changeset
|
103 |
92642f860860
- added template for src_flow
Eugene Zagidullin <e.asphyx@gmail.com>
parents:
4223
diff
changeset
|
104 {FMT_U32_LE, SAD_SAMPLE_U32_LE}, |
92642f860860
- added template for src_flow
Eugene Zagidullin <e.asphyx@gmail.com>
parents:
4223
diff
changeset
|
105 {FMT_U32_BE, SAD_SAMPLE_U32_BE}, |
92642f860860
- added template for src_flow
Eugene Zagidullin <e.asphyx@gmail.com>
parents:
4223
diff
changeset
|
106 {FMT_U32_NE, SAD_SAMPLE_U32}, |
92642f860860
- added template for src_flow
Eugene Zagidullin <e.asphyx@gmail.com>
parents:
4223
diff
changeset
|
107 |
92642f860860
- added template for src_flow
Eugene Zagidullin <e.asphyx@gmail.com>
parents:
4223
diff
changeset
|
108 {FMT_FLOAT, SAD_SAMPLE_FLOAT}, |
92642f860860
- added template for src_flow
Eugene Zagidullin <e.asphyx@gmail.com>
parents:
4223
diff
changeset
|
109 {FMT_FIXED32, SAD_SAMPLE_FIXED32}, |
92642f860860
- added template for src_flow
Eugene Zagidullin <e.asphyx@gmail.com>
parents:
4223
diff
changeset
|
110 }; |
92642f860860
- added template for src_flow
Eugene Zagidullin <e.asphyx@gmail.com>
parents:
4223
diff
changeset
|
111 |
92642f860860
- added template for src_flow
Eugene Zagidullin <e.asphyx@gmail.com>
parents:
4223
diff
changeset
|
112 SAD_sample_format |
92642f860860
- added template for src_flow
Eugene Zagidullin <e.asphyx@gmail.com>
parents:
4223
diff
changeset
|
113 sadfmt_from_afmt(AFormat fmt) |
92642f860860
- added template for src_flow
Eugene Zagidullin <e.asphyx@gmail.com>
parents:
4223
diff
changeset
|
114 { |
92642f860860
- added template for src_flow
Eugene Zagidullin <e.asphyx@gmail.com>
parents:
4223
diff
changeset
|
115 int i; |
92642f860860
- added template for src_flow
Eugene Zagidullin <e.asphyx@gmail.com>
parents:
4223
diff
changeset
|
116 for (i = 0; i < sizeof(format_table) / sizeof(format_table[0]); i++) { |
92642f860860
- added template for src_flow
Eugene Zagidullin <e.asphyx@gmail.com>
parents:
4223
diff
changeset
|
117 if (format_table[i].afmt == fmt) return format_table[i].sadfmt; |
92642f860860
- added template for src_flow
Eugene Zagidullin <e.asphyx@gmail.com>
parents:
4223
diff
changeset
|
118 } |
92642f860860
- added template for src_flow
Eugene Zagidullin <e.asphyx@gmail.com>
parents:
4223
diff
changeset
|
119 |
92642f860860
- added template for src_flow
Eugene Zagidullin <e.asphyx@gmail.com>
parents:
4223
diff
changeset
|
120 return -1; |
92642f860860
- added template for src_flow
Eugene Zagidullin <e.asphyx@gmail.com>
parents:
4223
diff
changeset
|
121 } |
92642f860860
- added template for src_flow
Eugene Zagidullin <e.asphyx@gmail.com>
parents:
4223
diff
changeset
|
122 |
92642f860860
- added template for src_flow
Eugene Zagidullin <e.asphyx@gmail.com>
parents:
4223
diff
changeset
|
123 |
2313 | 124 static gboolean |
125 find_file_func(const gchar * path, const gchar * basename, gpointer data) | |
126 { | |
127 FindFileContext *context = data; | |
128 | |
129 if (strlen(path) > FILENAME_MAX) { | |
4124
d217b71e5836
more strict error handling. make use of AUDDBG
Eugene Zagidullin <e.asphyx@gmail.com>
parents:
4097
diff
changeset
|
130 AUDDBG("Ignoring path: name too long (%s)\n", path); |
2313 | 131 return TRUE; |
132 } | |
133 | |
2989
15f6c9949cde
Add and use find_path_recursively() which search the FS without using VFS (for GTK).
William Pitcock <nenolod@atheme-project.org>
parents:
2988
diff
changeset
|
134 if (vfs_file_test(path, G_FILE_TEST_IS_REGULAR)) { |
2313 | 135 if (!strcasecmp(basename, context->to_match)) { |
136 context->match = g_strdup(path); | |
137 context->found = TRUE; | |
138 return TRUE; | |
139 } | |
140 } | |
2989
15f6c9949cde
Add and use find_path_recursively() which search the FS without using VFS (for GTK).
William Pitcock <nenolod@atheme-project.org>
parents:
2988
diff
changeset
|
141 else if (vfs_file_test(path, G_FILE_TEST_IS_DIR)) { |
2313 | 142 dir_foreach(path, find_file_func, context, NULL); |
143 if (context->found) | |
144 return TRUE; | |
145 } | |
146 | |
147 return FALSE; | |
148 } | |
149 | |
150 gchar * | |
151 find_file_recursively(const gchar * path, const gchar * filename) | |
152 { | |
153 FindFileContext context; | |
2989
15f6c9949cde
Add and use find_path_recursively() which search the FS without using VFS (for GTK).
William Pitcock <nenolod@atheme-project.org>
parents:
2988
diff
changeset
|
154 gchar *out = NULL; |
2313 | 155 |
156 context.to_match = filename; | |
157 context.match = NULL; | |
158 context.found = FALSE; | |
159 | |
160 dir_foreach(path, find_file_func, &context, NULL); | |
2989
15f6c9949cde
Add and use find_path_recursively() which search the FS without using VFS (for GTK).
William Pitcock <nenolod@atheme-project.org>
parents:
2988
diff
changeset
|
161 |
15f6c9949cde
Add and use find_path_recursively() which search the FS without using VFS (for GTK).
William Pitcock <nenolod@atheme-project.org>
parents:
2988
diff
changeset
|
162 if (context.match) |
15f6c9949cde
Add and use find_path_recursively() which search the FS without using VFS (for GTK).
William Pitcock <nenolod@atheme-project.org>
parents:
2988
diff
changeset
|
163 { |
15f6c9949cde
Add and use find_path_recursively() which search the FS without using VFS (for GTK).
William Pitcock <nenolod@atheme-project.org>
parents:
2988
diff
changeset
|
164 out = g_filename_to_uri(context.match, NULL, NULL); |
15f6c9949cde
Add and use find_path_recursively() which search the FS without using VFS (for GTK).
William Pitcock <nenolod@atheme-project.org>
parents:
2988
diff
changeset
|
165 g_free(context.match); |
15f6c9949cde
Add and use find_path_recursively() which search the FS without using VFS (for GTK).
William Pitcock <nenolod@atheme-project.org>
parents:
2988
diff
changeset
|
166 } |
2988
43a075cb5c81
find_file_recursively(): Return a valid URI instead of a literal path.
William Pitcock <nenolod@atheme-project.org>
parents:
2977
diff
changeset
|
167 |
43a075cb5c81
find_file_recursively(): Return a valid URI instead of a literal path.
William Pitcock <nenolod@atheme-project.org>
parents:
2977
diff
changeset
|
168 return out; |
2313 | 169 } |
170 | |
2989
15f6c9949cde
Add and use find_path_recursively() which search the FS without using VFS (for GTK).
William Pitcock <nenolod@atheme-project.org>
parents:
2988
diff
changeset
|
171 gchar * |
15f6c9949cde
Add and use find_path_recursively() which search the FS without using VFS (for GTK).
William Pitcock <nenolod@atheme-project.org>
parents:
2988
diff
changeset
|
172 find_path_recursively(const gchar * path, const gchar * filename) |
15f6c9949cde
Add and use find_path_recursively() which search the FS without using VFS (for GTK).
William Pitcock <nenolod@atheme-project.org>
parents:
2988
diff
changeset
|
173 { |
15f6c9949cde
Add and use find_path_recursively() which search the FS without using VFS (for GTK).
William Pitcock <nenolod@atheme-project.org>
parents:
2988
diff
changeset
|
174 FindFileContext context; |
15f6c9949cde
Add and use find_path_recursively() which search the FS without using VFS (for GTK).
William Pitcock <nenolod@atheme-project.org>
parents:
2988
diff
changeset
|
175 |
15f6c9949cde
Add and use find_path_recursively() which search the FS without using VFS (for GTK).
William Pitcock <nenolod@atheme-project.org>
parents:
2988
diff
changeset
|
176 context.to_match = filename; |
15f6c9949cde
Add and use find_path_recursively() which search the FS without using VFS (for GTK).
William Pitcock <nenolod@atheme-project.org>
parents:
2988
diff
changeset
|
177 context.match = NULL; |
15f6c9949cde
Add and use find_path_recursively() which search the FS without using VFS (for GTK).
William Pitcock <nenolod@atheme-project.org>
parents:
2988
diff
changeset
|
178 context.found = FALSE; |
15f6c9949cde
Add and use find_path_recursively() which search the FS without using VFS (for GTK).
William Pitcock <nenolod@atheme-project.org>
parents:
2988
diff
changeset
|
179 |
15f6c9949cde
Add and use find_path_recursively() which search the FS without using VFS (for GTK).
William Pitcock <nenolod@atheme-project.org>
parents:
2988
diff
changeset
|
180 dir_foreach(path, find_file_func, &context, NULL); |
15f6c9949cde
Add and use find_path_recursively() which search the FS without using VFS (for GTK).
William Pitcock <nenolod@atheme-project.org>
parents:
2988
diff
changeset
|
181 |
15f6c9949cde
Add and use find_path_recursively() which search the FS without using VFS (for GTK).
William Pitcock <nenolod@atheme-project.org>
parents:
2988
diff
changeset
|
182 return context.match; |
15f6c9949cde
Add and use find_path_recursively() which search the FS without using VFS (for GTK).
William Pitcock <nenolod@atheme-project.org>
parents:
2988
diff
changeset
|
183 } |
15f6c9949cde
Add and use find_path_recursively() which search the FS without using VFS (for GTK).
William Pitcock <nenolod@atheme-project.org>
parents:
2988
diff
changeset
|
184 |
2313 | 185 |
186 typedef enum { | |
187 ARCHIVE_UNKNOWN = 0, | |
188 ARCHIVE_DIR, | |
189 ARCHIVE_TAR, | |
190 ARCHIVE_TGZ, | |
191 ARCHIVE_ZIP, | |
192 ARCHIVE_TBZ2 | |
193 } ArchiveType; | |
194 | |
195 typedef gchar *(*ArchiveExtractFunc) (const gchar *, const gchar *); | |
196 | |
197 typedef struct { | |
198 ArchiveType type; | |
199 const gchar *ext; | |
200 } ArchiveExtensionType; | |
201 | |
202 static ArchiveExtensionType archive_extensions[] = { | |
203 {ARCHIVE_TAR, ".tar"}, | |
204 {ARCHIVE_ZIP, ".wsz"}, | |
205 {ARCHIVE_ZIP, ".zip"}, | |
206 {ARCHIVE_TGZ, ".tar.gz"}, | |
207 {ARCHIVE_TGZ, ".tgz"}, | |
208 {ARCHIVE_TBZ2, ".tar.bz2"}, | |
209 {ARCHIVE_TBZ2, ".bz2"}, | |
210 {ARCHIVE_UNKNOWN, NULL} | |
211 }; | |
212 | |
213 static gchar *archive_extract_tar(const gchar * archive, const gchar * dest); | |
214 static gchar *archive_extract_zip(const gchar * archive, const gchar * dest); | |
215 static gchar *archive_extract_tgz(const gchar * archive, const gchar * dest); | |
216 static gchar *archive_extract_tbz2(const gchar * archive, const gchar * dest); | |
217 | |
218 static ArchiveExtractFunc archive_extract_funcs[] = { | |
219 NULL, | |
220 NULL, | |
221 archive_extract_tar, | |
222 archive_extract_tgz, | |
223 archive_extract_zip, | |
224 archive_extract_tbz2 | |
225 }; | |
226 | |
227 | |
228 /* FIXME: these functions can be generalised into a function using a | |
229 * command lookup table */ | |
230 | |
231 static const gchar * | |
232 get_tar_command(void) | |
233 { | |
234 static const gchar *command = NULL; | |
235 | |
236 if (!command) { | |
237 if (!(command = getenv("TARCMD"))) | |
238 command = "tar"; | |
239 } | |
240 | |
241 return command; | |
242 } | |
243 | |
244 static const gchar * | |
245 get_unzip_command(void) | |
246 { | |
247 static const gchar *command = NULL; | |
248 | |
249 if (!command) { | |
250 if (!(command = getenv("UNZIPCMD"))) | |
251 command = "unzip"; | |
252 } | |
253 | |
254 return command; | |
255 } | |
256 | |
257 | |
258 static gchar * | |
259 archive_extract_tar(const gchar * archive, const gchar * dest) | |
260 { | |
261 return g_strdup_printf("%s >/dev/null xf \"%s\" -C %s", | |
262 get_tar_command(), archive, dest); | |
263 } | |
264 | |
265 static gchar * | |
266 archive_extract_zip(const gchar * archive, const gchar * dest) | |
267 { | |
268 return g_strdup_printf("%s >/dev/null -o -j \"%s\" -d %s", | |
269 get_unzip_command(), archive, dest); | |
270 } | |
271 | |
272 static gchar * | |
273 archive_extract_tgz(const gchar * archive, const gchar * dest) | |
274 { | |
275 return g_strdup_printf("%s >/dev/null xzf \"%s\" -C %s", | |
276 get_tar_command(), archive, dest); | |
277 } | |
278 | |
279 static gchar * | |
280 archive_extract_tbz2(const gchar * archive, const gchar * dest) | |
281 { | |
282 return g_strdup_printf("bzip2 -dc \"%s\" | %s >/dev/null xf - -C %s", | |
283 archive, get_tar_command(), dest); | |
284 } | |
285 | |
286 | |
287 ArchiveType | |
288 archive_get_type(const gchar * filename) | |
289 { | |
290 gint i = 0; | |
291 | |
292 if (g_file_test(filename, G_FILE_TEST_IS_DIR)) | |
293 return ARCHIVE_DIR; | |
294 | |
295 while (archive_extensions[i].ext) { | |
296 if (g_str_has_suffix(filename, archive_extensions[i].ext)) { | |
297 return archive_extensions[i].type; | |
298 } | |
299 i++; | |
300 } | |
301 | |
302 return ARCHIVE_UNKNOWN; | |
303 } | |
304 | |
305 gboolean | |
306 file_is_archive(const gchar * filename) | |
307 { | |
308 return (archive_get_type(filename) > ARCHIVE_DIR); | |
309 } | |
310 | |
311 gchar * | |
312 archive_basename(const gchar * str) | |
313 { | |
314 gint i = 0; | |
315 | |
316 while (archive_extensions[i].ext) { | |
317 if (str_has_suffix_nocase(str, archive_extensions[i].ext)) { | |
318 const gchar *end = g_strrstr(str, archive_extensions[i].ext); | |
319 if (end) { | |
320 return g_strndup(str, end - str); | |
321 } | |
322 break; | |
323 } | |
324 i++; | |
325 } | |
326 | |
327 return NULL; | |
328 } | |
329 | |
330 /* | |
331 decompress_archive | |
332 | |
333 Decompresses the archive "filename" to a temporary directory, | |
334 returns the path to the temp dir, or NULL if failed, | |
335 watch out tho, doesn't actually check if the system command succeeds :-| | |
336 */ | |
337 | |
338 gchar * | |
339 archive_decompress(const gchar * filename) | |
340 { | |
341 gchar *tmpdir, *cmd, *escaped_filename; | |
342 ArchiveType type; | |
2328 | 343 #ifndef HAVE_MKDTEMP |
2313 | 344 mode_t mode755 = S_IRWXU | S_IRGRP | S_IXGRP | S_IROTH | S_IXOTH; |
2328 | 345 #endif |
2313 | 346 |
347 if ((type = archive_get_type(filename)) <= ARCHIVE_DIR) | |
348 return NULL; | |
349 | |
350 #ifdef HAVE_MKDTEMP | |
351 tmpdir = g_build_filename(g_get_tmp_dir(), "audacious.XXXXXXXX", NULL); | |
352 if (!mkdtemp(tmpdir)) { | |
353 g_free(tmpdir); | |
4124
d217b71e5836
more strict error handling. make use of AUDDBG
Eugene Zagidullin <e.asphyx@gmail.com>
parents:
4097
diff
changeset
|
354 AUDDBG("Unable to load skin: Failed to create temporary " |
d217b71e5836
more strict error handling. make use of AUDDBG
Eugene Zagidullin <e.asphyx@gmail.com>
parents:
4097
diff
changeset
|
355 "directory: %s\n", g_strerror(errno)); |
2313 | 356 return NULL; |
357 } | |
358 #else | |
3637 | 359 tmpdir = g_strdup_printf("%s/audacious.%ld", g_get_tmp_dir(), (long) rand()); |
2313 | 360 make_directory(tmpdir, mode755); |
361 #endif | |
362 | |
363 escaped_filename = escape_shell_chars(filename); | |
364 cmd = archive_extract_funcs[type] (escaped_filename, tmpdir); | |
365 g_free(escaped_filename); | |
366 | |
367 if (!cmd) { | |
4124
d217b71e5836
more strict error handling. make use of AUDDBG
Eugene Zagidullin <e.asphyx@gmail.com>
parents:
4097
diff
changeset
|
368 AUDDBG("extraction function is NULL!\n"); |
2313 | 369 g_free(tmpdir); |
370 return NULL; | |
371 } | |
372 | |
4124
d217b71e5836
more strict error handling. make use of AUDDBG
Eugene Zagidullin <e.asphyx@gmail.com>
parents:
4097
diff
changeset
|
373 AUDDBG("Attempt to execute \"%s\"\n", cmd); |
d217b71e5836
more strict error handling. make use of AUDDBG
Eugene Zagidullin <e.asphyx@gmail.com>
parents:
4097
diff
changeset
|
374 |
d217b71e5836
more strict error handling. make use of AUDDBG
Eugene Zagidullin <e.asphyx@gmail.com>
parents:
4097
diff
changeset
|
375 if(system(cmd) != 0) |
2361
f24ae4f40e29
[svn] - security and warning fixes from ssommer@suse
nenolod
parents:
2332
diff
changeset
|
376 { |
4124
d217b71e5836
more strict error handling. make use of AUDDBG
Eugene Zagidullin <e.asphyx@gmail.com>
parents:
4097
diff
changeset
|
377 AUDDBG("could not execute cmd %s\n",cmd); |
2361
f24ae4f40e29
[svn] - security and warning fixes from ssommer@suse
nenolod
parents:
2332
diff
changeset
|
378 g_free(cmd); |
f24ae4f40e29
[svn] - security and warning fixes from ssommer@suse
nenolod
parents:
2332
diff
changeset
|
379 return NULL; |
f24ae4f40e29
[svn] - security and warning fixes from ssommer@suse
nenolod
parents:
2332
diff
changeset
|
380 } |
2313 | 381 g_free(cmd); |
382 | |
383 return tmpdir; | |
384 } | |
385 | |
386 | |
387 #ifdef HAVE_FTS_H | |
388 | |
389 void | |
390 del_directory(const gchar * dirname) | |
391 { | |
392 gchar *const argv[2] = { (gchar *) dirname, NULL }; | |
393 FTS *fts; | |
394 FTSENT *p; | |
395 | |
396 fts = fts_open(argv, FTS_PHYSICAL, (gint(*)())NULL); | |
397 while ((p = fts_read(fts))) { | |
398 switch (p->fts_info) { | |
399 case FTS_D: | |
400 break; | |
401 case FTS_DNR: | |
402 case FTS_ERR: | |
403 break; | |
404 case FTS_DP: | |
405 rmdir(p->fts_accpath); | |
406 break; | |
407 default: | |
408 unlink(p->fts_accpath); | |
409 break; | |
410 } | |
411 } | |
412 fts_close(fts); | |
413 } | |
414 | |
415 #else /* !HAVE_FTS */ | |
416 | |
417 gboolean | |
418 del_directory_func(const gchar * path, const gchar * basename, | |
419 gpointer params) | |
420 { | |
421 if (!strcmp(basename, ".") || !strcmp(path, "..")) | |
422 return FALSE; | |
423 | |
424 if (g_file_test(path, G_FILE_TEST_IS_DIR)) { | |
425 dir_foreach(path, del_directory_func, NULL, NULL); | |
426 rmdir(path); | |
427 return FALSE; | |
428 } | |
429 | |
430 unlink(path); | |
431 | |
432 return FALSE; | |
433 } | |
434 | |
435 void | |
436 del_directory(const gchar * path) | |
437 { | |
438 dir_foreach(path, del_directory_func, NULL, NULL); | |
439 rmdir(path); | |
440 } | |
441 | |
442 #endif /* ifdef HAVE_FTS */ | |
443 | |
2529 | 444 static void |
445 strip_string(GString *string) | |
446 { | |
447 while (string->len > 0 && string->str[0] == ' ') | |
448 g_string_erase(string, 0, 1); | |
449 | |
450 while (string->len > 0 && string->str[string->len - 1] == ' ') | |
451 g_string_erase(string, string->len - 1, 1); | |
452 } | |
453 | |
454 static void | |
455 strip_lower_string(GString *string) | |
456 { | |
2660
8d0b89db56e5
[svn] - fixed c++ish declaration in a c file (part 7)
giacomo
parents:
2635
diff
changeset
|
457 gchar *lower; |
2529 | 458 strip_string(string); |
2609 | 459 |
2660
8d0b89db56e5
[svn] - fixed c++ish declaration in a c file (part 7)
giacomo
parents:
2635
diff
changeset
|
460 lower = g_ascii_strdown(string->str, -1); |
2529 | 461 g_free(string->str); |
462 string->str = lower; | |
463 } | |
464 | |
4157
e474286a4c23
Close_ini_file() frees all memory allocated in open_ini_file() (Bugzilla #40)
Jussi Judin <jjudin+audacious@iki.fi>
parents:
4127
diff
changeset
|
465 static void |
e474286a4c23
Close_ini_file() frees all memory allocated in open_ini_file() (Bugzilla #40)
Jussi Judin <jjudin+audacious@iki.fi>
parents:
4127
diff
changeset
|
466 close_ini_file_free_value(gpointer value) |
e474286a4c23
Close_ini_file() frees all memory allocated in open_ini_file() (Bugzilla #40)
Jussi Judin <jjudin+audacious@iki.fi>
parents:
4127
diff
changeset
|
467 { |
e474286a4c23
Close_ini_file() frees all memory allocated in open_ini_file() (Bugzilla #40)
Jussi Judin <jjudin+audacious@iki.fi>
parents:
4127
diff
changeset
|
468 g_free((gchar*)value); |
e474286a4c23
Close_ini_file() frees all memory allocated in open_ini_file() (Bugzilla #40)
Jussi Judin <jjudin+audacious@iki.fi>
parents:
4127
diff
changeset
|
469 } |
e474286a4c23
Close_ini_file() frees all memory allocated in open_ini_file() (Bugzilla #40)
Jussi Judin <jjudin+audacious@iki.fi>
parents:
4127
diff
changeset
|
470 |
e474286a4c23
Close_ini_file() frees all memory allocated in open_ini_file() (Bugzilla #40)
Jussi Judin <jjudin+audacious@iki.fi>
parents:
4127
diff
changeset
|
471 static void |
e474286a4c23
Close_ini_file() frees all memory allocated in open_ini_file() (Bugzilla #40)
Jussi Judin <jjudin+audacious@iki.fi>
parents:
4127
diff
changeset
|
472 close_ini_file_free_section(gpointer section) |
e474286a4c23
Close_ini_file() frees all memory allocated in open_ini_file() (Bugzilla #40)
Jussi Judin <jjudin+audacious@iki.fi>
parents:
4127
diff
changeset
|
473 { |
e474286a4c23
Close_ini_file() frees all memory allocated in open_ini_file() (Bugzilla #40)
Jussi Judin <jjudin+audacious@iki.fi>
parents:
4127
diff
changeset
|
474 g_hash_table_destroy((GHashTable*)section); |
e474286a4c23
Close_ini_file() frees all memory allocated in open_ini_file() (Bugzilla #40)
Jussi Judin <jjudin+audacious@iki.fi>
parents:
4127
diff
changeset
|
475 } |
e474286a4c23
Close_ini_file() frees all memory allocated in open_ini_file() (Bugzilla #40)
Jussi Judin <jjudin+audacious@iki.fi>
parents:
4127
diff
changeset
|
476 |
2529 | 477 INIFile * |
478 open_ini_file(const gchar *filename) | |
2313 | 479 { |
4157
e474286a4c23
Close_ini_file() frees all memory allocated in open_ini_file() (Bugzilla #40)
Jussi Judin <jjudin+audacious@iki.fi>
parents:
4127
diff
changeset
|
480 GHashTable *ini_file = NULL; |
e474286a4c23
Close_ini_file() frees all memory allocated in open_ini_file() (Bugzilla #40)
Jussi Judin <jjudin+audacious@iki.fi>
parents:
4127
diff
changeset
|
481 GHashTable *section = NULL; |
2529 | 482 GString *section_name, *key_name, *value; |
483 gpointer section_hash, key_hash; | |
484 gchar *buffer = NULL; | |
2313 | 485 gsize off = 0; |
2529 | 486 gsize filesize = 0; |
487 | |
2313 | 488 unsigned char x[] = { 0xff, 0xfe, 0x00 }; |
2529 | 489 |
490 g_return_val_if_fail(filename, NULL); | |
491 vfs_file_get_contents(filename, &buffer, &filesize); | |
492 if (buffer == NULL) | |
2313 | 493 return NULL; |
494 | |
495 /* | |
496 * Convert UTF-16 into something useful. Original implementation | |
497 * by incomp@#audacious. Cleanups \nenolod | |
2529 | 498 * FIXME: can't we use a GLib function for that? -- 01mf02 |
2313 | 499 */ |
2607
65543c999c7e
[svn] Check filesize before doing memcmp (potential sigsegv).
hansmi
parents:
2556
diff
changeset
|
500 if (filesize > 2 && !memcmp(&buffer[0],&x,2)) |
2529 | 501 { |
502 gchar *outbuf = g_malloc (filesize); /* it's safe to waste memory. */ | |
503 guint counter; | |
2313 | 504 |
505 for (counter = 2; counter < filesize; counter += 2) | |
2529 | 506 { |
4157
e474286a4c23
Close_ini_file() frees all memory allocated in open_ini_file() (Bugzilla #40)
Jussi Judin <jjudin+audacious@iki.fi>
parents:
4127
diff
changeset
|
507 if (!memcmp(&buffer[counter+1], &x[2], 1)) { |
2313 | 508 outbuf[(counter-2)/2] = buffer[counter]; |
4157
e474286a4c23
Close_ini_file() frees all memory allocated in open_ini_file() (Bugzilla #40)
Jussi Judin <jjudin+audacious@iki.fi>
parents:
4127
diff
changeset
|
509 } else { |
e474286a4c23
Close_ini_file() frees all memory allocated in open_ini_file() (Bugzilla #40)
Jussi Judin <jjudin+audacious@iki.fi>
parents:
4127
diff
changeset
|
510 g_free(buffer); |
e474286a4c23
Close_ini_file() frees all memory allocated in open_ini_file() (Bugzilla #40)
Jussi Judin <jjudin+audacious@iki.fi>
parents:
4127
diff
changeset
|
511 g_free(outbuf); |
2529 | 512 return NULL; |
4157
e474286a4c23
Close_ini_file() frees all memory allocated in open_ini_file() (Bugzilla #40)
Jussi Judin <jjudin+audacious@iki.fi>
parents:
4127
diff
changeset
|
513 } |
2529 | 514 } |
2313 | 515 |
516 outbuf[(counter-2)/2] = '\0'; | |
517 | |
2529 | 518 if ((filesize - 2) / 2 == (counter - 2) / 2) |
519 { | |
2313 | 520 g_free(buffer); |
521 buffer = outbuf; | |
2529 | 522 } |
523 else | |
524 { | |
4157
e474286a4c23
Close_ini_file() frees all memory allocated in open_ini_file() (Bugzilla #40)
Jussi Judin <jjudin+audacious@iki.fi>
parents:
4127
diff
changeset
|
525 g_free(buffer); |
2313 | 526 g_free(outbuf); |
2529 | 527 return NULL; /* XXX wrong encoding */ |
2313 | 528 } |
529 } | |
530 | |
4157
e474286a4c23
Close_ini_file() frees all memory allocated in open_ini_file() (Bugzilla #40)
Jussi Judin <jjudin+audacious@iki.fi>
parents:
4127
diff
changeset
|
531 section_name = g_string_new(""); |
e474286a4c23
Close_ini_file() frees all memory allocated in open_ini_file() (Bugzilla #40)
Jussi Judin <jjudin+audacious@iki.fi>
parents:
4127
diff
changeset
|
532 key_name = g_string_new(NULL); |
e474286a4c23
Close_ini_file() frees all memory allocated in open_ini_file() (Bugzilla #40)
Jussi Judin <jjudin+audacious@iki.fi>
parents:
4127
diff
changeset
|
533 value = g_string_new(NULL); |
e474286a4c23
Close_ini_file() frees all memory allocated in open_ini_file() (Bugzilla #40)
Jussi Judin <jjudin+audacious@iki.fi>
parents:
4127
diff
changeset
|
534 |
e474286a4c23
Close_ini_file() frees all memory allocated in open_ini_file() (Bugzilla #40)
Jussi Judin <jjudin+audacious@iki.fi>
parents:
4127
diff
changeset
|
535 ini_file = g_hash_table_new_full(NULL, NULL, NULL, |
e474286a4c23
Close_ini_file() frees all memory allocated in open_ini_file() (Bugzilla #40)
Jussi Judin <jjudin+audacious@iki.fi>
parents:
4127
diff
changeset
|
536 close_ini_file_free_section); |
e474286a4c23
Close_ini_file() frees all memory allocated in open_ini_file() (Bugzilla #40)
Jussi Judin <jjudin+audacious@iki.fi>
parents:
4127
diff
changeset
|
537 section = g_hash_table_new_full(NULL, NULL, NULL, |
e474286a4c23
Close_ini_file() frees all memory allocated in open_ini_file() (Bugzilla #40)
Jussi Judin <jjudin+audacious@iki.fi>
parents:
4127
diff
changeset
|
538 close_ini_file_free_value); |
e474286a4c23
Close_ini_file() frees all memory allocated in open_ini_file() (Bugzilla #40)
Jussi Judin <jjudin+audacious@iki.fi>
parents:
4127
diff
changeset
|
539 /* make a nameless section which should store all entries that are not |
e474286a4c23
Close_ini_file() frees all memory allocated in open_ini_file() (Bugzilla #40)
Jussi Judin <jjudin+audacious@iki.fi>
parents:
4127
diff
changeset
|
540 * embedded in a section */ |
e474286a4c23
Close_ini_file() frees all memory allocated in open_ini_file() (Bugzilla #40)
Jussi Judin <jjudin+audacious@iki.fi>
parents:
4127
diff
changeset
|
541 section_hash = GINT_TO_POINTER(g_string_hash(section_name)); |
e474286a4c23
Close_ini_file() frees all memory allocated in open_ini_file() (Bugzilla #40)
Jussi Judin <jjudin+audacious@iki.fi>
parents:
4127
diff
changeset
|
542 g_hash_table_insert(ini_file, section_hash, section); |
e474286a4c23
Close_ini_file() frees all memory allocated in open_ini_file() (Bugzilla #40)
Jussi Judin <jjudin+audacious@iki.fi>
parents:
4127
diff
changeset
|
543 |
2529 | 544 while (off < filesize) |
545 { | |
546 /* ignore the following characters */ | |
547 if (buffer[off] == '\r' || buffer[off] == '\n' || | |
548 buffer[off] == ' ' || buffer[off] == '\t') | |
549 { | |
550 if (buffer[off] == '\n') | |
551 { | |
552 g_string_free(key_name, TRUE); | |
4095
7e57ace6385a
Fix memory leak in open_ini_file() function. (Bugzilla #17)
Jussi Judin <jjudin+audacious@iki.fi>
parents:
4073
diff
changeset
|
553 g_string_free(value, TRUE); |
2529 | 554 key_name = g_string_new(NULL); |
555 value = g_string_new(NULL); | |
556 } | |
557 | |
558 off++; | |
559 continue; | |
560 } | |
561 | |
562 /* if we encounter a possible section statement */ | |
563 if (buffer[off] == '[') | |
564 { | |
565 g_string_free(section_name, TRUE); | |
566 section_name = g_string_new(NULL); | |
2313 | 567 off++; |
2529 | 568 |
569 if (off >= filesize) | |
570 goto return_sequence; | |
571 | |
572 while (buffer[off] != ']') | |
573 { | |
574 /* if the section statement has not been closed before a | |
575 * linebreak */ | |
576 if (buffer[off] == '\n') | |
577 break; | |
578 | |
579 g_string_append_c(section_name, buffer[off]); | |
580 off++; | |
581 if (off >= filesize) | |
582 goto return_sequence; | |
583 } | |
584 if (buffer[off] == '\n') | |
585 continue; | |
586 if (buffer[off] == ']') | |
587 { | |
588 off++; | |
589 if (off >= filesize) | |
590 goto return_sequence; | |
591 | |
592 strip_lower_string(section_name); | |
593 section_hash = GINT_TO_POINTER(g_string_hash(section_name)); | |
594 | |
595 /* if this section already exists, we don't make a new one, | |
596 * but reuse the old one */ | |
597 if (g_hash_table_lookup(ini_file, section_hash) != NULL) | |
598 section = g_hash_table_lookup(ini_file, section_hash); | |
599 else | |
600 { | |
4157
e474286a4c23
Close_ini_file() frees all memory allocated in open_ini_file() (Bugzilla #40)
Jussi Judin <jjudin+audacious@iki.fi>
parents:
4127
diff
changeset
|
601 section = g_hash_table_new_full(NULL, NULL, NULL, |
e474286a4c23
Close_ini_file() frees all memory allocated in open_ini_file() (Bugzilla #40)
Jussi Judin <jjudin+audacious@iki.fi>
parents:
4127
diff
changeset
|
602 close_ini_file_free_value); |
2529 | 603 g_hash_table_insert(ini_file, section_hash, section); |
2313 | 604 } |
2529 | 605 |
606 continue; | |
2313 | 607 } |
608 } | |
2529 | 609 |
610 if (buffer[off] == '=') | |
611 { | |
612 off++; | |
2313 | 613 if (off >= filesize) |
2529 | 614 goto return_sequence; |
615 | |
2556 | 616 while (buffer[off] != '\n' && buffer[off] != '\r') |
2529 | 617 { |
618 g_string_append_c(value, buffer[off]); | |
2313 | 619 off++; |
620 if (off >= filesize) | |
621 break; | |
622 } | |
2529 | 623 |
624 strip_lower_string(key_name); | |
625 key_hash = GINT_TO_POINTER(g_string_hash(key_name)); | |
626 strip_string(value); | |
627 | |
628 if (key_name->len > 0 && value->len > 0) | |
2609 | 629 g_hash_table_insert(section, key_hash, g_strdup(value->str)); |
2313 | 630 } |
2529 | 631 else |
632 { | |
633 g_string_append_c(key_name, buffer[off]); | |
2313 | 634 off++; |
2529 | 635 if (off >= filesize) |
636 goto return_sequence; | |
637 } | |
2313 | 638 } |
639 | |
2529 | 640 return_sequence: |
641 g_string_free(section_name, TRUE); | |
642 g_string_free(key_name, TRUE); | |
643 g_string_free(value, TRUE); | |
644 g_free(buffer); | |
645 return ini_file; | |
646 } | |
647 | |
4157
e474286a4c23
Close_ini_file() frees all memory allocated in open_ini_file() (Bugzilla #40)
Jussi Judin <jjudin+audacious@iki.fi>
parents:
4127
diff
changeset
|
648 /** |
e474286a4c23
Close_ini_file() frees all memory allocated in open_ini_file() (Bugzilla #40)
Jussi Judin <jjudin+audacious@iki.fi>
parents:
4127
diff
changeset
|
649 * Frees the memory allocated for inifile. |
e474286a4c23
Close_ini_file() frees all memory allocated in open_ini_file() (Bugzilla #40)
Jussi Judin <jjudin+audacious@iki.fi>
parents:
4127
diff
changeset
|
650 */ |
2529 | 651 void |
652 close_ini_file(INIFile *inifile) | |
653 { | |
654 g_return_if_fail(inifile); | |
655 g_hash_table_destroy(inifile); | |
656 } | |
657 | |
4157
e474286a4c23
Close_ini_file() frees all memory allocated in open_ini_file() (Bugzilla #40)
Jussi Judin <jjudin+audacious@iki.fi>
parents:
4127
diff
changeset
|
658 /** |
e474286a4c23
Close_ini_file() frees all memory allocated in open_ini_file() (Bugzilla #40)
Jussi Judin <jjudin+audacious@iki.fi>
parents:
4127
diff
changeset
|
659 * Returns a string that corresponds to correct section and key in inifile. |
e474286a4c23
Close_ini_file() frees all memory allocated in open_ini_file() (Bugzilla #40)
Jussi Judin <jjudin+audacious@iki.fi>
parents:
4127
diff
changeset
|
660 * |
e474286a4c23
Close_ini_file() frees all memory allocated in open_ini_file() (Bugzilla #40)
Jussi Judin <jjudin+audacious@iki.fi>
parents:
4127
diff
changeset
|
661 * Returns NULL if value was not found in inifile. Otherwise returns a copy |
e474286a4c23
Close_ini_file() frees all memory allocated in open_ini_file() (Bugzilla #40)
Jussi Judin <jjudin+audacious@iki.fi>
parents:
4127
diff
changeset
|
662 * of string pointed by "section" and "key". Returned string should be freed |
e474286a4c23
Close_ini_file() frees all memory allocated in open_ini_file() (Bugzilla #40)
Jussi Judin <jjudin+audacious@iki.fi>
parents:
4127
diff
changeset
|
663 * after use. |
e474286a4c23
Close_ini_file() frees all memory allocated in open_ini_file() (Bugzilla #40)
Jussi Judin <jjudin+audacious@iki.fi>
parents:
4127
diff
changeset
|
664 */ |
2529 | 665 gchar * |
666 read_ini_string(INIFile *inifile, const gchar *section, const gchar *key) | |
667 { | |
2660
8d0b89db56e5
[svn] - fixed c++ish declaration in a c file (part 7)
giacomo
parents:
2635
diff
changeset
|
668 GString *section_string; |
8d0b89db56e5
[svn] - fixed c++ish declaration in a c file (part 7)
giacomo
parents:
2635
diff
changeset
|
669 GString *key_string; |
8d0b89db56e5
[svn] - fixed c++ish declaration in a c file (part 7)
giacomo
parents:
2635
diff
changeset
|
670 gchar *value = NULL; |
8d0b89db56e5
[svn] - fixed c++ish declaration in a c file (part 7)
giacomo
parents:
2635
diff
changeset
|
671 gpointer section_hash, key_hash; |
8d0b89db56e5
[svn] - fixed c++ish declaration in a c file (part 7)
giacomo
parents:
2635
diff
changeset
|
672 GHashTable *section_table; |
8d0b89db56e5
[svn] - fixed c++ish declaration in a c file (part 7)
giacomo
parents:
2635
diff
changeset
|
673 |
2529 | 674 g_return_val_if_fail(inifile, NULL); |
675 | |
2660
8d0b89db56e5
[svn] - fixed c++ish declaration in a c file (part 7)
giacomo
parents:
2635
diff
changeset
|
676 section_string = g_string_new(section); |
8d0b89db56e5
[svn] - fixed c++ish declaration in a c file (part 7)
giacomo
parents:
2635
diff
changeset
|
677 key_string = g_string_new(key); |
8d0b89db56e5
[svn] - fixed c++ish declaration in a c file (part 7)
giacomo
parents:
2635
diff
changeset
|
678 value = NULL; |
2529 | 679 |
680 strip_lower_string(section_string); | |
681 strip_lower_string(key_string); | |
2660
8d0b89db56e5
[svn] - fixed c++ish declaration in a c file (part 7)
giacomo
parents:
2635
diff
changeset
|
682 section_hash = GINT_TO_POINTER(g_string_hash(section_string)); |
8d0b89db56e5
[svn] - fixed c++ish declaration in a c file (part 7)
giacomo
parents:
2635
diff
changeset
|
683 key_hash = GINT_TO_POINTER(g_string_hash(key_string)); |
4097
96194518173c
Fix memory leak in read_ini_string() (Bugzilla #24)
Jussi Judin <jjudin+audacious@iki.fi>
parents:
4095
diff
changeset
|
684 section_table = g_hash_table_lookup(inifile, section_hash); |
2529 | 685 |
4097
96194518173c
Fix memory leak in read_ini_string() (Bugzilla #24)
Jussi Judin <jjudin+audacious@iki.fi>
parents:
4095
diff
changeset
|
686 if (section_table) { |
4157
e474286a4c23
Close_ini_file() frees all memory allocated in open_ini_file() (Bugzilla #40)
Jussi Judin <jjudin+audacious@iki.fi>
parents:
4127
diff
changeset
|
687 value = g_strdup(g_hash_table_lookup(section_table, |
e474286a4c23
Close_ini_file() frees all memory allocated in open_ini_file() (Bugzilla #40)
Jussi Judin <jjudin+audacious@iki.fi>
parents:
4127
diff
changeset
|
688 GINT_TO_POINTER(key_hash))); |
4097
96194518173c
Fix memory leak in read_ini_string() (Bugzilla #24)
Jussi Judin <jjudin+audacious@iki.fi>
parents:
4095
diff
changeset
|
689 } |
2529 | 690 |
4097
96194518173c
Fix memory leak in read_ini_string() (Bugzilla #24)
Jussi Judin <jjudin+audacious@iki.fi>
parents:
4095
diff
changeset
|
691 g_string_free(section_string, TRUE); |
96194518173c
Fix memory leak in read_ini_string() (Bugzilla #24)
Jussi Judin <jjudin+audacious@iki.fi>
parents:
4095
diff
changeset
|
692 g_string_free(key_string, TRUE); |
96194518173c
Fix memory leak in read_ini_string() (Bugzilla #24)
Jussi Judin <jjudin+audacious@iki.fi>
parents:
4095
diff
changeset
|
693 |
96194518173c
Fix memory leak in read_ini_string() (Bugzilla #24)
Jussi Judin <jjudin+audacious@iki.fi>
parents:
4095
diff
changeset
|
694 g_return_val_if_fail(value, NULL); |
2529 | 695 return value; |
2313 | 696 } |
697 | |
698 GArray * | |
2529 | 699 read_ini_array(INIFile *inifile, const gchar *section, const gchar *key) |
2514
7934ac463591
[svn] - removed unused function bmp_menu_translate()
mf0102
parents:
2494
diff
changeset
|
700 { |
7934ac463591
[svn] - removed unused function bmp_menu_translate()
mf0102
parents:
2494
diff
changeset
|
701 gchar *temp; |
7934ac463591
[svn] - removed unused function bmp_menu_translate()
mf0102
parents:
2494
diff
changeset
|
702 GArray *a; |
7934ac463591
[svn] - removed unused function bmp_menu_translate()
mf0102
parents:
2494
diff
changeset
|
703 |
2529 | 704 g_return_val_if_fail((temp = read_ini_string(inifile, section, key)), NULL); |
705 | |
2514
7934ac463591
[svn] - removed unused function bmp_menu_translate()
mf0102
parents:
2494
diff
changeset
|
706 a = string_to_garray(temp); |
7934ac463591
[svn] - removed unused function bmp_menu_translate()
mf0102
parents:
2494
diff
changeset
|
707 g_free(temp); |
7934ac463591
[svn] - removed unused function bmp_menu_translate()
mf0102
parents:
2494
diff
changeset
|
708 return a; |
7934ac463591
[svn] - removed unused function bmp_menu_translate()
mf0102
parents:
2494
diff
changeset
|
709 } |
7934ac463591
[svn] - removed unused function bmp_menu_translate()
mf0102
parents:
2494
diff
changeset
|
710 |
7934ac463591
[svn] - removed unused function bmp_menu_translate()
mf0102
parents:
2494
diff
changeset
|
711 GArray * |
2313 | 712 string_to_garray(const gchar * str) |
713 { | |
714 GArray *array; | |
715 gint temp; | |
716 const gchar *ptr = str; | |
717 gchar *endptr; | |
718 | |
719 array = g_array_new(FALSE, TRUE, sizeof(gint)); | |
720 for (;;) { | |
721 temp = strtol(ptr, &endptr, 10); | |
722 if (ptr == endptr) | |
723 break; | |
724 g_array_append_val(array, temp); | |
725 ptr = endptr; | |
726 while (!isdigit((int) *ptr) && (*ptr) != '\0') | |
727 ptr++; | |
728 if (*ptr == '\0') | |
729 break; | |
730 } | |
731 return (array); | |
732 } | |
733 | |
734 void | |
735 glist_movedown(GList * list) | |
736 { | |
737 gpointer temp; | |
738 | |
739 if (g_list_next(list)) { | |
740 temp = list->data; | |
741 list->data = list->next->data; | |
742 list->next->data = temp; | |
743 } | |
744 } | |
745 | |
746 void | |
747 glist_moveup(GList * list) | |
748 { | |
749 gpointer temp; | |
750 | |
751 if (g_list_previous(list)) { | |
752 temp = list->data; | |
753 list->data = list->prev->data; | |
754 list->prev->data = temp; | |
755 } | |
756 } | |
757 | |
758 | |
759 void | |
760 util_menu_position(GtkMenu * menu, gint * x, gint * y, | |
761 gboolean * push_in, gpointer data) | |
762 { | |
763 GtkRequisition requisition; | |
764 gint screen_width; | |
765 gint screen_height; | |
766 MenuPos *pos = data; | |
767 | |
768 gtk_widget_size_request(GTK_WIDGET(menu), &requisition); | |
769 | |
770 screen_width = gdk_screen_width(); | |
771 screen_height = gdk_screen_height(); | |
772 | |
773 *x = CLAMP(pos->x - 2, 0, MAX(0, screen_width - requisition.width)); | |
774 *y = CLAMP(pos->y - 2, 0, MAX(0, screen_height - requisition.height)); | |
775 } | |
776 | |
777 GdkFont * | |
778 util_font_load(const gchar * name) | |
779 { | |
780 GdkFont *font; | |
781 PangoFontDescription *desc; | |
782 | |
783 desc = pango_font_description_from_string(name); | |
784 font = gdk_font_from_description(desc); | |
785 | |
786 return font; | |
787 } | |
788 | |
789 /* text_get_extents() taken from The GIMP (C) Spencer Kimball, Peter | |
790 * Mattis et al */ | |
791 gboolean | |
792 text_get_extents(const gchar * fontname, | |
793 const gchar * text, | |
794 gint * width, gint * height, gint * ascent, gint * descent) | |
795 { | |
796 PangoFontDescription *font_desc; | |
797 PangoLayout *layout; | |
798 PangoRectangle rect; | |
799 | |
800 g_return_val_if_fail(fontname != NULL, FALSE); | |
801 g_return_val_if_fail(text != NULL, FALSE); | |
802 | |
803 /* FIXME: resolution */ | |
804 layout = gtk_widget_create_pango_layout(GTK_WIDGET(mainwin), text); | |
805 | |
806 font_desc = pango_font_description_from_string(fontname); | |
807 pango_layout_set_font_description(layout, font_desc); | |
808 pango_font_description_free(font_desc); | |
809 pango_layout_get_pixel_extents(layout, NULL, &rect); | |
810 | |
811 if (width) | |
812 *width = rect.width; | |
813 if (height) | |
814 *height = rect.height; | |
815 | |
816 if (ascent || descent) { | |
817 PangoLayoutIter *iter; | |
818 PangoLayoutLine *line; | |
819 | |
820 iter = pango_layout_get_iter(layout); | |
821 line = pango_layout_iter_get_line(iter); | |
822 pango_layout_iter_free(iter); | |
823 | |
824 pango_layout_line_get_pixel_extents(line, NULL, &rect); | |
825 | |
826 if (ascent) | |
827 *ascent = PANGO_ASCENT(rect); | |
828 if (descent) | |
829 *descent = -PANGO_DESCENT(rect); | |
830 } | |
831 | |
832 g_object_unref(layout); | |
833 | |
834 return TRUE; | |
835 } | |
836 | |
837 /* counts number of digits in a gint */ | |
838 guint | |
839 gint_count_digits(gint n) | |
840 { | |
841 guint count = 0; | |
842 | |
843 n = ABS(n); | |
844 do { | |
845 count++; | |
846 n /= 10; | |
847 } while (n > 0); | |
848 | |
849 return count; | |
850 } | |
851 | |
852 gboolean | |
853 dir_foreach(const gchar * path, DirForeachFunc function, | |
854 gpointer user_data, GError ** error) | |
855 { | |
856 GError *error_out = NULL; | |
857 GDir *dir; | |
858 const gchar *entry; | |
859 gchar *entry_fullpath; | |
860 | |
861 if (!(dir = g_dir_open(path, 0, &error_out))) { | |
862 g_propagate_error(error, error_out); | |
863 return FALSE; | |
864 } | |
865 | |
866 while ((entry = g_dir_read_name(dir))) { | |
867 entry_fullpath = g_build_filename(path, entry, NULL); | |
868 | |
869 if ((*function) (entry_fullpath, entry, user_data)) { | |
870 g_free(entry_fullpath); | |
871 break; | |
872 } | |
873 | |
874 g_free(entry_fullpath); | |
875 } | |
876 | |
877 g_dir_close(dir); | |
878 | |
879 return TRUE; | |
880 } | |
881 | |
882 GtkWidget * | |
2514
7934ac463591
[svn] - removed unused function bmp_menu_translate()
mf0102
parents:
2494
diff
changeset
|
883 make_filebrowser(const gchar *title, gboolean save) |
2313 | 884 { |
885 GtkWidget *dialog; | |
886 GtkWidget *button; | |
887 | |
888 g_return_val_if_fail(title != NULL, NULL); | |
889 | |
890 dialog = gtk_file_chooser_dialog_new(title, GTK_WINDOW(mainwin), | |
2514
7934ac463591
[svn] - removed unused function bmp_menu_translate()
mf0102
parents:
2494
diff
changeset
|
891 save ? |
7934ac463591
[svn] - removed unused function bmp_menu_translate()
mf0102
parents:
2494
diff
changeset
|
892 GTK_FILE_CHOOSER_ACTION_SAVE : |
7934ac463591
[svn] - removed unused function bmp_menu_translate()
mf0102
parents:
2494
diff
changeset
|
893 GTK_FILE_CHOOSER_ACTION_OPEN, |
7934ac463591
[svn] - removed unused function bmp_menu_translate()
mf0102
parents:
2494
diff
changeset
|
894 NULL, NULL); |
2313 | 895 |
2514
7934ac463591
[svn] - removed unused function bmp_menu_translate()
mf0102
parents:
2494
diff
changeset
|
896 button = gtk_dialog_add_button(GTK_DIALOG(dialog), GTK_STOCK_CANCEL, |
7934ac463591
[svn] - removed unused function bmp_menu_translate()
mf0102
parents:
2494
diff
changeset
|
897 GTK_RESPONSE_REJECT); |
2313 | 898 |
2514
7934ac463591
[svn] - removed unused function bmp_menu_translate()
mf0102
parents:
2494
diff
changeset
|
899 gtk_button_set_use_stock(GTK_BUTTON(button), TRUE); |
7934ac463591
[svn] - removed unused function bmp_menu_translate()
mf0102
parents:
2494
diff
changeset
|
900 GTK_WIDGET_SET_FLAGS(button, GTK_CAN_DEFAULT); |
2313 | 901 |
902 button = gtk_dialog_add_button(GTK_DIALOG(dialog), save ? | |
903 GTK_STOCK_SAVE : GTK_STOCK_OPEN, | |
904 GTK_RESPONSE_ACCEPT); | |
2514
7934ac463591
[svn] - removed unused function bmp_menu_translate()
mf0102
parents:
2494
diff
changeset
|
905 |
2313 | 906 gtk_button_set_use_stock(GTK_BUTTON(button), TRUE); |
2514
7934ac463591
[svn] - removed unused function bmp_menu_translate()
mf0102
parents:
2494
diff
changeset
|
907 gtk_dialog_set_default_response(GTK_DIALOG(dialog), GTK_RESPONSE_ACCEPT); |
2635 | 908 gtk_window_set_position(GTK_WINDOW(dialog), GTK_WIN_POS_CENTER); /* centering */ |
2313 | 909 |
910 return dialog; | |
911 } | |
912 | |
4212
47352b34dbdf
introduce ui_skinned_widget_draw
Tomasz Mon <desowin@gmail.com>
parents:
4157
diff
changeset
|
913 void ui_skinned_widget_draw(GtkWidget *widget, GdkPixbuf *obj, gint width, gint height, gboolean scale) { |
47352b34dbdf
introduce ui_skinned_widget_draw
Tomasz Mon <desowin@gmail.com>
parents:
4157
diff
changeset
|
914 g_return_if_fail(widget != NULL); |
47352b34dbdf
introduce ui_skinned_widget_draw
Tomasz Mon <desowin@gmail.com>
parents:
4157
diff
changeset
|
915 g_return_if_fail(obj != NULL); |
47352b34dbdf
introduce ui_skinned_widget_draw
Tomasz Mon <desowin@gmail.com>
parents:
4157
diff
changeset
|
916 |
47352b34dbdf
introduce ui_skinned_widget_draw
Tomasz Mon <desowin@gmail.com>
parents:
4157
diff
changeset
|
917 if (scale) { |
4223
2c9c2b5caaee
changed the hardcoded scale to 1.2 and set some dither and interpolation
Cristi Magherusan <majeru@atheme.org>
parents:
4218
diff
changeset
|
918 GdkPixbuf *image = gdk_pixbuf_scale_simple(obj, width * cfg.scale_factor, height* cfg.scale_factor, GDK_INTERP_BILINEAR); |
2c9c2b5caaee
changed the hardcoded scale to 1.2 and set some dither and interpolation
Cristi Magherusan <majeru@atheme.org>
parents:
4218
diff
changeset
|
919 gdk_draw_pixbuf(widget->window, NULL, image, 0, 0, 0, 0, width * cfg.scale_factor , height * cfg.scale_factor, GDK_RGB_DITHER_NORMAL, 0, 0); |
4212
47352b34dbdf
introduce ui_skinned_widget_draw
Tomasz Mon <desowin@gmail.com>
parents:
4157
diff
changeset
|
920 g_object_unref(image); |
47352b34dbdf
introduce ui_skinned_widget_draw
Tomasz Mon <desowin@gmail.com>
parents:
4157
diff
changeset
|
921 } else { |
47352b34dbdf
introduce ui_skinned_widget_draw
Tomasz Mon <desowin@gmail.com>
parents:
4157
diff
changeset
|
922 gdk_draw_pixbuf(widget->window, NULL, obj, 0, 0, 0, 0, width, height, GDK_RGB_DITHER_NONE, 0, 0); |
47352b34dbdf
introduce ui_skinned_widget_draw
Tomasz Mon <desowin@gmail.com>
parents:
4157
diff
changeset
|
923 } |
47352b34dbdf
introduce ui_skinned_widget_draw
Tomasz Mon <desowin@gmail.com>
parents:
4157
diff
changeset
|
924 } |
47352b34dbdf
introduce ui_skinned_widget_draw
Tomasz Mon <desowin@gmail.com>
parents:
4157
diff
changeset
|
925 |
2421
74ec16ef847b
[svn] - fix accidental removal of xmms_show_message
nenolod
parents:
2416
diff
changeset
|
926 /** |
74ec16ef847b
[svn] - fix accidental removal of xmms_show_message
nenolod
parents:
2416
diff
changeset
|
927 * xmms_show_message: |
74ec16ef847b
[svn] - fix accidental removal of xmms_show_message
nenolod
parents:
2416
diff
changeset
|
928 * @title: The title of the message to show. |
74ec16ef847b
[svn] - fix accidental removal of xmms_show_message
nenolod
parents:
2416
diff
changeset
|
929 * @text: The text of the message to show. |
74ec16ef847b
[svn] - fix accidental removal of xmms_show_message
nenolod
parents:
2416
diff
changeset
|
930 * @button_text: The text of the button which will close the messagebox. |
74ec16ef847b
[svn] - fix accidental removal of xmms_show_message
nenolod
parents:
2416
diff
changeset
|
931 * @modal: Whether or not the messagebox should be modal. |
74ec16ef847b
[svn] - fix accidental removal of xmms_show_message
nenolod
parents:
2416
diff
changeset
|
932 * @button_action: Code to execute on when the messagebox is closed, or %NULL. |
74ec16ef847b
[svn] - fix accidental removal of xmms_show_message
nenolod
parents:
2416
diff
changeset
|
933 * @action_data: Optional opaque data to pass to @button_action. |
74ec16ef847b
[svn] - fix accidental removal of xmms_show_message
nenolod
parents:
2416
diff
changeset
|
934 * |
74ec16ef847b
[svn] - fix accidental removal of xmms_show_message
nenolod
parents:
2416
diff
changeset
|
935 * Displays a message box. |
74ec16ef847b
[svn] - fix accidental removal of xmms_show_message
nenolod
parents:
2416
diff
changeset
|
936 * |
74ec16ef847b
[svn] - fix accidental removal of xmms_show_message
nenolod
parents:
2416
diff
changeset
|
937 * Return value: A GTK widget handle for the message box. |
74ec16ef847b
[svn] - fix accidental removal of xmms_show_message
nenolod
parents:
2416
diff
changeset
|
938 **/ |
74ec16ef847b
[svn] - fix accidental removal of xmms_show_message
nenolod
parents:
2416
diff
changeset
|
939 GtkWidget * |
3731
0e5da33a32b7
fun util dialog shit -> vtable
William Pitcock <nenolod@atheme.org>
parents:
3730
diff
changeset
|
940 util_info_dialog(const gchar * title, const gchar * text, |
0e5da33a32b7
fun util dialog shit -> vtable
William Pitcock <nenolod@atheme.org>
parents:
3730
diff
changeset
|
941 const gchar * button_text, gboolean modal, |
0e5da33a32b7
fun util dialog shit -> vtable
William Pitcock <nenolod@atheme.org>
parents:
3730
diff
changeset
|
942 GCallback button_action, gpointer action_data) |
2421
74ec16ef847b
[svn] - fix accidental removal of xmms_show_message
nenolod
parents:
2416
diff
changeset
|
943 { |
74ec16ef847b
[svn] - fix accidental removal of xmms_show_message
nenolod
parents:
2416
diff
changeset
|
944 GtkWidget *dialog; |
74ec16ef847b
[svn] - fix accidental removal of xmms_show_message
nenolod
parents:
2416
diff
changeset
|
945 GtkWidget *dialog_vbox, *dialog_hbox, *dialog_bbox; |
74ec16ef847b
[svn] - fix accidental removal of xmms_show_message
nenolod
parents:
2416
diff
changeset
|
946 GtkWidget *dialog_bbox_b1; |
74ec16ef847b
[svn] - fix accidental removal of xmms_show_message
nenolod
parents:
2416
diff
changeset
|
947 GtkWidget *dialog_textlabel; |
74ec16ef847b
[svn] - fix accidental removal of xmms_show_message
nenolod
parents:
2416
diff
changeset
|
948 GtkWidget *dialog_icon; |
74ec16ef847b
[svn] - fix accidental removal of xmms_show_message
nenolod
parents:
2416
diff
changeset
|
949 |
74ec16ef847b
[svn] - fix accidental removal of xmms_show_message
nenolod
parents:
2416
diff
changeset
|
950 dialog = gtk_window_new(GTK_WINDOW_TOPLEVEL); |
74ec16ef847b
[svn] - fix accidental removal of xmms_show_message
nenolod
parents:
2416
diff
changeset
|
951 gtk_window_set_type_hint( GTK_WINDOW(dialog) , GDK_WINDOW_TYPE_HINT_DIALOG ); |
74ec16ef847b
[svn] - fix accidental removal of xmms_show_message
nenolod
parents:
2416
diff
changeset
|
952 gtk_window_set_modal( GTK_WINDOW(dialog) , modal ); |
74ec16ef847b
[svn] - fix accidental removal of xmms_show_message
nenolod
parents:
2416
diff
changeset
|
953 gtk_window_set_title( GTK_WINDOW(dialog) , title ); |
74ec16ef847b
[svn] - fix accidental removal of xmms_show_message
nenolod
parents:
2416
diff
changeset
|
954 gtk_container_set_border_width( GTK_CONTAINER(dialog) , 10 ); |
74ec16ef847b
[svn] - fix accidental removal of xmms_show_message
nenolod
parents:
2416
diff
changeset
|
955 |
74ec16ef847b
[svn] - fix accidental removal of xmms_show_message
nenolod
parents:
2416
diff
changeset
|
956 dialog_vbox = gtk_vbox_new( FALSE , 0 ); |
74ec16ef847b
[svn] - fix accidental removal of xmms_show_message
nenolod
parents:
2416
diff
changeset
|
957 dialog_hbox = gtk_hbox_new( FALSE , 0 ); |
74ec16ef847b
[svn] - fix accidental removal of xmms_show_message
nenolod
parents:
2416
diff
changeset
|
958 |
74ec16ef847b
[svn] - fix accidental removal of xmms_show_message
nenolod
parents:
2416
diff
changeset
|
959 /* icon */ |
74ec16ef847b
[svn] - fix accidental removal of xmms_show_message
nenolod
parents:
2416
diff
changeset
|
960 dialog_icon = gtk_image_new_from_stock( GTK_STOCK_DIALOG_INFO , GTK_ICON_SIZE_DIALOG ); |
74ec16ef847b
[svn] - fix accidental removal of xmms_show_message
nenolod
parents:
2416
diff
changeset
|
961 gtk_box_pack_start( GTK_BOX(dialog_hbox) , dialog_icon , FALSE , FALSE , 2 ); |
74ec16ef847b
[svn] - fix accidental removal of xmms_show_message
nenolod
parents:
2416
diff
changeset
|
962 |
74ec16ef847b
[svn] - fix accidental removal of xmms_show_message
nenolod
parents:
2416
diff
changeset
|
963 /* label */ |
74ec16ef847b
[svn] - fix accidental removal of xmms_show_message
nenolod
parents:
2416
diff
changeset
|
964 dialog_textlabel = gtk_label_new( text ); |
74ec16ef847b
[svn] - fix accidental removal of xmms_show_message
nenolod
parents:
2416
diff
changeset
|
965 /* gtk_label_set_selectable( GTK_LABEL(dialog_textlabel) , TRUE ); */ |
74ec16ef847b
[svn] - fix accidental removal of xmms_show_message
nenolod
parents:
2416
diff
changeset
|
966 gtk_box_pack_start( GTK_BOX(dialog_hbox) , dialog_textlabel , TRUE , TRUE , 2 ); |
74ec16ef847b
[svn] - fix accidental removal of xmms_show_message
nenolod
parents:
2416
diff
changeset
|
967 |
74ec16ef847b
[svn] - fix accidental removal of xmms_show_message
nenolod
parents:
2416
diff
changeset
|
968 gtk_box_pack_start( GTK_BOX(dialog_vbox) , dialog_hbox , FALSE , FALSE , 2 ); |
74ec16ef847b
[svn] - fix accidental removal of xmms_show_message
nenolod
parents:
2416
diff
changeset
|
969 gtk_box_pack_start( GTK_BOX(dialog_vbox) , gtk_hseparator_new() , FALSE , FALSE , 4 ); |
74ec16ef847b
[svn] - fix accidental removal of xmms_show_message
nenolod
parents:
2416
diff
changeset
|
970 |
74ec16ef847b
[svn] - fix accidental removal of xmms_show_message
nenolod
parents:
2416
diff
changeset
|
971 dialog_bbox = gtk_hbutton_box_new(); |
74ec16ef847b
[svn] - fix accidental removal of xmms_show_message
nenolod
parents:
2416
diff
changeset
|
972 gtk_button_box_set_layout( GTK_BUTTON_BOX(dialog_bbox) , GTK_BUTTONBOX_END ); |
74ec16ef847b
[svn] - fix accidental removal of xmms_show_message
nenolod
parents:
2416
diff
changeset
|
973 dialog_bbox_b1 = gtk_button_new_with_label( button_text ); |
74ec16ef847b
[svn] - fix accidental removal of xmms_show_message
nenolod
parents:
2416
diff
changeset
|
974 g_signal_connect_swapped( G_OBJECT(dialog_bbox_b1) , "clicked" , |
74ec16ef847b
[svn] - fix accidental removal of xmms_show_message
nenolod
parents:
2416
diff
changeset
|
975 G_CALLBACK(gtk_widget_destroy) , dialog ); |
74ec16ef847b
[svn] - fix accidental removal of xmms_show_message
nenolod
parents:
2416
diff
changeset
|
976 if ( button_action ) |
74ec16ef847b
[svn] - fix accidental removal of xmms_show_message
nenolod
parents:
2416
diff
changeset
|
977 g_signal_connect( G_OBJECT(dialog_bbox_b1) , "clicked" , |
74ec16ef847b
[svn] - fix accidental removal of xmms_show_message
nenolod
parents:
2416
diff
changeset
|
978 button_action , action_data ); |
74ec16ef847b
[svn] - fix accidental removal of xmms_show_message
nenolod
parents:
2416
diff
changeset
|
979 |
74ec16ef847b
[svn] - fix accidental removal of xmms_show_message
nenolod
parents:
2416
diff
changeset
|
980 gtk_container_add( GTK_CONTAINER(dialog_bbox) , dialog_bbox_b1 ); |
74ec16ef847b
[svn] - fix accidental removal of xmms_show_message
nenolod
parents:
2416
diff
changeset
|
981 gtk_box_pack_start( GTK_BOX(dialog_vbox) , dialog_bbox , FALSE , FALSE , 0 ); |
74ec16ef847b
[svn] - fix accidental removal of xmms_show_message
nenolod
parents:
2416
diff
changeset
|
982 |
74ec16ef847b
[svn] - fix accidental removal of xmms_show_message
nenolod
parents:
2416
diff
changeset
|
983 gtk_container_add( GTK_CONTAINER(dialog) , dialog_vbox ); |
3120
3262bf0b8831
Moving gtk_widget_grab_default() below gtk_container_add() to avoid this
Christian Birchinger <joker@netswarm.net>
parents:
3103
diff
changeset
|
984 |
3262bf0b8831
Moving gtk_widget_grab_default() below gtk_container_add() to avoid this
Christian Birchinger <joker@netswarm.net>
parents:
3103
diff
changeset
|
985 GTK_WIDGET_SET_FLAGS( dialog_bbox_b1 , GTK_CAN_DEFAULT); |
3262bf0b8831
Moving gtk_widget_grab_default() below gtk_container_add() to avoid this
Christian Birchinger <joker@netswarm.net>
parents:
3103
diff
changeset
|
986 gtk_widget_grab_default( dialog_bbox_b1 ); |
3262bf0b8831
Moving gtk_widget_grab_default() below gtk_container_add() to avoid this
Christian Birchinger <joker@netswarm.net>
parents:
3103
diff
changeset
|
987 |
2421
74ec16ef847b
[svn] - fix accidental removal of xmms_show_message
nenolod
parents:
2416
diff
changeset
|
988 gtk_widget_show_all(dialog); |
74ec16ef847b
[svn] - fix accidental removal of xmms_show_message
nenolod
parents:
2416
diff
changeset
|
989 |
74ec16ef847b
[svn] - fix accidental removal of xmms_show_message
nenolod
parents:
2416
diff
changeset
|
990 return dialog; |
74ec16ef847b
[svn] - fix accidental removal of xmms_show_message
nenolod
parents:
2416
diff
changeset
|
991 } |
74ec16ef847b
[svn] - fix accidental removal of xmms_show_message
nenolod
parents:
2416
diff
changeset
|
992 |
74ec16ef847b
[svn] - fix accidental removal of xmms_show_message
nenolod
parents:
2416
diff
changeset
|
993 |
74ec16ef847b
[svn] - fix accidental removal of xmms_show_message
nenolod
parents:
2416
diff
changeset
|
994 /** |
3757
d24d28e76588
export util_get_localdir().
William Pitcock <nenolod@atheme.org>
parents:
3731
diff
changeset
|
995 * util_get_localdir: |
2421
74ec16ef847b
[svn] - fix accidental removal of xmms_show_message
nenolod
parents:
2416
diff
changeset
|
996 * |
74ec16ef847b
[svn] - fix accidental removal of xmms_show_message
nenolod
parents:
2416
diff
changeset
|
997 * Returns a string with the full path of Audacious local datadir (where config files are placed). |
74ec16ef847b
[svn] - fix accidental removal of xmms_show_message
nenolod
parents:
2416
diff
changeset
|
998 * It's useful in order to put in the right place custom config files for audacious plugins. |
74ec16ef847b
[svn] - fix accidental removal of xmms_show_message
nenolod
parents:
2416
diff
changeset
|
999 * |
74ec16ef847b
[svn] - fix accidental removal of xmms_show_message
nenolod
parents:
2416
diff
changeset
|
1000 * Return value: a string with full path of Audacious local datadir (should be freed after use) |
74ec16ef847b
[svn] - fix accidental removal of xmms_show_message
nenolod
parents:
2416
diff
changeset
|
1001 **/ |
74ec16ef847b
[svn] - fix accidental removal of xmms_show_message
nenolod
parents:
2416
diff
changeset
|
1002 gchar* |
3757
d24d28e76588
export util_get_localdir().
William Pitcock <nenolod@atheme.org>
parents:
3731
diff
changeset
|
1003 util_get_localdir(void) |
2421
74ec16ef847b
[svn] - fix accidental removal of xmms_show_message
nenolod
parents:
2416
diff
changeset
|
1004 { |
74ec16ef847b
[svn] - fix accidental removal of xmms_show_message
nenolod
parents:
2416
diff
changeset
|
1005 gchar *datadir; |
74ec16ef847b
[svn] - fix accidental removal of xmms_show_message
nenolod
parents:
2416
diff
changeset
|
1006 gchar *tmp; |
74ec16ef847b
[svn] - fix accidental removal of xmms_show_message
nenolod
parents:
2416
diff
changeset
|
1007 |
74ec16ef847b
[svn] - fix accidental removal of xmms_show_message
nenolod
parents:
2416
diff
changeset
|
1008 if ( (tmp = getenv("XDG_CONFIG_HOME")) == NULL ) |
74ec16ef847b
[svn] - fix accidental removal of xmms_show_message
nenolod
parents:
2416
diff
changeset
|
1009 datadir = g_build_filename( g_get_home_dir() , ".config" , "audacious" , NULL ); |
74ec16ef847b
[svn] - fix accidental removal of xmms_show_message
nenolod
parents:
2416
diff
changeset
|
1010 else |
74ec16ef847b
[svn] - fix accidental removal of xmms_show_message
nenolod
parents:
2416
diff
changeset
|
1011 datadir = g_build_filename( tmp , "audacious" , NULL ); |
74ec16ef847b
[svn] - fix accidental removal of xmms_show_message
nenolod
parents:
2416
diff
changeset
|
1012 |
74ec16ef847b
[svn] - fix accidental removal of xmms_show_message
nenolod
parents:
2416
diff
changeset
|
1013 return datadir; |
74ec16ef847b
[svn] - fix accidental removal of xmms_show_message
nenolod
parents:
2416
diff
changeset
|
1014 } |
74ec16ef847b
[svn] - fix accidental removal of xmms_show_message
nenolod
parents:
2416
diff
changeset
|
1015 |
4070
040243a50bd3
- modified playlist_load_ins_file() and playlist_load_ins_file_tuple(). path builder and ext_hash checker
Yoshiki Yazawa <yaz@cc.rim.or.jp>
parents:
3993
diff
changeset
|
1016 |
040243a50bd3
- modified playlist_load_ins_file() and playlist_load_ins_file_tuple(). path builder and ext_hash checker
Yoshiki Yazawa <yaz@cc.rim.or.jp>
parents:
3993
diff
changeset
|
1017 gchar * |
040243a50bd3
- modified playlist_load_ins_file() and playlist_load_ins_file_tuple(). path builder and ext_hash checker
Yoshiki Yazawa <yaz@cc.rim.or.jp>
parents:
3993
diff
changeset
|
1018 construct_uri(gchar *string, const gchar *playlist_name) // uri, path and anything else |
040243a50bd3
- modified playlist_load_ins_file() and playlist_load_ins_file_tuple(). path builder and ext_hash checker
Yoshiki Yazawa <yaz@cc.rim.or.jp>
parents:
3993
diff
changeset
|
1019 { |
040243a50bd3
- modified playlist_load_ins_file() and playlist_load_ins_file_tuple(). path builder and ext_hash checker
Yoshiki Yazawa <yaz@cc.rim.or.jp>
parents:
3993
diff
changeset
|
1020 gchar *filename = g_strdup(string); |
040243a50bd3
- modified playlist_load_ins_file() and playlist_load_ins_file_tuple(). path builder and ext_hash checker
Yoshiki Yazawa <yaz@cc.rim.or.jp>
parents:
3993
diff
changeset
|
1021 gchar *tmp, *path; |
040243a50bd3
- modified playlist_load_ins_file() and playlist_load_ins_file_tuple(). path builder and ext_hash checker
Yoshiki Yazawa <yaz@cc.rim.or.jp>
parents:
3993
diff
changeset
|
1022 gchar *uri = NULL; |
040243a50bd3
- modified playlist_load_ins_file() and playlist_load_ins_file_tuple(). path builder and ext_hash checker
Yoshiki Yazawa <yaz@cc.rim.or.jp>
parents:
3993
diff
changeset
|
1023 |
040243a50bd3
- modified playlist_load_ins_file() and playlist_load_ins_file_tuple(). path builder and ext_hash checker
Yoshiki Yazawa <yaz@cc.rim.or.jp>
parents:
3993
diff
changeset
|
1024 /* try to translate dos path */ |
040243a50bd3
- modified playlist_load_ins_file() and playlist_load_ins_file_tuple(). path builder and ext_hash checker
Yoshiki Yazawa <yaz@cc.rim.or.jp>
parents:
3993
diff
changeset
|
1025 convert_dos_path(filename); /* in place replacement */ |
040243a50bd3
- modified playlist_load_ins_file() and playlist_load_ins_file_tuple(). path builder and ext_hash checker
Yoshiki Yazawa <yaz@cc.rim.or.jp>
parents:
3993
diff
changeset
|
1026 |
040243a50bd3
- modified playlist_load_ins_file() and playlist_load_ins_file_tuple(). path builder and ext_hash checker
Yoshiki Yazawa <yaz@cc.rim.or.jp>
parents:
3993
diff
changeset
|
1027 /* convert backslash to slash */ |
040243a50bd3
- modified playlist_load_ins_file() and playlist_load_ins_file_tuple(). path builder and ext_hash checker
Yoshiki Yazawa <yaz@cc.rim.or.jp>
parents:
3993
diff
changeset
|
1028 while ((tmp = strchr(filename, '\\')) != NULL) |
040243a50bd3
- modified playlist_load_ins_file() and playlist_load_ins_file_tuple(). path builder and ext_hash checker
Yoshiki Yazawa <yaz@cc.rim.or.jp>
parents:
3993
diff
changeset
|
1029 *tmp = '/'; |
040243a50bd3
- modified playlist_load_ins_file() and playlist_load_ins_file_tuple(). path builder and ext_hash checker
Yoshiki Yazawa <yaz@cc.rim.or.jp>
parents:
3993
diff
changeset
|
1030 |
040243a50bd3
- modified playlist_load_ins_file() and playlist_load_ins_file_tuple(). path builder and ext_hash checker
Yoshiki Yazawa <yaz@cc.rim.or.jp>
parents:
3993
diff
changeset
|
1031 // make full path uri here |
040243a50bd3
- modified playlist_load_ins_file() and playlist_load_ins_file_tuple(). path builder and ext_hash checker
Yoshiki Yazawa <yaz@cc.rim.or.jp>
parents:
3993
diff
changeset
|
1032 // case 1: filename is raw full path or uri |
040243a50bd3
- modified playlist_load_ins_file() and playlist_load_ins_file_tuple(). path builder and ext_hash checker
Yoshiki Yazawa <yaz@cc.rim.or.jp>
parents:
3993
diff
changeset
|
1033 if (filename[0] == '/' || strstr(filename, "://")) { |
040243a50bd3
- modified playlist_load_ins_file() and playlist_load_ins_file_tuple(). path builder and ext_hash checker
Yoshiki Yazawa <yaz@cc.rim.or.jp>
parents:
3993
diff
changeset
|
1034 uri = g_filename_to_uri(filename, NULL, NULL); |
040243a50bd3
- modified playlist_load_ins_file() and playlist_load_ins_file_tuple(). path builder and ext_hash checker
Yoshiki Yazawa <yaz@cc.rim.or.jp>
parents:
3993
diff
changeset
|
1035 if(!uri) { |
040243a50bd3
- modified playlist_load_ins_file() and playlist_load_ins_file_tuple(). path builder and ext_hash checker
Yoshiki Yazawa <yaz@cc.rim.or.jp>
parents:
3993
diff
changeset
|
1036 uri = g_strdup(filename); |
040243a50bd3
- modified playlist_load_ins_file() and playlist_load_ins_file_tuple(). path builder and ext_hash checker
Yoshiki Yazawa <yaz@cc.rim.or.jp>
parents:
3993
diff
changeset
|
1037 } |
040243a50bd3
- modified playlist_load_ins_file() and playlist_load_ins_file_tuple(). path builder and ext_hash checker
Yoshiki Yazawa <yaz@cc.rim.or.jp>
parents:
3993
diff
changeset
|
1038 g_free(filename); |
040243a50bd3
- modified playlist_load_ins_file() and playlist_load_ins_file_tuple(). path builder and ext_hash checker
Yoshiki Yazawa <yaz@cc.rim.or.jp>
parents:
3993
diff
changeset
|
1039 } |
040243a50bd3
- modified playlist_load_ins_file() and playlist_load_ins_file_tuple(). path builder and ext_hash checker
Yoshiki Yazawa <yaz@cc.rim.or.jp>
parents:
3993
diff
changeset
|
1040 // case 2: filename is not raw full path nor uri, playlist path is full path |
040243a50bd3
- modified playlist_load_ins_file() and playlist_load_ins_file_tuple(). path builder and ext_hash checker
Yoshiki Yazawa <yaz@cc.rim.or.jp>
parents:
3993
diff
changeset
|
1041 // make full path by replacing last part of playlist path with filename. (using g_build_filename) |
040243a50bd3
- modified playlist_load_ins_file() and playlist_load_ins_file_tuple(). path builder and ext_hash checker
Yoshiki Yazawa <yaz@cc.rim.or.jp>
parents:
3993
diff
changeset
|
1042 else if (playlist_name[0] == '/' || strstr(playlist_name, "://")) { |
040243a50bd3
- modified playlist_load_ins_file() and playlist_load_ins_file_tuple(). path builder and ext_hash checker
Yoshiki Yazawa <yaz@cc.rim.or.jp>
parents:
3993
diff
changeset
|
1043 path = g_strdup(playlist_name); |
040243a50bd3
- modified playlist_load_ins_file() and playlist_load_ins_file_tuple(). path builder and ext_hash checker
Yoshiki Yazawa <yaz@cc.rim.or.jp>
parents:
3993
diff
changeset
|
1044 tmp = strrchr(path, '/'); *tmp = '\0'; |
040243a50bd3
- modified playlist_load_ins_file() and playlist_load_ins_file_tuple(). path builder and ext_hash checker
Yoshiki Yazawa <yaz@cc.rim.or.jp>
parents:
3993
diff
changeset
|
1045 tmp = g_build_filename(path, filename, NULL); |
4073 | 1046 g_free(path); g_free(filename); |
4070
040243a50bd3
- modified playlist_load_ins_file() and playlist_load_ins_file_tuple(). path builder and ext_hash checker
Yoshiki Yazawa <yaz@cc.rim.or.jp>
parents:
3993
diff
changeset
|
1047 uri = g_filename_to_uri(tmp, NULL, NULL); |
4073 | 1048 g_free(tmp); |
4070
040243a50bd3
- modified playlist_load_ins_file() and playlist_load_ins_file_tuple(). path builder and ext_hash checker
Yoshiki Yazawa <yaz@cc.rim.or.jp>
parents:
3993
diff
changeset
|
1049 } |
040243a50bd3
- modified playlist_load_ins_file() and playlist_load_ins_file_tuple(). path builder and ext_hash checker
Yoshiki Yazawa <yaz@cc.rim.or.jp>
parents:
3993
diff
changeset
|
1050 // case 3: filename is not raw full path nor uri, playlist path is not full path |
040243a50bd3
- modified playlist_load_ins_file() and playlist_load_ins_file_tuple(). path builder and ext_hash checker
Yoshiki Yazawa <yaz@cc.rim.or.jp>
parents:
3993
diff
changeset
|
1051 // just abort. |
040243a50bd3
- modified playlist_load_ins_file() and playlist_load_ins_file_tuple(). path builder and ext_hash checker
Yoshiki Yazawa <yaz@cc.rim.or.jp>
parents:
3993
diff
changeset
|
1052 else { |
040243a50bd3
- modified playlist_load_ins_file() and playlist_load_ins_file_tuple(). path builder and ext_hash checker
Yoshiki Yazawa <yaz@cc.rim.or.jp>
parents:
3993
diff
changeset
|
1053 g_free(filename); |
040243a50bd3
- modified playlist_load_ins_file() and playlist_load_ins_file_tuple(). path builder and ext_hash checker
Yoshiki Yazawa <yaz@cc.rim.or.jp>
parents:
3993
diff
changeset
|
1054 return NULL; |
040243a50bd3
- modified playlist_load_ins_file() and playlist_load_ins_file_tuple(). path builder and ext_hash checker
Yoshiki Yazawa <yaz@cc.rim.or.jp>
parents:
3993
diff
changeset
|
1055 } |
040243a50bd3
- modified playlist_load_ins_file() and playlist_load_ins_file_tuple(). path builder and ext_hash checker
Yoshiki Yazawa <yaz@cc.rim.or.jp>
parents:
3993
diff
changeset
|
1056 |
040243a50bd3
- modified playlist_load_ins_file() and playlist_load_ins_file_tuple(). path builder and ext_hash checker
Yoshiki Yazawa <yaz@cc.rim.or.jp>
parents:
3993
diff
changeset
|
1057 AUDDBG("uri=%s\n", uri); |
040243a50bd3
- modified playlist_load_ins_file() and playlist_load_ins_file_tuple(). path builder and ext_hash checker
Yoshiki Yazawa <yaz@cc.rim.or.jp>
parents:
3993
diff
changeset
|
1058 return uri; |
040243a50bd3
- modified playlist_load_ins_file() and playlist_load_ins_file_tuple(). path builder and ext_hash checker
Yoshiki Yazawa <yaz@cc.rim.or.jp>
parents:
3993
diff
changeset
|
1059 } |
4267
a41fb6bc632a
- src stuff traveled to src_flow.c
Eugene Zagidullin <e.asphyx@gmail.com>
parents:
4259
diff
changeset
|
1060 |
a41fb6bc632a
- src stuff traveled to src_flow.c
Eugene Zagidullin <e.asphyx@gmail.com>
parents:
4259
diff
changeset
|
1061 /* |
a41fb6bc632a
- src stuff traveled to src_flow.c
Eugene Zagidullin <e.asphyx@gmail.com>
parents:
4259
diff
changeset
|
1062 * minimize number of realloc's: |
a41fb6bc632a
- src stuff traveled to src_flow.c
Eugene Zagidullin <e.asphyx@gmail.com>
parents:
4259
diff
changeset
|
1063 * - set N to nearest power of 2 not less then N |
a41fb6bc632a
- src stuff traveled to src_flow.c
Eugene Zagidullin <e.asphyx@gmail.com>
parents:
4259
diff
changeset
|
1064 * - double it |
a41fb6bc632a
- src stuff traveled to src_flow.c
Eugene Zagidullin <e.asphyx@gmail.com>
parents:
4259
diff
changeset
|
1065 * |
a41fb6bc632a
- src stuff traveled to src_flow.c
Eugene Zagidullin <e.asphyx@gmail.com>
parents:
4259
diff
changeset
|
1066 * -- asphyx |
4278 | 1067 * |
1068 * XXX: what's so smart about this?? seems wasteful and silly. --nenolod | |
4267
a41fb6bc632a
- src stuff traveled to src_flow.c
Eugene Zagidullin <e.asphyx@gmail.com>
parents:
4259
diff
changeset
|
1069 */ |
4278 | 1070 gpointer |
1071 smart_realloc(gpointer ptr, gsize *size) | |
1072 { | |
4267
a41fb6bc632a
- src stuff traveled to src_flow.c
Eugene Zagidullin <e.asphyx@gmail.com>
parents:
4259
diff
changeset
|
1073 *size = (size_t)pow(2, ceil(log(*size) / log(2)) + 1); |
a41fb6bc632a
- src stuff traveled to src_flow.c
Eugene Zagidullin <e.asphyx@gmail.com>
parents:
4259
diff
changeset
|
1074 if (ptr != NULL) free(ptr); |
a41fb6bc632a
- src stuff traveled to src_flow.c
Eugene Zagidullin <e.asphyx@gmail.com>
parents:
4259
diff
changeset
|
1075 ptr = malloc(*size); |
a41fb6bc632a
- src stuff traveled to src_flow.c
Eugene Zagidullin <e.asphyx@gmail.com>
parents:
4259
diff
changeset
|
1076 return ptr; |
a41fb6bc632a
- src stuff traveled to src_flow.c
Eugene Zagidullin <e.asphyx@gmail.com>
parents:
4259
diff
changeset
|
1077 } |
a41fb6bc632a
- src stuff traveled to src_flow.c
Eugene Zagidullin <e.asphyx@gmail.com>
parents:
4259
diff
changeset
|
1078 |