Addition new functions Timers

git-svn-id: svn://kolibrios.org@7997 a494cfbc-eb01-0410-851d-a64ba20cac60
This commit is contained in:
pavelyakov 2020-05-29 09:37:24 +00:00
parent 717f2f2b9f
commit 3feca3e420

100
programs/cmm/lib/timers.c Normal file
View File

@ -0,0 +1,100 @@
/* TIMERS PaulCodeman */
#define offsetSizeTimers 4*3+1
#define defaultMaxTimers 1000
:struct Timers
{
dword time;
dword alloc;
dword count;
dword size;
void watch(void);
void getTime();
dword set(dword,dword,byte);
dword clear(dword);
};
void Timers::getTime(void)
{
EAX = 26;
EBX = 9;
$int 0x40
time = EAX;
}
void Timers::watch(void)
{
dword position = 0;
dword i = 0;
IF (!alloc) RETURN;
getTime();
i = count;
position = alloc;
WHILE(i)
{
IF (DSDWORD[position])
{
IF (DSDWORD[position+4]<=time)
{
$call DSDWORD[position];
IF (DSBYTE[position+12]) DSDWORD[position+4] = time+DSDWORD[position+8];
ELSE
{
DSDWORD[position] = 0;
count--;
}
}
i--;
}
position+=offsetSizeTimers;
}
}
dword Timers::set(dword function, newTime, byte repeat)
{
dword position = 0;
dword i = 0;
IF (!alloc)
{
size = defaultMaxTimers*offsetSizeTimers;
alloc = malloc(size);
}
i = count;
position = alloc;
WHILE(i)
{
IF (!DSDWORD[position]) BREAK;
position+=offsetSizeTimers;
i--;
}
count++;
getTime();
DSDWORD[position] = function;
DSDWORD[position+4] = time+newTime;
DSBYTE[position+8] = newTime;
DSBYTE[position+12] = repeat;
RETURN position;
}
dword Timers::clear(dword id)
{
IF (!alloc) || (!DSDWORD[id]) RETURN 0;
count--;
DSDWORD[id] = 0;
RETURN id;
}
// Analogs JS Functions
:Timers Time = {0};
inline dword setTimeout(dword function, time)
{
RETURN Time.set(function, time, 0);
}
inline dword setInterval(dword function, time)
{
RETURN Time.set(function, time, 1);
}
inline dword clearTimeout(dword id)
{
RETURN Time.clear(id);
}
inline dword clearInterval(dword id)
{
RETURN Time.clear(id);
}