Unjumble the PT5 wav ordering in regions/tracks

by sorting alphanumerically and case insensitively

Signed-off-by: Damien Zammit <damien@zamaudio.com>
This commit is contained in:
Damien Zammit 2016-02-02 16:49:12 +11:00 committed by Robin Gareus
parent 255fbe7b55
commit 81a9f7a956
2 changed files with 32 additions and 4 deletions

View file

@ -630,6 +630,17 @@ PTFFormat::parserest5(void) {
}
}
void
PTFFormat::resort(std::vector<wav_t> *ws) {
int j = 0;
std::sort((*ws).begin(), (*ws).end());
for (std::vector<wav_t>::iterator i = (*ws).begin();
i != (*ws).end(); ++i) {
(*i).index = j;
j++;
}
}
void
PTFFormat::parseaudio5(void) {
int i,k,l;
@ -670,6 +681,7 @@ PTFFormat::parseaudio5(void) {
wavnumber = 0;
i+=16;
char ext[5];
while (i < len && numberofwavs > 0) {
i++;
if ( (ptfunxored[i ] == 0x5a) &&
@ -684,11 +696,19 @@ PTFFormat::parseaudio5(void) {
wavname[l] = ptfunxored[i+l];
l++;
}
i+=lengthofname + 4;
i+=lengthofname;
ext[0] = ptfunxored[i++];
ext[1] = ptfunxored[i++];
ext[2] = ptfunxored[i++];
ext[3] = ptfunxored[i++];
ext[4] = '\0';
wavname[l] = 0;
if (foundin(wavname, ".wav")) {
if (foundin(wavname, ".L") || foundin(wavname, ".R")) {
extension = string("");
} else if (foundin(wavname, ".wav") || foundin(ext, "WAVE")) {
extension = string(".wav");
} else if (foundin(wavname, ".aif")) {
} else if (foundin(wavname, ".aif") || foundin(ext, "AIFF")) {
extension = string(".aif");
} else {
extension = string("");
@ -707,6 +727,8 @@ PTFFormat::parseaudio5(void) {
numberofwavs--;
i += 7;
}
resort(&actualwavs);
resort(&audiofiles);
}
void

View file

@ -16,10 +16,10 @@
#define PTFFORMAT_H
#include <string>
#include <cstring>
#include <algorithm>
#include <vector>
#include <stdint.h>
#include "ptformat/visibility.h"
class LIBPTFORMAT_API PTFFormat {
@ -39,6 +39,11 @@ public:
int64_t posabsolute;
int64_t length;
bool operator <(const struct wav& other) {
return (strcasecmp(this->filename.c_str(),
other.filename.c_str()) < 0);
}
bool operator ==(const struct wav& other) {
return (this->filename == other.filename ||
this->index == other.index);
@ -125,6 +130,7 @@ private:
void parserest10(void);
void parseaudio5(void);
void parseaudio(void);
void resort(std::vector<wav_t> *ws);
std::vector<wav_t> actualwavs;
float ratefactor;
std::string extension;