annotate libaudacious/formatter.c @ 2062:409df027cc31 trunk

[svn] - rewrite input_check_file() - make similar functions use input_check_file() instead of probing by hand
author nenolod
date Tue, 05 Dec 2006 00:31:38 -0800
parents 53a3d5db6b58
children f18a5b617c34
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
2045
04961c9a5242 [svn] - document the formatter class
nenolod
parents: 0
diff changeset
1 /* Audacious
04961c9a5242 [svn] - document the formatter class
nenolod
parents: 0
diff changeset
2 * Copyright (C) 2005-2007 Audacious team
04961c9a5242 [svn] - document the formatter class
nenolod
parents: 0
diff changeset
3 *
04961c9a5242 [svn] - document the formatter class
nenolod
parents: 0
diff changeset
4 * XMMS - Cross-platform multimedia player
04961c9a5242 [svn] - document the formatter class
nenolod
parents: 0
diff changeset
5 * Copyright (C) 1998-2003 Peter Alm, Mikael Alm, Olle Hallnas,
04961c9a5242 [svn] - document the formatter class
nenolod
parents: 0
diff changeset
6 * Thomas Nilsson and 4Front Technologies
04961c9a5242 [svn] - document the formatter class
nenolod
parents: 0
diff changeset
7 * Copyright (C) 1999-2003 Haavard Kvaalen
04961c9a5242 [svn] - document the formatter class
nenolod
parents: 0
diff changeset
8 *
04961c9a5242 [svn] - document the formatter class
nenolod
parents: 0
diff changeset
9 * This program is free software; you can redistribute it and/or modify
04961c9a5242 [svn] - document the formatter class
nenolod
parents: 0
diff changeset
10 * it under the terms of the GNU General Public License as published by
04961c9a5242 [svn] - document the formatter class
nenolod
parents: 0
diff changeset
11 * the Free Software Foundation; either version 2 of the License, or
04961c9a5242 [svn] - document the formatter class
nenolod
parents: 0
diff changeset
12 * (at your option) any later version.
04961c9a5242 [svn] - document the formatter class
nenolod
parents: 0
diff changeset
13 *
04961c9a5242 [svn] - document the formatter class
nenolod
parents: 0
diff changeset
14 * This program is distributed in the hope that it will be useful,
04961c9a5242 [svn] - document the formatter class
nenolod
parents: 0
diff changeset
15 * but WITHOUT ANY WARRANTY; without even the implied warranty of
04961c9a5242 [svn] - document the formatter class
nenolod
parents: 0
diff changeset
16 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
04961c9a5242 [svn] - document the formatter class
nenolod
parents: 0
diff changeset
17 * GNU General Public License for more details.
04961c9a5242 [svn] - document the formatter class
nenolod
parents: 0
diff changeset
18 *
04961c9a5242 [svn] - document the formatter class
nenolod
parents: 0
diff changeset
19 * You should have received a copy of the GNU General Public License
04961c9a5242 [svn] - document the formatter class
nenolod
parents: 0
diff changeset
20 * along with this program; if not, write to the Free Software
04961c9a5242 [svn] - document the formatter class
nenolod
parents: 0
diff changeset
21 * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
04961c9a5242 [svn] - document the formatter class
nenolod
parents: 0
diff changeset
22 */
04961c9a5242 [svn] - document the formatter class
nenolod
parents: 0
diff changeset
23
0
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
24 #ifdef HAVE_CONFIG_H
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
25 # include "config.h"
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
26 #endif
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
27
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
28 #include <glib.h>
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
29 #include <string.h>
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
30 #include "formatter.h"
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
31
2045
04961c9a5242 [svn] - document the formatter class
nenolod
parents: 0
diff changeset
32 /**
04961c9a5242 [svn] - document the formatter class
nenolod
parents: 0
diff changeset
33 * xmms_formatter_new:
04961c9a5242 [svn] - document the formatter class
nenolod
parents: 0
diff changeset
34 *
04961c9a5242 [svn] - document the formatter class
nenolod
parents: 0
diff changeset
35 * Factory for #Formatter objects.
2060
53a3d5db6b58 [svn] - finish documenting the libaudacious API
nenolod
parents: 2045
diff changeset
36 *
53a3d5db6b58 [svn] - finish documenting the libaudacious API
nenolod
parents: 2045
diff changeset
37 * Return value: A #Formatter object.
2045
04961c9a5242 [svn] - document the formatter class
nenolod
parents: 0
diff changeset
38 **/
0
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
39 Formatter *
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
40 xmms_formatter_new(void)
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
41 {
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
42 Formatter *formatter = g_new0(Formatter, 1);
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
43
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
44 xmms_formatter_associate(formatter, '%', "%");
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
45 return formatter;
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
46 }
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
47
2045
04961c9a5242 [svn] - document the formatter class
nenolod
parents: 0
diff changeset
48 /**
04961c9a5242 [svn] - document the formatter class
nenolod
parents: 0
diff changeset
49 * xmms_formatter_destroy:
04961c9a5242 [svn] - document the formatter class
nenolod
parents: 0
diff changeset
50 * @formatter: A #Formatter object to destroy.
04961c9a5242 [svn] - document the formatter class
nenolod
parents: 0
diff changeset
51 *
04961c9a5242 [svn] - document the formatter class
nenolod
parents: 0
diff changeset
52 * Destroys #Formatter objects.
04961c9a5242 [svn] - document the formatter class
nenolod
parents: 0
diff changeset
53 **/
0
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
54 void
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
55 xmms_formatter_destroy(Formatter * formatter)
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
56 {
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
57 int i;
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
58
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
59 for (i = 0; i < 256; i++)
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
60 if (formatter->values[i])
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
61 g_free(formatter->values[i]);
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
62 g_free(formatter);
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
63 }
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
64
2045
04961c9a5242 [svn] - document the formatter class
nenolod
parents: 0
diff changeset
65 /**
04961c9a5242 [svn] - document the formatter class
nenolod
parents: 0
diff changeset
66 * xmms_formatter_associate:
04961c9a5242 [svn] - document the formatter class
nenolod
parents: 0
diff changeset
67 * @formatter: A #Formatter object to use.
04961c9a5242 [svn] - document the formatter class
nenolod
parents: 0
diff changeset
68 * @id: The character to use for replacement.
04961c9a5242 [svn] - document the formatter class
nenolod
parents: 0
diff changeset
69 * @value: The value to replace with.
04961c9a5242 [svn] - document the formatter class
nenolod
parents: 0
diff changeset
70 *
04961c9a5242 [svn] - document the formatter class
nenolod
parents: 0
diff changeset
71 * Adds a id->replacement set to the formatter's stack.
04961c9a5242 [svn] - document the formatter class
nenolod
parents: 0
diff changeset
72 **/
0
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
73 void
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
74 xmms_formatter_associate(Formatter * formatter, guchar id, char *value)
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
75 {
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
76 xmms_formatter_dissociate(formatter, id);
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
77 formatter->values[id] = g_strdup(value);
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
78 }
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
79
2045
04961c9a5242 [svn] - document the formatter class
nenolod
parents: 0
diff changeset
80 /**
04961c9a5242 [svn] - document the formatter class
nenolod
parents: 0
diff changeset
81 * xmms_formatter_dissociate:
04961c9a5242 [svn] - document the formatter class
nenolod
parents: 0
diff changeset
82 * @formatter: A #Formatter object to use.
04961c9a5242 [svn] - document the formatter class
nenolod
parents: 0
diff changeset
83 * @id: The id to remove the id->replacement mapping for.
04961c9a5242 [svn] - document the formatter class
nenolod
parents: 0
diff changeset
84 *
04961c9a5242 [svn] - document the formatter class
nenolod
parents: 0
diff changeset
85 * Removes an id->replacement mapping from the formatter's stack.
04961c9a5242 [svn] - document the formatter class
nenolod
parents: 0
diff changeset
86 **/
0
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
87 void
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
88 xmms_formatter_dissociate(Formatter * formatter, guchar id)
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
89 {
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
90 if (formatter->values[id])
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
91 g_free(formatter->values[id]);
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
92 formatter->values[id] = 0;
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
93 }
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
94
2045
04961c9a5242 [svn] - document the formatter class
nenolod
parents: 0
diff changeset
95 /**
04961c9a5242 [svn] - document the formatter class
nenolod
parents: 0
diff changeset
96 * xmms_formatter_format:
04961c9a5242 [svn] - document the formatter class
nenolod
parents: 0
diff changeset
97 * @formatter: A #Formatter object to use.
04961c9a5242 [svn] - document the formatter class
nenolod
parents: 0
diff changeset
98 * @format: A string to format.
04961c9a5242 [svn] - document the formatter class
nenolod
parents: 0
diff changeset
99 *
04961c9a5242 [svn] - document the formatter class
nenolod
parents: 0
diff changeset
100 * Performs id->replacement substitution on a string.
04961c9a5242 [svn] - document the formatter class
nenolod
parents: 0
diff changeset
101 *
04961c9a5242 [svn] - document the formatter class
nenolod
parents: 0
diff changeset
102 * Returns: The formatted string.
04961c9a5242 [svn] - document the formatter class
nenolod
parents: 0
diff changeset
103 **/
0
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
104 gchar *
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
105 xmms_formatter_format(Formatter * formatter, char *format)
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
106 {
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
107 char *p, *q, *buffer;
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
108 int len;
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
109
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
110 for (p = format, len = 0; *p; p++)
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
111 if (*p == '%') {
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
112 if (formatter->values[(int) *++p])
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
113 len += strlen(formatter->values[(int) *p]);
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
114 else if (!*p) {
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
115 len += 1;
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
116 p--;
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
117 }
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
118 else
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
119 len += 2;
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
120 }
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
121 else
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
122 len++;
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
123 buffer = g_malloc(len + 1);
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
124 for (p = format, q = buffer; *p; p++)
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
125 if (*p == '%') {
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
126 if (formatter->values[(int) *++p]) {
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
127 strcpy(q, formatter->values[(int) *p]);
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
128 q += strlen(q);
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
129 }
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
130 else {
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
131 *q++ = '%';
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
132 if (*p != '\0')
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
133 *q++ = *p;
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
134 else
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
135 p--;
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
136 }
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
137 }
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
138 else
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
139 *q++ = *p;
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
140 *q = 0;
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
141 return buffer;
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
142 }