gzdoom/libraries/timidityplus/timiditypp/sfitem.h

94 lines
2.6 KiB
C++

/*
TiMidity++ -- MIDI to WAVE converter and player
Copyright (C) 1999-2002 Masanao Izumo <mo@goice.co.jp>
Copyright (C) 1995 Tuukka Toivonen <tt@cgs.fi>
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; either version 2 of the License, or
(at your option) any later version.
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., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
*/
/*================================================================
* sfitem.h
* soundfont generator conversion table
*================================================================*/
#ifndef SFITEM_H_DEF
#define SFITEM_H_DEF
#include "sflayer.h"
#include "sffile.h"
namespace TimidityPlus
{
typedef struct _LayerItem {
int copy; /* copy policy */
int type; /* conversion type */
int minv; /* minimum value */
int maxv; /* maximum value */
int defv; /* default value */
} LayerItem;
/* copy policy */
enum {
L_INHRT, /* add to global */
L_OVWRT, /* overwrite on global */
L_RANGE, /* range */
L_PRSET, /* preset only */
L_INSTR /* instrument only */
};
/* data type */
enum {
T_NOP, /* nothing */
T_NOCONV, /* no conversion */
T_OFFSET, /* address offset */
T_HI_OFF, /* address coarse offset (32k) */
T_RANGE, /* range; composite values (0-127/0-127) */
T_CUTOFF, /* initial cutoff */
T_FILTERQ, /* initial resonance */
T_TENPCT, /* effects send */
T_PANPOS, /* panning position */
T_ATTEN, /* initial attenuation */
T_SCALE, /* scale tuning */
T_TIME, /* envelope/LFO time */
T_TM_KEY, /* time change per key */
T_FREQ, /* LFO frequency */
T_PSHIFT, /* env/LFO pitch shift */
T_CSHIFT, /* env/LFO cutoff shift */
T_TREMOLO, /* LFO tremolo shift */
T_MODSUST, /* modulation env sustain level */
T_VOLSUST, /* volume env sustain level */
T_EOT /* end of type */
};
/* sbk->sf2 convertor function */
typedef int (*SBKConv)(int gen, int amount);
/* macros for range operation */
#define RANGE(lo,hi) (((hi)&0xff) << 8 | ((lo)&0xff))
#define LOWNUM(val) ((val) & 0xff)
#define HIGHNUM(val) (((val) >> 8) & 0xff)
/* layer type definitions */
extern const LayerItem static_layer_items[SF_EOF];
extern int sbk_to_sf2(int oper, int amount, const LayerItem *);
}
#endif