view extra_rwops.h @ 562:7e08477b0fc1

MP3 decoder upgrade work. Ripped out SMPEG and mpglib support, replaced it with "mpg123.c" and libmpg123. libmpg123 is a much better version of mpglib, so it should solve all the problems about MP3's not seeking, or most modern MP3's not playing at all, etc. Since you no longer have to make a tradeoff with SMPEG for features, and SMPEG is basically rotting, I removed it from the project. There is still work to be done with libmpg123...there are MMX, 3DNow, SSE, Altivec, etc decoders which we don't have enabled at the moment, and the build system could use some work to make this compile more cleanly, etc. Still: huge win.
author Ryan C. Gordon <icculus@icculus.org>
date Fri, 30 Jan 2009 02:44:47 -0500
parents 2e8907ff98e9
children
line wrap: on
line source

/*
 * SDL_sound -- An abstract sound format decoding API.
 * Copyright (C) 2001  Ryan C. Gordon.
 *
 * This library is free software; you can redistribute it and/or
 * modify it under the terms of the GNU Lesser General Public
 * License as published by the Free Software Foundation; either
 * version 2.1 of the License, or (at your option) any later version.
 *
 * This library 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
 * Lesser General Public License for more details.
 *
 * You should have received a copy of the GNU Lesser General Public
 * License along with this library; if not, write to the Free Software
 * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA
 */

/*
 * Some extra RWops that are needed or are just handy to have.
 *
 * Please see the file LICENSE.txt in the source's root directory.
 *
 *  This file written by Ryan C. Gordon. (icculus@icculus.org)
 */

#ifndef _INCLUDE_EXTRA_RWOPS_H_
#define _INCLUDE_EXTRA_RWOPS_H_

#include "SDL.h"

#ifdef __cplusplus
extern "C" {
#endif

/*
 * The Reference Counter RWops...
 *
 *  This wraps another RWops with a reference counter. When you create a
 *   reference counter RWops, it sets a counter to one. Everytime you call
 *   RWops_RWRefCounter_new(), that's RWops's counter increments by one.
 *   Everytime you call that RWops's close() method, the counter decrements
 *   by one. If the counter hits zero, the original RWops's close() method
 *   is called, and the reference counting wrapper deletes itself. The read,
 *   write, and seek methods just pass through to the original.
 *
 *  This is handy if you have two libraries (in the original case, SDL_sound
 *   and SMPEG), who both want an SDL_RWops, and both want to close it when
 *   they are finished. This resolves that contention. The user creates a
 *   RWops, passes it to SDL_sound, which wraps it in a reference counter and
 *   increments the number of references, and passes the wrapped RWops to
 *   SMPEG. SMPEG "closes" this wrapped RWops when the MP3 has finished
 *   playing, and SDL_sound then closes it, too. This second closing removes
 *   the last reference, and the RWops is smoothly destructed.
 */

/* Return a SDL_RWops that is a reference counting wrapper of (rw). */
SDL_RWops *RWops_RWRefCounter_new(SDL_RWops *rw);

/* Increment a reference counting RWops's refcount by one. */
void RWops_RWRefCounter_addRef(SDL_RWops *rw);


/*
 * RWops pooling. This is to reduce malloc() pressure for audio that is
 *  placed into Sound_Samples over and over again.
 */

/* Call this first. */
int RWops_pooled_init(void);

/* Call this last. */
int RWops_pooled_deinit(void);

/* Get a new RWops, allocating if needed. */
SDL_RWops *RWops_pooled_alloc(void);

/* Return a RWops to the pool for reuse. */
void RWops_pooled_free(SDL_RWops *rw);

#ifdef __cplusplus
}
#endif

#endif /* !defined _INCLUDE_EXTRA_RWOPS_H_ */

/* end of extra_rwops.h ... */