summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorDamien Zammit <damien@zamaudio.com>2016-02-02 16:49:12 +1100
committerDamien Zammit <damien@zamaudio.com>2016-02-02 16:49:12 +1100
commitd84463cd15d8875a78c1c8de5141a4ec330c59df (patch)
tree3132f158bbc49d554ece29fcc9816674955919ba
parent36b11098a209bcf9372bb83169a9ffa2ce68af59 (diff)
Unjumble the PT5 wav ordering in regions/tracks
by sorting alphanumerically and case insensitively Signed-off-by: Damien Zammit <damien@zamaudio.com>
-rw-r--r--libs/ptformat/ptfformat.cc28
-rw-r--r--libs/ptformat/ptfformat.h8
2 files changed, 32 insertions, 4 deletions
diff --git a/libs/ptformat/ptfformat.cc b/libs/ptformat/ptfformat.cc
index f233f51dfa..99c89510dc 100644
--- a/libs/ptformat/ptfformat.cc
+++ b/libs/ptformat/ptfformat.cc
@@ -631,6 +631,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;
int lengthofname, wavnumber;
@@ -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
diff --git a/libs/ptformat/ptfformat.h b/libs/ptformat/ptfformat.h
index be7076dbfd..1d3dac2ba3 100644
--- a/libs/ptformat/ptfformat.h
+++ b/libs/ptformat/ptfformat.h
@@ -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;