mirror of
https://github.com/Ninjdai1/pokeemerald.git
synced 2025-01-13 23:23:43 +01:00
Merge pull request #984 from Diegoisawesome/master
Make aif2pcm looping not dependent on order of MARK and INST chunks
This commit is contained in:
commit
a85587d8c2
@ -65,8 +65,8 @@ struct Bytes {
|
|||||||
};
|
};
|
||||||
|
|
||||||
struct Marker {
|
struct Marker {
|
||||||
uint16_t id;
|
unsigned short id;
|
||||||
uint32_t position;
|
unsigned long position;
|
||||||
// don't care about the name
|
// don't care about the name
|
||||||
};
|
};
|
||||||
|
|
||||||
@ -174,7 +174,7 @@ void read_aif(struct Bytes *aif, AifData *aif_data)
|
|||||||
}
|
}
|
||||||
|
|
||||||
struct Marker *markers = NULL;
|
struct Marker *markers = NULL;
|
||||||
unsigned short num_markers = 0;
|
unsigned short num_markers = 0, loop_start = 0, loop_end = 0;
|
||||||
unsigned long num_sample_frames = 0;
|
unsigned long num_sample_frames = 0;
|
||||||
|
|
||||||
// Read all the Chunks to populate the AifData struct.
|
// Read all the Chunks to populate the AifData struct.
|
||||||
@ -272,42 +272,13 @@ void read_aif(struct Bytes *aif, AifData *aif_data)
|
|||||||
unsigned short loop_type = (aif->data[pos++] << 8);
|
unsigned short loop_type = (aif->data[pos++] << 8);
|
||||||
loop_type |= (uint8_t)aif->data[pos++];
|
loop_type |= (uint8_t)aif->data[pos++];
|
||||||
|
|
||||||
if (loop_type && markers)
|
if (loop_type)
|
||||||
{
|
{
|
||||||
unsigned short marker_id = (aif->data[pos++] << 8);
|
loop_start = (aif->data[pos++] << 8);
|
||||||
marker_id |= (uint8_t)aif->data[pos++];
|
loop_start |= (uint8_t)aif->data[pos++];
|
||||||
|
|
||||||
struct Marker *cur_marker = markers;
|
loop_end = (aif->data[pos++] << 8);
|
||||||
|
loop_end |= (uint8_t)aif->data[pos++];
|
||||||
// Grab loop start point.
|
|
||||||
for (int i = 0; i < num_markers; i++, cur_marker++)
|
|
||||||
{
|
|
||||||
if (cur_marker->id == marker_id)
|
|
||||||
{
|
|
||||||
aif_data->loop_offset = cur_marker->position;
|
|
||||||
aif_data->has_loop = true;
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
marker_id = (aif->data[pos++] << 8);
|
|
||||||
marker_id |= (uint8_t)aif->data[pos++];
|
|
||||||
|
|
||||||
cur_marker = markers;
|
|
||||||
|
|
||||||
// Grab loop end point.
|
|
||||||
for (int i = 0; i < num_markers; i++, cur_marker++)
|
|
||||||
{
|
|
||||||
if (cur_marker->id == marker_id)
|
|
||||||
{
|
|
||||||
if (cur_marker->position < aif_data->loop_offset) {
|
|
||||||
aif_data->loop_offset = cur_marker->position;
|
|
||||||
aif_data->has_loop = true;
|
|
||||||
}
|
|
||||||
aif_data->num_samples = cur_marker->position;
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
@ -338,8 +309,41 @@ void read_aif(struct Bytes *aif, AifData *aif_data)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (markers)
|
||||||
|
{
|
||||||
|
// Resolve loop points.
|
||||||
|
struct Marker *cur_marker = markers;
|
||||||
|
|
||||||
|
// Grab loop start point.
|
||||||
|
for (int i = 0; i < num_markers; i++, cur_marker++)
|
||||||
|
{
|
||||||
|
if (cur_marker->id == loop_start)
|
||||||
|
{
|
||||||
|
aif_data->loop_offset = cur_marker->position;
|
||||||
|
aif_data->has_loop = true;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
cur_marker = markers;
|
||||||
|
|
||||||
|
// Grab loop end point.
|
||||||
|
for (int i = 0; i < num_markers; i++, cur_marker++)
|
||||||
|
{
|
||||||
|
if (cur_marker->id == loop_end)
|
||||||
|
{
|
||||||
|
if (cur_marker->position < aif_data->loop_offset) {
|
||||||
|
aif_data->loop_offset = cur_marker->position;
|
||||||
|
aif_data->has_loop = true;
|
||||||
|
}
|
||||||
|
aif_data->num_samples = cur_marker->position;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
free(markers);
|
free(markers);
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
// This is a table of deltas between sample values in compressed PCM data.
|
// This is a table of deltas between sample values in compressed PCM data.
|
||||||
const int gDeltaEncodingTable[] = {
|
const int gDeltaEncodingTable[] = {
|
||||||
|
Loading…
x
Reference in New Issue
Block a user