aboutsummaryrefslogtreecommitdiff
path: root/core
diff options
context:
space:
mode:
authorGravatar Chris Xiong <chirs241097@gmail.com> 2019-11-16 12:30:51 +0800
committerGravatar Chris Xiong <chirs241097@gmail.com> 2019-11-16 12:30:51 +0800
commitaf657df8a4accb3758138769e3cc5b86530b57d5 (patch)
tree9563dc2e9b1ea36dc4d50be52c2e1d717f1fb8d6 /core
parentc12df3744f04716e88e905888beeaaa4f331d687 (diff)
downloadQMidiPlayer-af657df8a4accb3758138769e3cc5b86530b57d5.tar.xz
Even more fixes for Microsoft(R) Windows(R) operating system.
Device initalization file dialog doesn't work correctly on Windows. Make hiding console an option on Windows. For some dumb reason preset selection dialog refuses to work if no soundfont is selected.
Diffstat (limited to 'core')
-rw-r--r--core/qmpmidioutrtmidi.cpp11
1 files changed, 4 insertions, 7 deletions
diff --git a/core/qmpmidioutrtmidi.cpp b/core/qmpmidioutrtmidi.cpp
index 6dc9ca6..eeda04b 100644
--- a/core/qmpmidioutrtmidi.cpp
+++ b/core/qmpmidioutrtmidi.cpp
@@ -26,14 +26,16 @@ qmpDeviceInitializer* qmpDeviceInitializer::parse(const char* path)
{
qmpDeviceInitializer *ret=new qmpDeviceInitializer();
ret->initseq.eventList.clear();
- FILE* f=fopen(path, "r");
- if(!f)return nullptr;
bool st_inmapping=false;
char buf[1024];
int ln=0;
int cmsb=-1,clsb=-1;
+#define err(e) {delete ret;return fprintf(stderr,"line %d: %s",ln,e),nullptr;}
+ FILE* f=fopen(path,"r");
+ if(!f)err("file not found")
+
//writing such a bad parser makes me want my money for
//the credits from "compiler principles" back...
auto h2d=[](char c)->char{return 'F'>=c&&c>='A'?c-'A'+10:'9'>=c&&c>='0'?c-'0':-1;};
@@ -45,7 +47,6 @@ qmpDeviceInitializer* qmpDeviceInitializer::parse(const char* path)
(x<0||x>0xff)&&(x=-1);
return r==1?x:-1;
};
-#define err(e) {delete ret;return fprintf(stderr,"line %d: %s",ln,e),nullptr;}
while(fgets(buf,1024,f))
{
++ln;
@@ -232,17 +233,13 @@ void qmpMidiOutRtMidi::reset(uint8_t ch)
if(ch==0xFF)
{
if(devinit)
- {
for(auto&msg:devinit->initseq.eventList)
{
if((msg.type&0xF0)==0xF0)
extendedMessage(msg.str.length(),msg.str.data());
else
- {
basicMessage(msg.type,msg.p1,msg.p2);
- }
}
- }
}
else
{