This makes the editor quite a bit friendlier in terms of CPU usage. After checking for input, we wait for 1 ms if none was reported.

git-svn-id: https://svn.eduke32.com/eduke32@406 1a8010ca-5511-0410-912e-c29ae57300e0
This commit is contained in:
terminx 2006-12-11 21:56:00 +00:00
parent 215e0fb0c6
commit e7d1346248
6 changed files with 34 additions and 31 deletions

View file

@ -69,6 +69,7 @@ void initprintf(const char *, ...);
void debugprintf(const char *,...); void debugprintf(const char *,...);
int handleevents(void); int handleevents(void);
void idle(void);
typedef void (*KeyPressCallback)(long,long); typedef void (*KeyPressCallback)(long,long);
typedef void (*MousePressCallback)(long,long); typedef void (*MousePressCallback)(long,long);

View file

@ -397,7 +397,7 @@ CANCEL:
keystatus[1] = 1; keystatus[1] = 1;
quitevent = 0; quitevent = 0;
} }
} } else idle();
OSD_DispatchQueued(); OSD_DispatchQueued();
@ -433,7 +433,7 @@ CANCEL:
quitflag = 1; quitflag = 1;
break; break;
} }
} } else idle();
if (keystatus[0x15] != 0) { if (keystatus[0x15] != 0) {
keystatus[0x15] = 0; keystatus[0x15] = 0;
@ -457,7 +457,8 @@ CANCEL:
while ((keystatus[1]|keystatus[0x1c]|keystatus[0x39]|keystatus[0x31]|keystatus[0x2e]) == 0) while ((keystatus[1]|keystatus[0x1c]|keystatus[0x39]|keystatus[0x31]|keystatus[0x2e]) == 0)
{ {
if (handleevents()) if (quitevent) break; // like saying no if (handleevents()) { if (quitevent) break; } // like saying no
else idle();
if (keystatus[0x15] != 0) { if (keystatus[0x15] != 0) {
keystatus[0x15] = 0; keystatus[0x15] = 0;
@ -2500,7 +2501,7 @@ long gettile(long tilenum)
if (handleevents()) { if (handleevents()) {
if (quitevent) quitevent = 0; if (quitevent) quitevent = 0;
} } else idle();
synctics = totalclock-lockclock; synctics = totalclock-lockclock;
lockclock += synctics; lockclock += synctics;
@ -2570,7 +2571,7 @@ long gettile(long tilenum)
{ {
if (handleevents()) { if (handleevents()) {
if (quitevent) quitevent = 0; if (quitevent) quitevent = 0;
} } else idle();
ch = bgetchar(); ch = bgetchar();
@ -2821,7 +2822,7 @@ void overheadeditor(void)
keystatus[1] = 1; keystatus[1] = 1;
quitevent = 0; quitevent = 0;
} }
} } else idle();
OSD_DispatchQueued(); OSD_DispatchQueued();
@ -5459,7 +5460,7 @@ CANCEL:
if (quitevent) { if (quitevent) {
quitevent = 0; quitevent = 0;
} }
} } else idle();
ch = bgetchar(); ch = bgetchar();
@ -5481,7 +5482,7 @@ CANCEL:
if (quitevent) { if (quitevent) {
quitevent = 0; quitevent = 0;
} }
} } else idle();
ch = bgetchar(); ch = bgetchar();
@ -5706,7 +5707,7 @@ CANCEL:
if (handleevents()) { if (handleevents()) {
if (quitevent) quitevent = 0; if (quitevent) quitevent = 0;
} } else idle();
ch = bgetchar(); ch = bgetchar();
@ -5798,7 +5799,7 @@ CANCEL:
{ {
if (handleevents()) { if (handleevents()) {
if (quitevent) quitevent = 0; if (quitevent) quitevent = 0;
} } else idle();
ch = bgetchar(); ch = bgetchar();
@ -5812,7 +5813,7 @@ CANCEL:
{ {
if (handleevents()) { if (handleevents()) {
if (quitevent) break; // like saying no if (quitevent) break; // like saying no
} } else idle();
ch = bgetchar(); ch = bgetchar();
@ -6370,7 +6371,7 @@ long getnumber16(char namestart[80], long num, long maxnumber, char sign)
{ {
if (handleevents()) { if (handleevents()) {
if (quitevent) quitevent = 0; if (quitevent) quitevent = 0;
} } else idle();
ch = bgetchar(); ch = bgetchar();
@ -6415,7 +6416,7 @@ long getnumber256(char namestart[80], long num, long maxnumber, char sign)
{ {
if (handleevents()) { if (handleevents()) {
if (quitevent) quitevent = 0; if (quitevent) quitevent = 0;
} } else idle();
drawrooms(posx,posy,posz,ang,horiz,cursectnum); drawrooms(posx,posy,posz,ang,horiz,cursectnum);
#ifdef SUPERBUILD #ifdef SUPERBUILD
@ -6571,7 +6572,7 @@ long menuselect(void)
keystatus[1] = 1; keystatus[1] = 1;
quitevent = 0; quitevent = 0;
} }
} } else idle();
ch = bgetchar(); ch = bgetchar();
{ // JBF 20040208: seek to first name matching pressed character { // JBF 20040208: seek to first name matching pressed character
CACHE1D_FIND_REC *seeker = currentlist ? findfiles : finddirs; CACHE1D_FIND_REC *seeker = currentlist ? findfiles : finddirs;

View file

@ -492,11 +492,7 @@ long initmultiplayerscycle(void)
long i, k; long i, k;
extern long totalclock; extern long totalclock;
#ifdef _WIN32 idle();
Sleep(1);
#else
usleep(1);
#endif
getpacket(&i,0); getpacket(&i,0);

View file

@ -1499,6 +1499,10 @@ int handleevents(void)
return rv; return rv;
} }
void idle(void)
{
usleep(1);
}
static int buildkeytranslationtable(void) static int buildkeytranslationtable(void)
{ {

View file

@ -528,9 +528,10 @@ int handleevents(void)
return rv; return rv;
} }
void idle(void)
{
Sleep(1);
}

View file

@ -1626,7 +1626,7 @@ static int AskIfSure(void)
retval = 1; retval = 1;
break; break;
} }
} } else idle();
if (keystatus[0x15] != 0) if (keystatus[0x15] != 0)
{ {
keystatus[0x15] = 0; keystatus[0x15] = 0;
@ -4956,7 +4956,7 @@ static void EditSectorData(short sectnum)
if (handleevents()) if (handleevents())
{ {
if (quitevent) quitevent = 0; if (quitevent) quitevent = 0;
} } else idle();
printmessage16("Edit mode, press <Esc> to exit"); printmessage16("Edit mode, press <Esc> to exit");
if (keystatus[0xd0] > 0) if (keystatus[0xd0] > 0)
{ {
@ -5193,7 +5193,7 @@ static void EditWallData(short wallnum)
if (handleevents()) if (handleevents())
{ {
if (quitevent) quitevent = 0; if (quitevent) quitevent = 0;
} } else idle();
printmessage16("Edit mode, press <Esc> to exit"); printmessage16("Edit mode, press <Esc> to exit");
if (keystatus[0xd0] > 0) if (keystatus[0xd0] > 0)
{ {
@ -5327,7 +5327,7 @@ static void EditSpriteData(short spritenum)
if (handleevents()) if (handleevents())
{ {
if (quitevent) quitevent = 0; if (quitevent) quitevent = 0;
} } else idle();
printmessage16("Edit mode, press <Esc> to exit"); printmessage16("Edit mode, press <Esc> to exit");
if (keystatus[0xd0] > 0) if (keystatus[0xd0] > 0)
{ {
@ -5738,7 +5738,7 @@ static void FuncMenu(void)
if (handleevents()) if (handleevents())
{ {
if (quitevent) quitevent = 0; if (quitevent) quitevent = 0;
} } else idle();
printmessage16("Select an option, press <Esc> to exit"); printmessage16("Select an option, press <Esc> to exit");
if (keystatus[0xd0] > 0) if (keystatus[0xd0] > 0)
{ {