annotate libaudacious/formatter.c @ 2059:8aaf0f145578 trunk

[svn] - documentation fixups
author nenolod
date Mon, 04 Dec 2006 18:30:58 -0800
parents 04961c9a5242
children 53a3d5db6b58
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.
04961c9a5242 [svn] - document the formatter class
nenolod
parents: 0
diff changeset
36 **/
0
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
37 Formatter *
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
38 xmms_formatter_new(void)
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
39 {
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
40 Formatter *formatter = g_new0(Formatter, 1);
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
41
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
42 xmms_formatter_associate(formatter, '%', "%");
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
43 return formatter;
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
44 }
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
45
2045
04961c9a5242 [svn] - document the formatter class
nenolod
parents: 0
diff changeset
46 /**
04961c9a5242 [svn] - document the formatter class
nenolod
parents: 0
diff changeset
47 * xmms_formatter_destroy:
04961c9a5242 [svn] - document the formatter class
nenolod
parents: 0
diff changeset
48 * @formatter: A #Formatter object to destroy.
04961c9a5242 [svn] - document the formatter class
nenolod
parents: 0
diff changeset
49 *
04961c9a5242 [svn] - document the formatter class
nenolod
parents: 0
diff changeset
50 * Destroys #Formatter objects.
04961c9a5242 [svn] - document the formatter class
nenolod
parents: 0
diff changeset
51 **/
0
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
52 void
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
53 xmms_formatter_destroy(Formatter * formatter)
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
54 {
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
55 int i;
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
56
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
57 for (i = 0; i < 256; i++)
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
58 if (formatter->values[i])
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
59 g_free(formatter->values[i]);
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
60 g_free(formatter);
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
61 }
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
62
2045
04961c9a5242 [svn] - document the formatter class
nenolod
parents: 0
diff changeset
63 /**
04961c9a5242 [svn] - document the formatter class
nenolod
parents: 0
diff changeset
64 * xmms_formatter_associate:
04961c9a5242 [svn] - document the formatter class
nenolod
parents: 0
diff changeset
65 * @formatter: A #Formatter object to use.
04961c9a5242 [svn] - document the formatter class
nenolod
parents: 0
diff changeset
66 * @id: The character to use for replacement.
04961c9a5242 [svn] - document the formatter class
nenolod
parents: 0
diff changeset
67 * @value: The value to replace with.
04961c9a5242 [svn] - document the formatter class
nenolod
parents: 0
diff changeset
68 *
04961c9a5242 [svn] - document the formatter class
nenolod
parents: 0
diff changeset
69 * Adds a id->replacement set to the formatter's stack.
04961c9a5242 [svn] - document the formatter class
nenolod
parents: 0
diff changeset
70 **/
0
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
71 void
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
72 xmms_formatter_associate(Formatter * formatter, guchar id, char *value)
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
73 {
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
74 xmms_formatter_dissociate(formatter, id);
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
75 formatter->values[id] = g_strdup(value);
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
76 }
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
77
2045
04961c9a5242 [svn] - document the formatter class
nenolod
parents: 0
diff changeset
78 /**
04961c9a5242 [svn] - document the formatter class
nenolod
parents: 0
diff changeset
79 * xmms_formatter_dissociate:
04961c9a5242 [svn] - document the formatter class
nenolod
parents: 0
diff changeset
80 * @formatter: A #Formatter object to use.
04961c9a5242 [svn] - document the formatter class
nenolod
parents: 0
diff changeset
81 * @id: The id to remove the id->replacement mapping for.
04961c9a5242 [svn] - document the formatter class
nenolod
parents: 0
diff changeset
82 *
04961c9a5242 [svn] - document the formatter class
nenolod
parents: 0
diff changeset
83 * Removes an id->replacement mapping from the formatter's stack.
04961c9a5242 [svn] - document the formatter class
nenolod
parents: 0
diff changeset
84 **/
0
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
85 void
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
86 xmms_formatter_dissociate(Formatter * formatter, guchar id)
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
87 {
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
88 if (formatter->values[id])
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
89 g_free(formatter->values[id]);
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
90 formatter->values[id] = 0;
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
91 }
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
92
2045
04961c9a5242 [svn] - document the formatter class
nenolod
parents: 0
diff changeset
93 /**
04961c9a5242 [svn] - document the formatter class
nenolod
parents: 0
diff changeset
94 * xmms_formatter_format:
04961c9a5242 [svn] - document the formatter class
nenolod
parents: 0
diff changeset
95 * @formatter: A #Formatter object to use.
04961c9a5242 [svn] - document the formatter class
nenolod
parents: 0
diff changeset
96 * @format: A string to format.
04961c9a5242 [svn] - document the formatter class
nenolod
parents: 0
diff changeset
97 *
04961c9a5242 [svn] - document the formatter class
nenolod
parents: 0
diff changeset
98 * Performs id->replacement substitution on a string.
04961c9a5242 [svn] - document the formatter class
nenolod
parents: 0
diff changeset
99 *
04961c9a5242 [svn] - document the formatter class
nenolod
parents: 0
diff changeset
100 * Returns: The formatted string.
04961c9a5242 [svn] - document the formatter class
nenolod
parents: 0
diff changeset
101 **/
0
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
102 gchar *
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
103 xmms_formatter_format(Formatter * formatter, char *format)
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
104 {
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
105 char *p, *q, *buffer;
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
106 int len;
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
107
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
108 for (p = format, len = 0; *p; p++)
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
109 if (*p == '%') {
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
110 if (formatter->values[(int) *++p])
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
111 len += strlen(formatter->values[(int) *p]);
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
112 else if (!*p) {
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
113 len += 1;
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
114 p--;
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
115 }
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
116 else
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
117 len += 2;
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
118 }
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
119 else
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
120 len++;
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
121 buffer = g_malloc(len + 1);
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
122 for (p = format, q = buffer; *p; p++)
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
123 if (*p == '%') {
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
124 if (formatter->values[(int) *++p]) {
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
125 strcpy(q, formatter->values[(int) *p]);
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
126 q += strlen(q);
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
127 }
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
128 else {
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
129 *q++ = '%';
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
130 if (*p != '\0')
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
131 *q++ = *p;
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
132 else
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
133 p--;
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
134 }
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
135 }
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
136 else
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
137 *q++ = *p;
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
138 *q = 0;
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
139 return buffer;
cb178e5ad177 [svn] Import audacious source.
nenolod
parents:
diff changeset
140 }