Mercurial > audlegacy
view src/audacious/formatter.c @ 4291:ca077e01ed3a
Add caching to Jump to Track feature to speed up searches. (Bugzilla #180)
author | Jussi Judin <jjudin+audacious@iki.fi> |
---|---|
date | Mon, 18 Feb 2008 20:44:40 -0600 |
parents | 7b9d5718a6dc |
children |
line wrap: on
line source
/* Audacious * Copyright (C) 2005-2007 Audacious team * * XMMS - Cross-platform multimedia player * Copyright (C) 1998-2003 Peter Alm, Mikael Alm, Olle Hallnas, * Thomas Nilsson and 4Front Technologies * Copyright (C) 1999-2003 Haavard Kvaalen * * This program is free software; you can redistribute it and/or modify * it under the terms of the GNU General Public License as published by * the Free Software Foundation; under version 3 of the License. * * This program is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU General Public License for more details. * * You should have received a copy of the GNU General Public License * along with this program. If not, see <http://www.gnu.org/licenses>. * * The Audacious team does not consider modular code linking to * Audacious or using our public API to be a derived work. */ #ifdef HAVE_CONFIG_H # include "config.h" #endif #include <glib.h> #include <string.h> #include "formatter.h" /** * formatter_new: * * Factory for #Formatter objects. * * Return value: A #Formatter object. **/ Formatter * formatter_new(void) { Formatter *formatter = g_slice_new0(Formatter); formatter_associate(formatter, '%', "%"); return formatter; } /** * formatter_destroy: * @formatter: A #Formatter object to destroy. * * Destroys #Formatter objects. **/ void formatter_destroy(Formatter * formatter) { int i; for (i = 0; i < 256; i++) if (formatter->values[i]) g_free(formatter->values[i]); g_slice_free(Formatter, formatter); } /** * formatter_associate: * @formatter: A #Formatter object to use. * @id: The character to use for replacement. * @value: The value to replace with. * * Adds a id->replacement set to the formatter's stack. **/ void formatter_associate(Formatter * formatter, guchar id, char *value) { formatter_dissociate(formatter, id); formatter->values[id] = g_strdup(value); } /** * formatter_dissociate: * @formatter: A #Formatter object to use. * @id: The id to remove the id->replacement mapping for. * * Removes an id->replacement mapping from the formatter's stack. **/ void formatter_dissociate(Formatter * formatter, guchar id) { if (formatter->values[id]) g_free(formatter->values[id]); formatter->values[id] = 0; } /** * formatter_format: * @formatter: A #Formatter object to use. * @format: A string to format. * * Performs id->replacement substitution on a string. * * Returns: The formatted string. **/ gchar * formatter_format(Formatter * formatter, char *format) { char *p, *q, *buffer; int len; for (p = format, len = 0; *p; p++) if (*p == '%') { if (formatter->values[(int) *++p]) len += strlen(formatter->values[(int) *p]); else if (!*p) { len += 1; p--; } else len += 2; } else len++; buffer = g_malloc(len + 1); for (p = format, q = buffer; *p; p++) if (*p == '%') { if (formatter->values[(int) *++p]) { g_strlcpy(q, formatter->values[(int) *p], len - 1); q += strlen(q); } else { *q++ = '%'; if (*p != '\0') *q++ = *p; else p--; } } else *q++ = *p; *q = 0; return buffer; }