1 /* 2 TiMidity++ -- MIDI to WAVE converter and player 3 Copyright (C) 1999-2002 Masanao Izumo <mo@goice.co.jp> 4 Copyright (C) 1995 Tuukka Toivonen <tt@cgs.fi> 5 6 This program is free software; you can redistribute it and/or modify 7 it under the terms of the GNU General Public License as published by 8 the Free Software Foundation; either version 2 of the License, or 9 (at your option) any later version. 10 11 This program is distributed in the hope that it will be useful, 12 but WITHOUT ANY WARRANTY; without even the implied warranty of 13 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the 14 GNU General Public License for more details. 15 16 You should have received a copy of the GNU General Public License 17 along with this program; if not, write to the Free Software 18 Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA 19 */ 20 21 /*================================================================ 22 * sfitem.c 23 * soundfont generator table definition 24 *================================================================*/ 25 26 #include <stdint.h> 27 #include "sflayer.h" 28 #include "sfitem.h" 29 30 namespace TimidityPlus 31 { 32 33 /* layer type definitions */ 34 const LayerItem static_layer_items[SF_EOF] = { 35 {L_INHRT, T_OFFSET, 0, 0, 0}, /* startAddrs */ 36 {L_INHRT, T_OFFSET, 0, 0, 0}, /* endAddrs */ 37 {L_INHRT, T_OFFSET, 0, 0, 0}, /* startloopAddrs */ 38 {L_INHRT, T_OFFSET, 0, 0, 0}, /* endloopAddrs */ 39 {L_INHRT, T_HI_OFF, 0, 0, 0}, /* startAddrsHi */ 40 {L_INHRT, T_PSHIFT, -12000, 12000, 0}, /* lfo1ToPitch */ 41 {L_INHRT, T_PSHIFT, -12000, 12000, 0}, /* lfo2ToPitch */ 42 {L_INHRT, T_PSHIFT, -12000, 12000, 0}, /* env1ToPitch */ 43 {L_INHRT, T_CUTOFF, 1500, 13500, 13500}, /* initialFilterFc */ 44 {L_INHRT, T_FILTERQ, 0, 960, 0}, /* initialFilterQ */ 45 {L_INHRT, T_CSHIFT, -12000, 12000, 0}, /* lfo1ToFilterFc */ 46 {L_INHRT, T_CSHIFT, -12000, 12000, 0}, /* env1ToFilterFc */ 47 {L_INHRT, T_HI_OFF, 0, 0, 0}, /* endAddrsHi */ 48 {L_INHRT, T_TREMOLO, -960, 960, 0}, /* lfo1ToVolume */ 49 {L_INHRT, T_NOP, 0, 0, 0}, /* env2ToVolume / unused1 */ 50 {L_INHRT, T_TENPCT, 0, 1000, 0}, /* chorusEffectsSend */ 51 {L_INHRT, T_TENPCT, 0, 1000, 0}, /* reverbEffectsSend */ 52 {L_INHRT, T_PANPOS, 0, 1000, 0}, /* panEffectsSend */ 53 {L_INHRT, T_NOP, 0, 0, 0}, /* unused */ 54 {L_INHRT, T_NOP, 0, 0, 0}, /* sampleVolume / unused */ 55 {L_INHRT, T_NOP, 0, 0, 0}, /* unused3 */ 56 {L_INHRT, T_TIME, -12000, 5000, -12000}, /* delayLfo1 */ set_dry_signal(int32_t * buf,int32_t n)57 {L_INHRT, T_FREQ, -16000, 4500, 0}, /* freqLfo1 */ 58 {L_INHRT, T_TIME, -12000, 5000, -12000}, /* delayLfo2 */ 59 {L_INHRT, T_FREQ, -16000, 4500, 0}, /* freqLfo2 */ 60 {L_INHRT, T_TIME, -12000, 5000, -12000}, /* delayEnv1 */ 61 {L_INHRT, T_TIME, -12000, 5000, -12000}, /* attackEnv1 */ 62 {L_INHRT, T_TIME, -12000, 5000, -12000}, /* holdEnv1 */ 63 {L_INHRT, T_TIME, -12000, 5000, -12000}, /* decayEnv1 */ 64 {L_INHRT, T_MODSUST, 0, 1000, 0}, /* sustainEnv1 */ 65 {L_INHRT, T_TIME, -12000, 5000, -12000}, /* releaseEnv1 */ 66 {L_INHRT, T_TM_KEY, -1200, 1200, 0}, /* autoHoldEnv1 */ 67 {L_INHRT, T_TM_KEY, -1200, 1200, 0}, /* autoDecayEnv1 */ set_dry_signal_xg(int32_t * sbuffer,int32_t n,int32_t level)68 {L_INHRT, T_TIME, -12000, 5000, -12000}, /* delayEnv2 */ 69 {L_INHRT, T_TIME, -12000, 5000, -12000}, /* attackEnv2 */ 70 {L_INHRT, T_TIME, -12000, 5000, -12000}, /* holdEnv2 */ 71 {L_INHRT, T_TIME, -12000, 5000, -12000}, /* decayEnv2 */ 72 {L_INHRT, T_VOLSUST, 0, 1440, 0}, /* sustainEnv2 */ 73 {L_INHRT, T_TIME, -12000, 5000, -12000}, /* releaseEnv2 */ 74 {L_INHRT, T_TM_KEY, -1200, 1200, 0}, /* autoHoldEnv2 */ 75 {L_INHRT, T_TM_KEY, -1200, 1200, 0}, /* autoDecayEnv2 */ 76 {L_PRSET, T_NOCONV, 0, 0, 0}, /* instrument */ 77 {L_INHRT, T_NOP, 0, 0, 0}, /* nop */ 78 {L_RANGE, T_RANGE, 0, 0, RANGE(0,127)}, /* keyRange */ 79 {L_RANGE, T_RANGE, 0, 0, RANGE(0,127)}, /* velRange */ 80 {L_INHRT, T_HI_OFF, 0, 0, 0}, /* startloopAddrsHi */ mix_dry_signal(int32_t * buf,int32_t n)81 {L_OVWRT, T_NOCONV, 0, 127, -1}, /* keynum */ 82 {L_OVWRT, T_NOCONV, 0, 127, -1}, /* velocity */ 83 {L_INHRT, T_ATTEN, 0, 1440, 0}, /* initialAttenuation */ 84 {L_INHRT, T_NOP, 0, 0, 0}, /* keyTuning */ 85 {L_INHRT, T_HI_OFF, 0, 0, 0}, /* endloopAddrsHi */ 86 {L_INHRT, T_NOCONV, -120, 120, 0}, /* coarseTune */ 87 {L_INHRT, T_NOCONV, -99, 99, 0}, /* fineTune */ 88 {L_INSTR, T_NOCONV, 0, 0, 0}, /* sampleId */ 89 {L_OVWRT, T_NOCONV, 0, 3, 0}, /* sampleFlags */ isprime(int val)90 {L_OVWRT, T_NOCONV, 0, 0, 0}, /* samplePitch (only in SBK) */ 91 {L_INHRT, T_SCALE, 0, 1200, 100}, /* scaleTuning */ 92 {L_OVWRT, T_NOCONV, 0, 127, 0}, /* keyExclusiveClass */ 93 {L_OVWRT, T_NOCONV, 0, 127, -1}, /* rootKey */ 94 }; 95 96 } 97