/[svn]/libgig/trunk/src/tools/gigdump.cpp
ViewVC logotype

Contents of /libgig/trunk/src/tools/gigdump.cpp

Parent Directory Parent Directory | Revision Log Revision Log


Revision 511 - (show annotations) (download)
Thu May 5 13:49:53 2005 UTC (18 years, 11 months ago) by schoenebeck
Original Path: libgig/trunk/src/gigdump.cpp
File size: 16578 byte(s)
* src/gigdump.cpp: added output of LoopPlayCount

1 /***************************************************************************
2 * *
3 * libgig - C++ cross-platform Gigasampler format file loader library *
4 * *
5 * Copyright (C) 2003-2005 by Christian Schoenebeck *
6 * <cuse@users.sourceforge.net> *
7 * *
8 * This program is free software; you can redistribute it and/or modify *
9 * it under the terms of the GNU General Public License as published by *
10 * the Free Software Foundation; either version 2 of the License, or *
11 * (at your option) any later version. *
12 * *
13 * This program is distributed in the hope that it will be useful, *
14 * but WITHOUT ANY WARRANTY; without even the implied warranty of *
15 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the *
16 * GNU General Public License for more details. *
17 * *
18 * You should have received a copy of the GNU General Public License *
19 * along with this program; if not, write to the Free Software *
20 * Foundation, Inc., 59 Temple Place, Suite 330, Boston, *
21 * MA 02111-1307 USA *
22 ***************************************************************************/
23
24 #ifdef HAVE_CONFIG_H
25 # include <config.h>
26 #endif
27
28 #include <iostream>
29 #include <cstdlib>
30
31 #include "gig.h"
32
33 using namespace std;
34
35 void PrintSamples(gig::File* gig);
36 void PrintInstruments(gig::File* gig);
37 void PrintRegions(gig::Instrument* instr);
38 void PrintUsage();
39 void PrintDimensionRegions(gig::Region* rgn);
40
41 int main(int argc, char *argv[])
42 {
43 if (argc <= 1) {
44 PrintUsage();
45 return EXIT_FAILURE;
46 }
47 FILE* hFile = fopen(argv[1], "r");
48 if (!hFile) {
49 cout << "Invalid file argument!" << endl;
50 return EXIT_FAILURE;
51 }
52 fclose(hFile);
53 try {
54 RIFF::File* riff = new RIFF::File(argv[1]);
55 gig::File* gig = new gig::File(riff);
56 PrintSamples(gig);
57 cout << endl;
58 PrintInstruments(gig);
59 delete gig;
60 delete riff;
61 }
62 catch (RIFF::Exception e) {
63 e.PrintMessage();
64 return EXIT_FAILURE;
65 }
66 catch (...) {
67 cout << "Unknown exception while trying to parse file." << endl;
68 return EXIT_FAILURE;
69 }
70
71 return EXIT_SUCCESS;
72 }
73
74 void PrintSamples(gig::File* gig) {
75 int samples = 0;
76 cout << "ALL Available Samples (as there might be more than referenced by Instruments):" << endl;
77 gig::Sample* pSample = gig->GetFirstSample();
78 while (pSample) {
79 samples++;
80 string name = pSample->pInfo->Name;
81 if (name == "") name = "<NO NAME>";
82 else name = '\"' + name + '\"';
83 cout << " Sample " << samples << ") " << name << ", ";
84 cout << pSample->SamplesPerSecond << "Hz, " << pSample->Channels << " Channels, " << pSample->Loops << " Loops";
85 if (pSample->Loops) {
86 cout << " (Type: ";
87 switch (pSample->LoopType) {
88 case gig::loop_type_normal: cout << "normal)"; break;
89 case gig::loop_type_bidirectional: cout << "pingpong)"; break;
90 case gig::loop_type_backward: cout << "reverse)"; break;
91 }
92 cout << ", LoopFraction=" << pSample->LoopFraction << ", Start=" << pSample->LoopStart << ", End=" << pSample->LoopEnd;
93 cout << ", LoopPlayCount=" << pSample->LoopPlayCount;
94 }
95 cout << ", Length=" << pSample->SamplesTotal << " Compressed=" << ((pSample->Compressed) ? "true" : "false") << endl;
96 pSample = gig->GetNextSample();
97 }
98 }
99
100 void PrintInstruments(gig::File* gig) {
101 int instruments = 0;
102 cout << "Available Instruments:" << endl;
103 gig::Instrument* pInstrument = gig->GetFirstInstrument();
104 while (pInstrument) {
105 instruments++;
106 string name = pInstrument->pInfo->Name;
107 if (name == "") name = "<NO NAME>";
108 else name = '\"' + name + '\"';
109 cout << " Instrument " << instruments << ") " << name << ", ";
110
111 cout << " MIDIBank=" << pInstrument->MIDIBank << ", MIDIProgram=" << pInstrument->MIDIProgram << endl;
112 PrintRegions(pInstrument);
113
114 pInstrument = gig->GetNextInstrument();
115 }
116 }
117
118 void PrintRegions(gig::Instrument* instr) {
119 int iRegion = 1;
120 gig::Region* pRegion = instr->GetFirstRegion();
121 while (pRegion) {
122 cout << " Region " << iRegion++ << ") ";
123 gig::Sample* pSample = pRegion->GetSample();
124 if (pSample) {
125 cout << "Sample: ";
126 if (pSample->pInfo->Name != "") {
127 cout << "\"" << pSample->pInfo->Name << "\", ";
128 }
129 cout << pSample->SamplesPerSecond << "Hz, " << endl;
130 }
131 else {
132 cout << "<NO_VALID_SAMPLE_REFERENCE> ";
133 }
134 cout << " KeyRange=" << pRegion->KeyRange.low << "-" << pRegion->KeyRange.high << ", ";
135 cout << "VelocityRange=" << pRegion->VelocityRange.low << "-" << pRegion->VelocityRange.high << ", Layers=" << pRegion->Layers << endl;
136 cout << " Loops=" << pRegion->SampleLoops << endl;
137 cout << " Dimensions=" << pRegion->Dimensions << endl;
138 for (int iDimension = 0; iDimension < pRegion->Dimensions; iDimension++) {
139 cout << " Dimension[" << iDimension << "]: Type=";
140 gig::dimension_def_t DimensionDef = pRegion->pDimensionDefinitions[iDimension];
141 switch (DimensionDef.dimension) {
142 case gig::dimension_none:
143 cout << "NONE";
144 break;
145 case gig::dimension_samplechannel: // If used sample has more than one channel (thus is not mono).
146 cout << "SAMPLECHANNEL";
147 break;
148 case gig::dimension_layer: { // For layering of up to 8 instruments (and eventually crossfading of 2 or 4 layers).
149 gig::crossfade_t crossfade = pRegion->pDimensionRegions[iDimension]->Crossfade;
150 cout << "LAYER (Crossfade in_start=" << (int) crossfade.in_start << ",in_end=" << (int) crossfade.in_end << ",out_start=" << (int) crossfade.out_start << ",out_end=" << (int) crossfade.out_end << ")";
151 break;
152 }
153 case gig::dimension_velocity: // Key Velocity (this is the only dimension where the ranges can exactly be defined).
154 cout << "VELOCITY";
155 break;
156 case gig::dimension_channelaftertouch: // Channel Key Pressure
157 cout << "AFTERTOUCH";
158 break;
159 case gig::dimension_releasetrigger: // Special dimension for triggering samples on releasing a key.
160 cout << "RELEASETRIGGER";
161 break;
162 case gig::dimension_keyboard: // Key Position
163 cout << "KEYBOARD";
164 break;
165 case gig::dimension_roundrobin: // Different samples triggered each time a note is played, dimension regions selected in sequence
166 cout << "ROUNDROBIN";
167 break;
168 case gig::dimension_random: // Different samples triggered each time a note is played, random order
169 cout << "RANDOM";
170 break;
171 case gig::dimension_modwheel: // Modulation Wheel (MIDI Controller 1)
172 cout << "MODWHEEL";
173 break;
174 case gig::dimension_breath: // Breath Controller (Coarse, MIDI Controller 2)
175 cout << "BREATH";
176 break;
177 case gig::dimension_foot: // Foot Pedal (Coarse, MIDI Controller 4)
178 cout << "FOOT";
179 break;
180 case gig::dimension_portamentotime: // Portamento Time (Coarse, MIDI Controller 5)
181 cout << "PORTAMENTOTIME";
182 break;
183 case gig::dimension_effect1: // Effect Controller 1 (Coarse, MIDI Controller 12)
184 cout << "EFFECT1";
185 break;
186 case gig::dimension_effect2: // Effect Controller 2 (Coarse, MIDI Controller 13)
187 cout << "EFFECT2";
188 break;
189 case gig::dimension_genpurpose1: // General Purpose Controller 1 (Slider, MIDI Controller 16)
190 cout << "GENPURPOSE1";
191 break;
192 case gig::dimension_genpurpose2: // General Purpose Controller 2 (Slider, MIDI Controller 17)
193 cout << "GENPURPOSE2";
194 break;
195 case gig::dimension_genpurpose3: // General Purpose Controller 3 (Slider, MIDI Controller 18)
196 cout << "GENPURPOSE3";
197 break;
198 case gig::dimension_genpurpose4: // General Purpose Controller 4 (Slider, MIDI Controller 19)
199 cout << "GENPURPOSE4";
200 break;
201 case gig::dimension_sustainpedal: // Sustain Pedal (MIDI Controller 64)
202 cout << "SUSTAINPEDAL";
203 break;
204 case gig::dimension_portamento: // Portamento (MIDI Controller 65)
205 cout << "PORTAMENTO";
206 break;
207 case gig::dimension_sostenutopedal: // Sostenuto Pedal (MIDI Controller 66)
208 cout << "SOSTENUTOPEDAL";
209 break;
210 case gig::dimension_softpedal: // Soft Pedal (MIDI Controller 67)
211 cout << "SOFTPEDAL";
212 break;
213 case gig::dimension_genpurpose5: // General Purpose Controller 5 (Button, MIDI Controller 80)
214 cout << "GENPURPOSE5";
215 break;
216 case gig::dimension_genpurpose6: // General Purpose Controller 6 (Button, MIDI Controller 81)
217 cout << "GENPURPOSE6";
218 break;
219 case gig::dimension_genpurpose7: // General Purpose Controller 7 (Button, MIDI Controller 82)
220 cout << "GENPURPOSE7";
221 break;
222 case gig::dimension_genpurpose8: // General Purpose Controller 8 (Button, MIDI Controller 83)
223 cout << "GENPURPOSE8";
224 break;
225 case gig::dimension_effect1depth: // Effect 1 Depth (MIDI Controller 91)
226 cout << "EFFECT1DEPTH";
227 break;
228 case gig::dimension_effect2depth: // Effect 2 Depth (MIDI Controller 92)
229 cout << "EFFECT2DEPTH";
230 break;
231 case gig::dimension_effect3depth: // Effect 3 Depth (MIDI Controller 93)
232 cout << "EFFECT3DEPTH";
233 break;
234 case gig::dimension_effect4depth: // Effect 4 Depth (MIDI Controller 94)
235 cout << "EFFECT4DEPTH";
236 break;
237 case gig::dimension_effect5depth: // Effect 5 Depth (MIDI Controller 95)
238 cout << "EFFECT5DEPTH";
239 break;
240 default:
241 cout << "UNKNOWN (" << int(DimensionDef.dimension) << ") - please report this !";
242 break;
243 }
244 cout << ", Bits=" << (uint) DimensionDef.bits << ", Zones=" << (uint) DimensionDef.zones;
245 cout << ", SplitType=";
246 switch (DimensionDef.split_type) {
247 case gig::split_type_normal:
248 cout << "NORMAL" << endl;
249 break;
250 case gig::split_type_customvelocity:
251 cout << "CUSTOMVELOCITY" << endl;
252 break;
253 case gig::split_type_bit:
254 cout << "BIT" << endl;
255 break;
256 default:
257 cout << "UNKNOWN" << endl;
258 }
259 }
260
261 PrintDimensionRegions(pRegion);
262
263 pRegion = instr->GetNextRegion();
264 }
265 }
266
267 void PrintDimensionRegions(gig::Region* rgn) {
268 int dimensionRegions = 0;
269 gig::DimensionRegion* pDimensionRegion;
270 while (dimensionRegions < 32) {
271 pDimensionRegion = rgn->pDimensionRegions[dimensionRegions];
272 if (!pDimensionRegion) break;
273
274 cout << " Dimension Region " << dimensionRegions + 1 << ")" << endl;
275
276 gig::Sample* pSample = pDimensionRegion->pSample;
277 if (pSample) {
278 cout << " Sample: ";
279 if (pSample->pInfo->Name != "") {
280 cout << "\"" << pSample->pInfo->Name << "\", ";
281 }
282 cout << pSample->SamplesPerSecond << "Hz, ";
283 cout << "UnityNote=" << (int) pDimensionRegion->UnityNote << ", FineTune=" << (int) pDimensionRegion->FineTune << ", Gain=" << (-pDimensionRegion->Gain / 655360.0) << "dB, SampleStartOffset=" << pDimensionRegion->SampleStartOffset << endl;
284 }
285 else {
286 cout << " Sample: <NO_VALID_SAMPLE_REFERENCE> " << endl;
287 }
288 cout << " LFO1Frequency=" << pDimensionRegion->LFO1Frequency << "Hz, LFO1InternalDepth=" << pDimensionRegion-> LFO1InternalDepth << ", LFO1ControlDepth=" << pDimensionRegion->LFO1ControlDepth << " LFO1Controller=" << pDimensionRegion->LFO1Controller << endl;
289 cout << " LFO2Frequency=" << pDimensionRegion->LFO2Frequency << "Hz, LFO2InternalDepth=" << pDimensionRegion-> LFO2InternalDepth << ", LFO2ControlDepth=" << pDimensionRegion->LFO2ControlDepth << " LFO2Controller=" << pDimensionRegion->LFO2Controller << endl;
290 cout << " LFO3Frequency=" << pDimensionRegion->LFO3Frequency << "Hz, LFO3InternalDepth=" << pDimensionRegion-> LFO3InternalDepth << ", LFO3ControlDepth=" << pDimensionRegion->LFO3ControlDepth << " LFO3Controller=" << pDimensionRegion->LFO3Controller << endl;
291 cout << " EG1PreAttack=" << pDimensionRegion->EG1PreAttack << "permille, EG1Attack=" << pDimensionRegion->EG1Attack << "s, EG1Decay1=" << pDimensionRegion->EG1Decay1 << "s, EG1Sustain=" << pDimensionRegion->EG1Sustain << "permille, EG1Release=" << pDimensionRegion->EG1Release << "s, EG1Decay2=" << pDimensionRegion->EG1Decay2 << "s, EG1Hold=" << pDimensionRegion->EG1Hold << endl;
292 cout << " EG2PreAttack=" << pDimensionRegion->EG2PreAttack << "permille, EG2Attack=" << pDimensionRegion->EG2Attack << "s, EG2Decay1=" << pDimensionRegion->EG2Decay1 << "s, EG2Sustain=" << pDimensionRegion->EG2Sustain << "permille, EG2Release=" << pDimensionRegion->EG2Release << "s, EG2Decay2=" << pDimensionRegion->EG2Decay2 << "s" << endl;
293 cout << " VCFEnabled=" << pDimensionRegion->VCFEnabled << ", VCFType=" << pDimensionRegion->VCFType << ", VCFCutoff=" << (int) pDimensionRegion->VCFCutoff << ", VCFResonance=" << (int) pDimensionRegion->VCFResonance << ", VCFCutoffController=" << pDimensionRegion->VCFCutoffController << endl;
294 cout << " VelocityResponseCurve=";
295 switch (pDimensionRegion->VelocityResponseCurve) {
296 case gig::curve_type_nonlinear:
297 cout << "NONLINEAR";
298 break;
299 case gig::curve_type_linear:
300 cout << "LINEAR";
301 break;
302 case gig::curve_type_special:
303 cout << "SPECIAL";
304 break;
305 case gig::curve_type_unknown:
306 default:
307 cout << "UNKNOWN - please report this !";
308 }
309 cout << ", VelocityResponseDepth=" << (int) pDimensionRegion->VelocityResponseDepth << ", VelocityResponseCurveScaling=" << (int) pDimensionRegion->VelocityResponseCurveScaling << endl;
310 cout << " Pan=" << (int) pDimensionRegion->Pan << endl;
311
312 dimensionRegions++;
313 }
314 }
315
316 void PrintUsage() {
317 cout << "gigdump - parses Gigasampler files and prints out the content." << endl;
318 cout << endl;
319 cout << "Usage: gigdump FILE" << endl;
320 }

  ViewVC Help
Powered by ViewVC