Remove debug information, fix few bugs, including PgmUpDown handling and performance numbers out of range.

pull/581/head
Kevin 1 year ago
parent 2109b576e3
commit d5819608c5
  1. 83
      src/performanceconfig.cpp
  2. 4
      src/performanceconfig.h
  3. 45
      src/uimenu.cpp

@ -29,6 +29,8 @@
LOGMODULE ("Performance"); LOGMODULE ("Performance");
//#define VERBOSE_DEBUG
#define PERFORMANCE_DIR "performance" #define PERFORMANCE_DIR "performance"
#define DEFAULT_PERFORMANCE_FILENAME "performance.ini" #define DEFAULT_PERFORMANCE_FILENAME "performance.ini"
#define DEFAULT_PERFORMANCE_NAME "Default" #define DEFAULT_PERFORMANCE_NAME "Default"
@ -63,7 +65,9 @@ bool CPerformanceConfig::Init (void)
// List banks if present // List banks if present
ListPerformanceBanks(); ListPerformanceBanks();
#ifdef VERBOSE_DEBUG
#warning "PerformanceConfig in verbose debug printing mode"
LOGNOTE("Testing loading of banks"); LOGNOTE("Testing loading of banks");
for (unsigned i=0; i<NUM_PERFORMANCE_BANKS; i++) for (unsigned i=0; i<NUM_PERFORMANCE_BANKS; i++)
{ {
@ -73,7 +77,7 @@ bool CPerformanceConfig::Init (void)
SetNewPerformance(0); SetNewPerformance(0);
} }
} }
#endif
// Set to default initial bank // Set to default initial bank
SetPerformanceBank(0); SetPerformanceBank(0);
SetNewPerformance(0); SetNewPerformance(0);
@ -949,7 +953,9 @@ bool CPerformanceConfig::ListPerformances()
FILINFO FileInfo; FILINFO FileInfo;
FRESULT Result; FRESULT Result;
std::string PerfDir = "SD:/" PERFORMANCE_DIR + AddPerformanceBankDirName(m_nPerformanceBank); std::string PerfDir = "SD:/" PERFORMANCE_DIR + AddPerformanceBankDirName(m_nPerformanceBank);
#ifdef VERBOSE_DEBUG
LOGNOTE("Listing Performances from %s", PerfDir.c_str()); LOGNOTE("Listing Performances from %s", PerfDir.c_str());
#endif
Result = f_opendir (&Directory, PerfDir.c_str()); Result = f_opendir (&Directory, PerfDir.c_str());
if (Result != FR_OK) if (Result != FR_OK)
{ {
@ -985,27 +991,32 @@ bool CPerformanceConfig::ListPerformances()
if ((nPIndex < 1) || (nPIndex >= (NUM_PERFORMANCES+1))) if ((nPIndex < 1) || (nPIndex >= (NUM_PERFORMANCES+1)))
{ {
// Index is out of range - skip to next file // Index is out of range - skip to next file
continue; LOGNOTE ("Performance number out of range: %s (%d to %d)", FileInfo.fname, 1, NUM_PERFORMANCES);
} }
// Convert from "user facing" 1..indexed number to internal 0..indexed else
nPIndex = nPIndex-1;
if (m_PerformanceFileName[nPIndex].empty())
{ {
if(nPIndex > m_nLastPerformance) // Convert from "user facing" 1..indexed number to internal 0..indexed
nPIndex = nPIndex-1;
if (m_PerformanceFileName[nPIndex].empty())
{ {
m_nLastPerformance=nPIndex; if(nPIndex > m_nLastPerformance)
} {
m_nLastPerformance=nPIndex;
}
std::string FileName = OriFileName.substr(0,OriFileName.length()-4).substr(7,14); std::string FileName = OriFileName.substr(0,OriFileName.length()-4).substr(7,14);
m_PerformanceFileName[nPIndex] = FileName; m_PerformanceFileName[nPIndex] = FileName;
LOGNOTE ("Loading performance %s (%d, %s)", OriFileName.c_str(), nPIndex, FileName.c_str()); #ifdef VERBOSE_DEBUG
} LOGNOTE ("Loading performance %s (%d, %s)", OriFileName.c_str(), nPIndex, FileName.c_str());
else #endif
{ }
LOGNOTE ("Duplicate performance %s", OriFileName.c_str()); else
{
LOGNOTE ("Duplicate performance %s", OriFileName.c_str());
}
} }
} }
} }
} }
@ -1024,7 +1035,9 @@ void CPerformanceConfig::SetNewPerformance (unsigned nID)
std::string FileN = GetPerformanceFullFilePath(nID); std::string FileN = GetPerformanceFullFilePath(nID);
new (&m_Properties) CPropertiesFatFsFile(FileN.c_str(), m_pFileSystem); new (&m_Properties) CPropertiesFatFsFile(FileN.c_str(), m_pFileSystem);
#ifdef VERBOSE_DEBUG
LOGNOTE("Selecting Performance: %d (%s)", nID+1, FileN.c_str()); LOGNOTE("Selecting Performance: %d (%s)", nID+1, FileN.c_str());
#endif
} }
unsigned CPerformanceConfig::FindFirstPerformance (void) unsigned CPerformanceConfig::FindFirstPerformance (void)
@ -1123,27 +1136,29 @@ bool CPerformanceConfig::ListPerformanceBanks()
if ((FileInfo.fattrib & AM_DIR) != 0) if ((FileInfo.fattrib & AM_DIR) != 0)
{ {
// Looking for Performance banks of the form: 01_Perf Bank Name // Looking for Performance banks of the form: 01_Perf Bank Name
// So positions 0,1 = decimal digit // So positions 0,1,2 = decimal digit
// position 2 = "_" // position 3 = "_"
// positions 3.. = actual name // positions 4.. = actual name
// //
std::string OriFileName = FileInfo.fname; std::string OriFileName = FileInfo.fname;
size_t nLen = OriFileName.length(); size_t nLen = OriFileName.length();
if ( nLen > 3 && nLen <26 && strcmp(OriFileName.substr(2,1).c_str(), "_")==0) if ( nLen > 4 && nLen <26 && strcmp(OriFileName.substr(3,1).c_str(), "_")==0)
{ {
unsigned nBankIndex = stoi(OriFileName.substr(0,2)); unsigned nBankIndex = stoi(OriFileName.substr(0,3));
// Recall user index numbered 02..NUM_PERFORMANCE_BANKS // Recall user index numbered 002..NUM_PERFORMANCE_BANKS
// NB: Bank 01 is reserved for the default performance directory // NB: Bank 001 is reserved for the default performance directory
if ((nBankIndex > 0) && (nBankIndex <= NUM_PERFORMANCE_BANKS)) if ((nBankIndex > 0) && (nBankIndex <= NUM_PERFORMANCE_BANKS))
{ {
// Convert from "user facing" 1..indexed number to internal 0..indexed // Convert from "user facing" 1..indexed number to internal 0..indexed
nBankIndex = nBankIndex-1; nBankIndex = nBankIndex-1;
if (m_PerformanceBankName[nBankIndex].empty()) if (m_PerformanceBankName[nBankIndex].empty())
{ {
std::string BankName = OriFileName.substr(3,nLen); std::string BankName = OriFileName.substr(4,nLen);
m_PerformanceBankName[nBankIndex] = BankName; m_PerformanceBankName[nBankIndex] = BankName;
#ifdef VERBOSE_DEBUG
LOGNOTE ("Found performance bank %s (%d, %s)", OriFileName.c_str(), nBankIndex, BankName.c_str()); LOGNOTE ("Found performance bank %s (%d, %s)", OriFileName.c_str(), nBankIndex, BankName.c_str());
#endif
nNumBanks++; nNumBanks++;
if (nBankIndex > m_nLastPerformanceBank) if (nBankIndex > m_nLastPerformanceBank)
{ {
@ -1155,18 +1170,20 @@ bool CPerformanceConfig::ListPerformanceBanks()
LOGNOTE ("Duplicate Performance Bank: %s", FileInfo.fname); LOGNOTE ("Duplicate Performance Bank: %s", FileInfo.fname);
if (nBankIndex==0) if (nBankIndex==0)
{ {
LOGNOTE ("(Bank 01 is the default performance directory)"); LOGNOTE ("(Bank 001 is the default performance directory)");
} }
} }
} }
else else
{ {
LOGNOTE ("Performance Bank number out of range: %s", FileInfo.fname); LOGNOTE ("Performance Bank number out of range: %s (%d to %d)", FileInfo.fname, 1, NUM_PERFORMANCE_BANKS);
} }
} }
else else
{ {
//LOGNOTE ("Skipping: %s", FileInfo.fname); #ifdef VERBOSE_DEBUG
LOGNOTE ("Skipping: %s", FileInfo.fname);
#endif
} }
} }
@ -1187,7 +1204,9 @@ void CPerformanceConfig::SetPerformanceBank(unsigned nBankID)
assert (nBankID < NUM_PERFORMANCE_BANKS); assert (nBankID < NUM_PERFORMANCE_BANKS);
if (IsValidPerformanceBank(nBankID)) if (IsValidPerformanceBank(nBankID))
{ {
#ifdef VERBOSE_DEBUG
LOGNOTE("Selecting Performance Bank: %d", nBankID+1); LOGNOTE("Selecting Performance Bank: %d", nBankID+1);
#endif
m_nPerformanceBank = nBankID; m_nPerformanceBank = nBankID;
ListPerformances(); ListPerformances();
} }
@ -1216,14 +1235,19 @@ std::string CPerformanceConfig::AddPerformanceBankDirName(unsigned nBankID)
assert (nBankID < NUM_PERFORMANCE_BANKS); assert (nBankID < NUM_PERFORMANCE_BANKS);
if (IsValidPerformanceBank(nBankID)) if (IsValidPerformanceBank(nBankID))
{ {
// Performance Banks directories in format "01_Bank Name" // Performance Banks directories in format "001_Bank Name"
std::string Index; std::string Index;
if (nBankID == 0) if (nBankID == 0)
{ {
// Legacy: Bank 1 is the default performance directory // Legacy: Bank 1 is the default performance directory
return ""; return "";
} }
if (nBankID < 9) if (nBankID < 9)
{
Index = "00" + std::to_string(nBankID+1);
}
else if (nBankID < 99)
{ {
Index = "0" + std::to_string(nBankID+1); Index = "0" + std::to_string(nBankID+1);
} }
@ -1231,6 +1255,7 @@ std::string CPerformanceConfig::AddPerformanceBankDirName(unsigned nBankID)
{ {
Index = std::to_string(nBankID+1); Index = std::to_string(nBankID+1);
} }
return "/" + Index + "_" + m_PerformanceBankName[nBankID]; return "/" + Index + "_" + m_PerformanceBankName[nBankID];
} }
else else

@ -27,8 +27,8 @@
#include <fatfs/ff.h> #include <fatfs/ff.h>
#include <Properties/propertiesfatfsfile.h> #include <Properties/propertiesfatfsfile.h>
#define NUM_VOICE_PARAM 156 #define NUM_VOICE_PARAM 156
#define NUM_PERFORMANCES 256 #define NUM_PERFORMANCES 128
#define NUM_PERFORMANCE_BANKS 64 #define NUM_PERFORMANCE_BANKS 128
class CPerformanceConfig // Performance configuration class CPerformanceConfig // Performance configuration
{ {

@ -1213,24 +1213,43 @@ void CUIMenu::PgmUpDownHandler (TMenuEvent Event)
// Program Up/Down acts on performances // Program Up/Down acts on performances
unsigned nLastPerformance = m_pMiniDexed->GetLastPerformance(); unsigned nLastPerformance = m_pMiniDexed->GetLastPerformance();
unsigned nPerformance = m_pMiniDexed->GetActualPerformanceID(); unsigned nPerformance = m_pMiniDexed->GetActualPerformanceID();
unsigned nStart = nPerformance;
//LOGNOTE("Performance actual=%d, last=%d", nPerformance, nLastPerformance); //LOGNOTE("Performance actual=%d, last=%d", nPerformance, nLastPerformance);
if (Event == MenuEventPgmDown) if (Event == MenuEventPgmDown)
{ {
if (nPerformance > 0) do
{ {
m_nSelectedPerformanceID = nPerformance-1; if (nPerformance == 0)
m_pMiniDexed->SetNewPerformance(m_nSelectedPerformanceID); {
//LOGNOTE("Performance new=%d, last=%d", m_nSelectedPerformanceID, nLastPerformance); // Wrap around
} nPerformance = nLastPerformance;
}
else if (nPerformance > 0)
{
--nPerformance;
}
} while ((m_pMiniDexed->IsValidPerformance(nPerformance) != true) && (nPerformance != nStart));
m_nSelectedPerformanceID = nPerformance;
m_pMiniDexed->SetNewPerformance(m_nSelectedPerformanceID);
//LOGNOTE("Performance new=%d, last=%d", m_nSelectedPerformanceID, nLastPerformance);
} }
else else // MenuEventPgmUp
{ {
if (nPerformance < nLastPerformance-1) do
{ {
m_nSelectedPerformanceID = nPerformance+1; if (nPerformance == nLastPerformance)
m_pMiniDexed->SetNewPerformance(m_nSelectedPerformanceID); {
//LOGNOTE("Performance new=%d, last=%d", m_nSelectedPerformanceID, nLastPerformance); // Wrap around
} nPerformance = 0;
}
else if (nPerformance < nLastPerformance)
{
++nPerformance;
}
} while ((m_pMiniDexed->IsValidPerformance(nPerformance) != true) && (nPerformance != nStart));
m_nSelectedPerformanceID = nPerformance;
m_pMiniDexed->SetNewPerformance(m_nSelectedPerformanceID);
//LOGNOTE("Performance new=%d, last=%d", m_nSelectedPerformanceID, nLastPerformance);
} }
} }
else else
@ -1503,8 +1522,8 @@ void CUIMenu::PerformanceMenu (CUIMenu *pUIMenu, TMenuEvent Event)
} }
pUIMenu->m_pUI->DisplayWrite (pUIMenu->m_pParentMenu[pUIMenu->m_nCurrentMenuItem].Name, nPSelected.c_str(), pUIMenu->m_pUI->DisplayWrite (pUIMenu->m_pParentMenu[pUIMenu->m_nCurrentMenuItem].Name, nPSelected.c_str(),
Value.c_str (), Value.c_str (), true, true);
(int) nValue > 0, (int) nValue < (int) pUIMenu->m_pMiniDexed->GetLastPerformance()-1); // (int) nValue > 0, (int) nValue < (int) pUIMenu->m_pMiniDexed->GetLastPerformance());
} }
else else
{ {

Loading…
Cancel
Save