+ if (cue_data != NULL)
+ {
+ if (cue_data->tracks[2].fname == NULL) { // NULL means track2 is in same file as track1
+ Cur_LBA = Tracks[0].Length = cue_data->tracks[2].sector_offset;
+ }
+ i = 100 / cue_data->track_count+1;
+ for (num_track = 2; num_track <= cue_data->track_count; num_track++)
+ {
+ if (PicoCDLoadProgressCB != NULL) PicoCDLoadProgressCB(i * num_track);
+ index = num_track - 1;
+ Cur_LBA += cue_data->tracks[num_track].pregap;
+ if (cue_data->tracks[num_track].type == CT_MP3) {
+ ret = audio_track_mp3(cue_data->tracks[num_track].fname, index);
+ if (ret != 0) break;
+ }
+ else
+ {
+ Tracks[index].ftype = cue_data->tracks[num_track].type;
+ if (cue_data->tracks[num_track].fname != NULL)
+ {
+ pm_file *pmfn = pm_open(cue_data->tracks[num_track].fname);
+ if (pmfn != NULL)
+ {
+ // addume raw, ignore header for wav..
+ Tracks[index].F = pmfn;
+ Tracks[index].Length = pmfn->size / 2352;
+ Tracks[index].Offset = cue_data->tracks[num_track].sector_offset;
+ }
+ else
+ {
+ elprintf(EL_STATUS, "track %2i (%s): can't determine length",
+ num_track, cue_data->tracks[num_track].fname);
+ Tracks[index].Length = 2*75;
+ Tracks[index].Offset = 0;
+ }
+ }
+ else
+ {
+ if (num_track < cue_data->track_count)
+ Tracks[index].Length = cue_data->tracks[num_track+1].sector_offset -
+ cue_data->tracks[num_track].sector_offset;
+ else
+ Tracks[index].Length = cd_img_sectors - cue_data->tracks[num_track].sector_offset;
+ Tracks[index].Offset = cue_data->tracks[num_track].sector_offset;
+ }
+ }
+
+ if (cue_data->tracks[num_track].sector_xlength != 0)
+ // overriden by custom cue command
+ Tracks[index].Length = cue_data->tracks[num_track].sector_xlength;
+
+ LBA_to_MSF(Cur_LBA, &Tracks[index].MSF);
+ Cur_LBA += Tracks[index].Length;
+
+ elprintf(EL_STATUS, "Track %2i: %02d:%02d:%02d %9i AUDIO - %s", num_track, Tracks[index].MSF.M,
+ Tracks[index].MSF.S, Tracks[index].MSF.F, Tracks[index].Length,
+ cue_data->tracks[num_track].fname);
+ }
+ cue_destroy(cue_data);
+ goto finish;
+ }