Mercurial > audlegacy
view src/audacious/memorypool.h @ 2668:d5da5d37ec8b trunk
[svn] - unlock many playlist operations that do not really need locking
- information retrieval should not be atomic
- add code to expose potentially unnecessary playlist locks
- now playlists with remote URIs can mostly be probed in the background
author | nenolod |
---|---|
date | Tue, 10 Apr 2007 11:12:56 -0700 |
parents | 3149d4b1a9a9 |
children | d226b83fa329 |
line wrap: on
line source
/* Audacious * Copyright (c) 2007 William Pitcock <nenolod -at- atheme.org> * * 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 2 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, write to the Free Software * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. */ #ifndef AUDACIOUS_MEMORYPOOL_H #define AUDACIOUS_MEMORYPOOL_H typedef struct _MemoryPool MemoryPool; MemoryPool * memory_pool_new(void); MemoryPool * memory_pool_with_custom_destructor(GDestroyNotify notify); gpointer memory_pool_add(MemoryPool * pool, gpointer ptr); gpointer memory_pool_allocate(MemoryPool * pool, gsize sz); void memory_pool_release(MemoryPool * pool, gpointer addr); void memory_pool_cleanup(MemoryPool * pool); void memory_pool_destroy(MemoryPool * pool); gchar * memory_pool_strdup(MemoryPool * pool, gchar * src); #define memory_pool_alloc_object(pool, obj) \ memory_pool_allocate(pool, sizeof(obj)) #endif