ref: a034af18c16e6688373c4c910d97a7dc0342c8a7
dir: /src/allegro/datxmq.c/
/*  _______         ____    __         ___    ___
 * \    _  \       \    /  \  /       \   \  /   /       '   '  '
 *  |  | \  \       |  |    ||         |   \/   |         .      .
 *  |  |  |  |      |  |    ||         ||\  /|  |
 *  |  |  |  |      |  |    ||         || \/ |  |         '  '  '
 *  |  |  |  |      |  |    ||         ||    |  |         .      .
 *  |  |_/  /        \  \__//          ||    |  |
 * /_______/ynamic    \____/niversal  /__\  /____\usic   /|  .  . ibliotheque
 *                                                      /  \
 *                                                     / .  \
 * datxmq.c - Integration of XM files with            / / \  \
 *            Allegro's datafiles.                   | <  /   \_
 *                                                   |  \/ /\   /
 * By entheh.                                         \_  /  > /
 *                                                      | \ / /
 *                                                      |  ' /
 *                                                       \__/
 */
#include <allegro.h>
#include "aldumb.h"
#include "internal/aldumb.h"
static void *dat_read_xm_quick(PACKFILE *f, long size)
{
	DUMBFILE *df;
	DUH *duh;
	(void)size;
	df = dumbfile_open_packfile(f);
	if (!df)
		return NULL;
	duh = dumb_read_xm_quick(df);
	dumbfile_close(df);
	return duh;
}
/* dumb_register_dat_xm_quick(): tells Allegro about the XM datafile object.
 * If you intend to load a datafile containing an XM object, you must call this
 * function first. It is recommended you pass DUMB_DAT_XM, but you may have a
 * reason to use a different type (perhaps you already have a datafile with
 * XM files in and they use a different type).
 *
 * This installs the quick loader: the song length and fast seek points are
 * not calculated.
 */
void dumb_register_dat_xm_quick(long type)
{
	register_datafile_object(
		type,
		&dat_read_xm_quick,
		&_dat_unload_duh
	);
}