cwSfTrack.h/cpp : Updates to support call to test() from score_test. Added result_count() and result_base().

This commit is contained in:
kevin 2023-08-20 17:14:25 -04:00
parent f27124a09a
commit 01e6ac208d
2 changed files with 41 additions and 58 deletions

View File

@ -7,6 +7,8 @@
#include "cwMidi.h" #include "cwMidi.h"
#include "cwMidiFile.h" #include "cwMidiFile.h"
#include "cwFileSys.h" #include "cwFileSys.h"
#include "cwDynRefTbl.h"
#include "cwScoreParse.h"
#include "cwSfScore.h" #include "cwSfScore.h"
#include "cwSfMatch.h" #include "cwSfMatch.h"
#include "cwSfTrack.h" #include "cwSfTrack.h"
@ -308,7 +310,6 @@ namespace cw
cw::rc_t cw::sftrack::create( handle_t& hRef, cw::rc_t cw::sftrack::create( handle_t& hRef,
double srate, // System sample rate.
sfscore::handle_t scH, // Score handle. See cmScore.h. sfscore::handle_t scH, // Score handle. See cmScore.h.
unsigned scWndN, // Length of the scores active search area. ** See Notes. unsigned scWndN, // Length of the scores active search area. ** See Notes.
unsigned midiWndN, // Length of the MIDI active note buffer. ** See Notes. unsigned midiWndN, // Length of the MIDI active note buffer. ** See Notes.
@ -430,6 +431,19 @@ cw::rc_t cw::sftrack::exec( handle_t h, unsigned smpIdx, unsigned muid, unsigned
return rc; return rc;
} }
unsigned cw::sftrack::result_count( handle_t h )
{
sftrack_t* p = _handleToPtr(h);
return p->ri;
}
const cw::sftrack::result_t* cw::sftrack::result_base( handle_t h )
{
sftrack_t* p = _handleToPtr(h);
return p->res;
}
void cw::sftrack::print( handle_t h ) void cw::sftrack::print( handle_t h )
{ {
sftrack_t* p = _handleToPtr(h); sftrack_t* p = _handleToPtr(h);
@ -447,42 +461,27 @@ namespace cw
} }
} }
cw::rc_t cw::sftrack::test( const object_t* cfg ) cw::rc_t cw::sftrack::test( const object_t* cfg, sfscore::handle_t scoreH )
{ {
rc_t rc = kOkRC; rc_t rc = kOkRC;
const char* score_csv_fname = nullptr;
double srate = 48000.0;
unsigned maxScWndN = 10;
unsigned maxMidiWndN = 7;
bool report_midi_file_fl = false; bool report_midi_file_fl = false;
bool report_score_fl = false;
bool report_track_fl = false; bool report_track_fl = false;
sfscore::dyn_ref_t* dynRefA = nullptr;
unsigned dynRefN = 0;;
const object_t* dynArrayNode = nullptr;
const object_t* perf = nullptr; const object_t* perf = nullptr;
bool perf_enable_fl = false; bool perf_enable_fl = false;
unsigned perf_loc_idx = 0; unsigned perf_loc_idx = 0;
const char* perf_midi_fname = nullptr; const char* perf_midi_fname = nullptr;
unsigned maxScWndN = 10;
unsigned maxMidiWndN = 7;
const midi::file::trackMsg_t** midiMsgA = nullptr; const midi::file::trackMsg_t** midiMsgA = nullptr;
unsigned midiMsgN = 0; unsigned midiMsgN = 0;
sfscore::handle_t scoreH;
sftrack::handle_t trackH; sftrack::handle_t trackH;
midi::file::handle_t mfH; midi::file::handle_t mfH;
// parse the test cfg // parse the test cfg
if((rc = cfg->getv( "cm_score_fname", score_csv_fname, if((rc = cfg->getv("maxScWndN", maxScWndN,
"srate", srate,
"dyn_ref", dynArrayNode,
"maxScWndN", maxScWndN,
"maxMidiWndN", maxMidiWndN, "maxMidiWndN", maxMidiWndN,
"report_midi_file_fl",report_midi_file_fl, "report_midi_file_fl",report_midi_file_fl,
"report_score_fl",report_score_fl,
"report_track_fl",report_track_fl, "report_track_fl",report_track_fl,
"perf", perf)) != kOkRC ) "perf", perf)) != kOkRC )
{ {
@ -498,25 +497,8 @@ cw::rc_t cw::sftrack::test( const object_t* cfg )
goto errLabel; goto errLabel;
} }
// dynamic reference
if((rc = sfscore::parse_dyn_ref_cfg( dynArrayNode, dynRefA, dynRefN )) != kOkRC )
{
rc = cwLogError(rc,"The reference dynamics array parse failed.");
goto errLabel;
}
// create the score
if((rc = sfscore::create(scoreH,score_csv_fname,srate,dynRefA,dynRefN)) != kOkRC )
{
rc = cwLogError(rc,"Score test create failed.");
goto errLabel;
}
if( report_score_fl )
report(scoreH);
// create the score tracker // create the score tracker
if((rc = create(trackH, srate, scoreH, maxScWndN, maxMidiWndN, _test_cb_func, nullptr )) != kOkRC ) if((rc = create(trackH, scoreH, maxScWndN, maxMidiWndN, _test_cb_func, nullptr )) != kOkRC )
{ {
rc = cwLogError(rc,"sftrack create failed."); rc = cwLogError(rc,"sftrack create failed.");
goto errLabel; goto errLabel;
@ -561,9 +543,7 @@ cw::rc_t cw::sftrack::test( const object_t* cfg )
errLabel: errLabel:
midi::file::close(mfH); midi::file::close(mfH);
sftrack::destroy(trackH); destroy(trackH);
sfscore::destroy(scoreH);
mem::release(dynRefA);
return rc; return rc;
} }

View File

@ -51,7 +51,6 @@ namespace cw
typedef handle<struct sftrack_str> handle_t; typedef handle<struct sftrack_str> handle_t;
rc_t create( handle_t& hRef, rc_t create( handle_t& hRef,
double srate, // System sample rate.
sfscore::handle_t scH, // Score handle. See cmScore.h. sfscore::handle_t scH, // Score handle. See cmScore.h.
unsigned scWndN, // Length of the scores active search area. ** See Notes. unsigned scWndN, // Length of the scores active search area. ** See Notes.
unsigned midiWndN, // Length of the MIDI active note buffer. ** See Notes. unsigned midiWndN, // Length of the MIDI active note buffer. ** See Notes.
@ -112,9 +111,13 @@ namespace cw
midi::byte_t d1, midi::byte_t d1,
unsigned* scLocIdxPtr ); unsigned* scLocIdxPtr );
unsigned result_count( handle_t h );
const result_t* result_base( handle_t h );
void print( handle_t h ); void print( handle_t h );
rc_t test( const object_t* cfg ); rc_t test( const object_t* cfg, sfscore::handle_t scoreH );
} }
} }