cwPianoScore.h/cpp : Added loc_to_pitch_context() in support of cwPresetSel.translate_frags()
This commit is contained in:
parent
b951e7a09d
commit
f9ac5a8f39
104
cwPianoScore.cpp
104
cwPianoScore.cpp
@ -8,10 +8,11 @@
|
|||||||
#include "cwTime.h"
|
#include "cwTime.h"
|
||||||
#include "cwFile.h"
|
#include "cwFile.h"
|
||||||
#include "cwCsv.h"
|
#include "cwCsv.h"
|
||||||
|
#include "cwVectOps.h"
|
||||||
|
|
||||||
namespace cw
|
namespace cw
|
||||||
{
|
{
|
||||||
namespace score
|
namespace perf_score
|
||||||
{
|
{
|
||||||
typedef struct score_str
|
typedef struct score_str
|
||||||
{
|
{
|
||||||
@ -47,6 +48,27 @@ namespace cw
|
|||||||
return rc;
|
return rc;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void _set_bar_pitch_index( score_t* p )
|
||||||
|
{
|
||||||
|
unsigned cntA[ midi::kMidiNoteCnt ];
|
||||||
|
unsigned barNumb = kInvalidId;
|
||||||
|
|
||||||
|
for(event_t* e=p->base; e!=nullptr; e=e->link)
|
||||||
|
{
|
||||||
|
if( barNumb != e->meas )
|
||||||
|
{
|
||||||
|
vop::fill(cntA,midi::kMidiNoteCnt,0);
|
||||||
|
barNumb = e->meas;
|
||||||
|
}
|
||||||
|
|
||||||
|
if( midi::isNoteOn(e->status,e->d1) )
|
||||||
|
{
|
||||||
|
e->barPitchIdx = cntA[ e->d0 ];
|
||||||
|
cntA[ e->d0 ] += 1;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
unsigned _scan_to_end_of_field( const char* lineBuf, unsigned buf_idx, unsigned bufCharCnt )
|
unsigned _scan_to_end_of_field( const char* lineBuf, unsigned buf_idx, unsigned bufCharCnt )
|
||||||
{
|
{
|
||||||
for(; buf_idx < bufCharCnt; ++buf_idx )
|
for(; buf_idx < bufCharCnt; ++buf_idx )
|
||||||
@ -132,6 +154,10 @@ namespace cw
|
|||||||
{
|
{
|
||||||
switch( field_idx )
|
switch( field_idx )
|
||||||
{
|
{
|
||||||
|
case kMeas_FIdx:
|
||||||
|
rc = _parse_csv_unsigned( line_buf, bfi, efi, e->meas );
|
||||||
|
break;
|
||||||
|
|
||||||
case kLoc_FIdx:
|
case kLoc_FIdx:
|
||||||
rc = _parse_csv_unsigned( line_buf, bfi, efi, e->loc );
|
rc = _parse_csv_unsigned( line_buf, bfi, efi, e->loc );
|
||||||
break;
|
break;
|
||||||
@ -408,7 +434,7 @@ namespace cw
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
cw::rc_t cw::score::create( handle_t& hRef, const char* fn )
|
cw::rc_t cw::perf_score::create( handle_t& hRef, const char* fn )
|
||||||
{
|
{
|
||||||
rc_t rc;
|
rc_t rc;
|
||||||
object_t* cfg = nullptr;
|
object_t* cfg = nullptr;
|
||||||
@ -421,6 +447,8 @@ cw::rc_t cw::score::create( handle_t& hRef, const char* fn )
|
|||||||
|
|
||||||
rc = _parse_csv(p,fn);
|
rc = _parse_csv(p,fn);
|
||||||
|
|
||||||
|
_set_bar_pitch_index(p);
|
||||||
|
|
||||||
hRef.set(p);
|
hRef.set(p);
|
||||||
|
|
||||||
p->has_locs_fl = true;
|
p->has_locs_fl = true;
|
||||||
@ -434,7 +462,7 @@ cw::rc_t cw::score::create( handle_t& hRef, const char* fn )
|
|||||||
return rc;
|
return rc;
|
||||||
}
|
}
|
||||||
|
|
||||||
cw::rc_t cw::score::create( handle_t& hRef, const object_t* cfg )
|
cw::rc_t cw::perf_score::create( handle_t& hRef, const object_t* cfg )
|
||||||
{
|
{
|
||||||
rc_t rc;
|
rc_t rc;
|
||||||
if((rc = destroy(hRef)) != kOkRC )
|
if((rc = destroy(hRef)) != kOkRC )
|
||||||
@ -449,6 +477,8 @@ cw::rc_t cw::score::create( handle_t& hRef, const object_t* cfg )
|
|||||||
goto errLabel;
|
goto errLabel;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
_set_bar_pitch_index(p);
|
||||||
|
|
||||||
p->has_locs_fl = true;
|
p->has_locs_fl = true;
|
||||||
|
|
||||||
hRef.set(p);
|
hRef.set(p);
|
||||||
@ -460,7 +490,7 @@ cw::rc_t cw::score::create( handle_t& hRef, const object_t* cfg )
|
|||||||
return rc;
|
return rc;
|
||||||
}
|
}
|
||||||
|
|
||||||
cw::rc_t cw::score::create_from_midi_csv( handle_t& hRef, const char* fn )
|
cw::rc_t cw::perf_score::create_from_midi_csv( handle_t& hRef, const char* fn )
|
||||||
{
|
{
|
||||||
rc_t rc;
|
rc_t rc;
|
||||||
if((rc = destroy(hRef)) != kOkRC )
|
if((rc = destroy(hRef)) != kOkRC )
|
||||||
@ -475,6 +505,8 @@ cw::rc_t cw::score::create_from_midi_csv( handle_t& hRef, const char* fn )
|
|||||||
goto errLabel;
|
goto errLabel;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
_set_bar_pitch_index(p);
|
||||||
|
|
||||||
p->has_locs_fl = false;
|
p->has_locs_fl = false;
|
||||||
|
|
||||||
hRef.set(p);
|
hRef.set(p);
|
||||||
@ -487,7 +519,7 @@ cw::rc_t cw::score::create_from_midi_csv( handle_t& hRef, const char* fn )
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
cw::rc_t cw::score::destroy( handle_t& hRef )
|
cw::rc_t cw::perf_score::destroy( handle_t& hRef )
|
||||||
{
|
{
|
||||||
rc_t rc = kOkRC;
|
rc_t rc = kOkRC;
|
||||||
|
|
||||||
@ -505,14 +537,14 @@ cw::rc_t cw::score::destroy( handle_t& hRef )
|
|||||||
return rc;
|
return rc;
|
||||||
}
|
}
|
||||||
|
|
||||||
bool cw::score::has_loc_info_flag( handle_t h )
|
bool cw::perf_score::has_loc_info_flag( handle_t h )
|
||||||
{
|
{
|
||||||
score_t* p = _handleToPtr(h);
|
score_t* p = _handleToPtr(h);
|
||||||
return p->has_locs_fl;
|
return p->has_locs_fl;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
unsigned cw::score::event_count( handle_t h )
|
unsigned cw::perf_score::event_count( handle_t h )
|
||||||
{
|
{
|
||||||
score_t* p = _handleToPtr(h);
|
score_t* p = _handleToPtr(h);
|
||||||
unsigned n = 0;
|
unsigned n = 0;
|
||||||
@ -522,70 +554,26 @@ unsigned cw::score::event_count( handle_t h )
|
|||||||
return n;
|
return n;
|
||||||
}
|
}
|
||||||
|
|
||||||
const cw::score::event_t* cw::score::base_event( handle_t h )
|
const cw::perf_score::event_t* cw::perf_score::base_event( handle_t h )
|
||||||
{
|
{
|
||||||
score_t* p = _handleToPtr(h);
|
score_t* p = _handleToPtr(h);
|
||||||
return p->base;
|
return p->base;
|
||||||
}
|
}
|
||||||
|
|
||||||
const cw::score::event_t* cw::score::loc_to_event( handle_t h, unsigned loc )
|
const cw::perf_score::event_t* cw::perf_score::loc_to_event( handle_t h, unsigned loc )
|
||||||
{
|
{
|
||||||
score_t* p = _handleToPtr(h);
|
score_t* p = _handleToPtr(h);
|
||||||
return _loc_to_event(p,loc);
|
return _loc_to_event(p,loc);
|
||||||
}
|
}
|
||||||
|
|
||||||
/*
|
void cw::perf_score::loc_to_pitch_context( handle_t h, uint8_t* preNoteCtxA, uint8_t* postNoteCtxA, unsigned ctxN )
|
||||||
unsigned cw::score::loc_count( handle_t h )
|
|
||||||
{
|
{
|
||||||
score_t* p = _handleToPtr(h);
|
score_t* p = _handleToPtr(h);
|
||||||
return p->maxLocId;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
bool cw::score::is_loc_valid( handle_t h, unsigned locId )
|
|
||||||
{
|
|
||||||
score_t* p = _handleToPtr(h);
|
|
||||||
return locId < p->maxLocId;
|
|
||||||
}
|
|
||||||
|
|
||||||
unsigned cw::score::loc_to_measure( handle_t h, unsigned locId )
|
cw::rc_t cw::perf_score::event_to_string( handle_t h, unsigned uid, char* buf, unsigned buf_byte_cnt )
|
||||||
{
|
|
||||||
score_t* p = _handleToPtr(h);
|
|
||||||
const event_t* e;
|
|
||||||
if((e = _loc_to_event(p,locId)) == nullptr )
|
|
||||||
return 0;
|
|
||||||
|
|
||||||
return kInvalidId;
|
|
||||||
}
|
|
||||||
|
|
||||||
unsigned cw::score::loc_to_next_note_on_measure( handle_t h, unsigned locId )
|
|
||||||
{
|
|
||||||
score_t* p = _handleToPtr(h);
|
|
||||||
const event_t* e = _loc_to_event(p,locId);
|
|
||||||
|
|
||||||
while( e != nullptr )
|
|
||||||
if( midi::isNoteOn(e->status,e->d1))
|
|
||||||
return e->meas;
|
|
||||||
|
|
||||||
return kInvalidId;
|
|
||||||
}
|
|
||||||
|
|
||||||
double cw::score::locs_to_diff_seconds( handle_t h, unsigned loc0Id, unsigned loc1Id )
|
|
||||||
{
|
|
||||||
score_t* p = _handleToPtr(h);
|
|
||||||
const event_t* e0 = _loc_to_event(p,loc0Id);
|
|
||||||
const event_t* e1 = _loc_to_event(p,loc1Id);
|
|
||||||
|
|
||||||
return e1->sec - e0->sec;
|
|
||||||
}
|
|
||||||
|
|
||||||
const cw::score::event_t* cw::score::uid_to_event( handle_t h, unsigned uid )
|
|
||||||
{
|
|
||||||
//hscore_t* p = _handleToPtr(h);
|
|
||||||
return nullptr;
|
|
||||||
}
|
|
||||||
*/
|
|
||||||
|
|
||||||
cw::rc_t cw::score::event_to_string( handle_t h, unsigned uid, char* buf, unsigned buf_byte_cnt )
|
|
||||||
{
|
{
|
||||||
score_t* p = _handleToPtr(h);
|
score_t* p = _handleToPtr(h);
|
||||||
const event_t* e = nullptr;
|
const event_t* e = nullptr;
|
||||||
@ -611,7 +599,7 @@ cw::rc_t cw::score::event_to_string( handle_t h, unsigned uid, char* buf, unsig
|
|||||||
return rc;
|
return rc;
|
||||||
}
|
}
|
||||||
|
|
||||||
cw::rc_t cw::score::test( const object_t* cfg )
|
cw::rc_t cw::perf_score::test( const object_t* cfg )
|
||||||
{
|
{
|
||||||
handle_t h;
|
handle_t h;
|
||||||
rc_t rc = kOkRC;
|
rc_t rc = kOkRC;
|
||||||
|
@ -3,7 +3,7 @@
|
|||||||
|
|
||||||
namespace cw
|
namespace cw
|
||||||
{
|
{
|
||||||
namespace score
|
namespace perf_score
|
||||||
{
|
{
|
||||||
typedef handle<struct score_str> handle_t;
|
typedef handle<struct score_str> handle_t;
|
||||||
|
|
||||||
@ -25,6 +25,7 @@ namespace cw
|
|||||||
unsigned bpm; // tempo BPM or 0
|
unsigned bpm; // tempo BPM or 0
|
||||||
char grace_mark[4]; // grace mark or 0
|
char grace_mark[4]; // grace mark or 0
|
||||||
unsigned bar; // bar number or 0
|
unsigned bar; // bar number or 0
|
||||||
|
unsigned barPitchIdx; // bar pitch index
|
||||||
unsigned section; // section number or 0
|
unsigned section; // section number or 0
|
||||||
struct event_str* link; // list link
|
struct event_str* link; // list link
|
||||||
} event_t;
|
} event_t;
|
||||||
@ -44,17 +45,7 @@ namespace cw
|
|||||||
const event_t* base_event( handle_t h );
|
const event_t* base_event( handle_t h );
|
||||||
|
|
||||||
const event_t* loc_to_event( handle_t h, unsigned loc );
|
const event_t* loc_to_event( handle_t h, unsigned loc );
|
||||||
|
void loc_to_pitch_context( handle_t h, uint8_t* preNoteCtxA, uint8_t* postNoteCtxA, unsigned ctxN );
|
||||||
/*
|
|
||||||
unsigned loc_count( handle_t h );
|
|
||||||
bool is_loc_valid( handle_t h, unsigned locId );
|
|
||||||
unsigned loc_to_measure( handle_t h, unsigned locId );
|
|
||||||
unsigned loc_to_next_note_on_measure( handle_t h, unsigned locId );
|
|
||||||
double locs_to_diff_seconds( handle_t h, unsigned loc0Id, unsigned loc1Id );
|
|
||||||
*/
|
|
||||||
|
|
||||||
//const event_t* uid_to_event( handle_t h, unsigned uid );
|
|
||||||
|
|
||||||
|
|
||||||
// Format the event as a string for printing.
|
// Format the event as a string for printing.
|
||||||
rc_t event_to_string( handle_t h, unsigned uid, char* buf, unsigned buf_byte_cnt );
|
rc_t event_to_string( handle_t h, unsigned uid, char* buf, unsigned buf_byte_cnt );
|
||||||
|
Loading…
Reference in New Issue
Block a user