forked from KolibriOS/kolibrios
Fixed a bug in the mouse, added functions in string.h, optimized some functions.
git-svn-id: svn://kolibrios.org@5573 a494cfbc-eb01-0410-851d-a64ba20cac60
This commit is contained in:
parent
64effed438
commit
312f091355
@ -65,7 +65,7 @@ char program_path[4096];
|
|||||||
/**
|
/**
|
||||||
* The structure of the mouse
|
* The structure of the mouse
|
||||||
* x - coordinate X
|
* x - coordinate X
|
||||||
* ó - coordinate Ó
|
* y - coordinate Y
|
||||||
* xx and yy - time coordinates
|
* xx and yy - time coordinates
|
||||||
* lkm - left mouse button
|
* lkm - left mouse button
|
||||||
* pkm - right mouse button
|
* pkm - right mouse button
|
||||||
@ -82,6 +82,7 @@ char program_path[4096];
|
|||||||
void get();
|
void get();
|
||||||
};
|
};
|
||||||
|
|
||||||
|
//get new attributes mouse
|
||||||
:void mouse::get()
|
:void mouse::get()
|
||||||
{
|
{
|
||||||
EAX = 37;
|
EAX = 37;
|
||||||
@ -126,7 +127,8 @@ char program_path[4096];
|
|||||||
//when you press the mouse button
|
//when you press the mouse button
|
||||||
else {
|
else {
|
||||||
up = false;
|
up = false;
|
||||||
down = key;
|
if(key) down = true;
|
||||||
|
else down = false;
|
||||||
if(down) tmp = key;
|
if(down) tmp = key;
|
||||||
if((xx!=x)||(yy!=y)){
|
if((xx!=x)||(yy!=y)){
|
||||||
move = true;
|
move = true;
|
||||||
@ -136,7 +138,8 @@ char program_path[4096];
|
|||||||
else move = false;
|
else move = false;
|
||||||
}
|
}
|
||||||
|
|
||||||
EAX = 37; //áªà®««
|
//scroll
|
||||||
|
EAX = 37;
|
||||||
EBX = 7;
|
EBX = 7;
|
||||||
$int 0x40
|
$int 0x40
|
||||||
$mov ebx, eax
|
$mov ebx, eax
|
||||||
|
@ -2,22 +2,28 @@
|
|||||||
// strcmp( ESI, EDI)
|
// strcmp( ESI, EDI)
|
||||||
// strlen( EDI)
|
// strlen( EDI)
|
||||||
// strcpy( EDI, ESI) --- 0 if ==
|
// strcpy( EDI, ESI) --- 0 if ==
|
||||||
|
// strncpy(dword text1,text2,signed length)
|
||||||
// strcat( EDI, ESI)
|
// strcat( EDI, ESI)
|
||||||
|
// strncat(dword text1,text2,signed length) --- pasting the text of a certain length
|
||||||
// strchr( ESI,BL) --- find first BL
|
// strchr( ESI,BL) --- find first BL
|
||||||
// strrchr( ESI,BL) --- find last BL
|
// strrchr( ESI,BL) --- find last BL
|
||||||
// strstr( EBX, EDX)
|
// strstr( EBX, EDX)
|
||||||
// itoa( ESI)
|
// itoa(signed long number) --- convert the number as a string
|
||||||
// atoi( EAX)
|
// atoi(dword text) --- convert a string as a number
|
||||||
// strupr( ESI)
|
// strupr( ESI)
|
||||||
// strlwr( ESI) --- kyrillic symbols may not work
|
// strlwr( ESI) --- kyrillic symbols may not work
|
||||||
// strttl( EDX)
|
// strttl( EDX)
|
||||||
// strtok( ESI)
|
// strtok( ESI)
|
||||||
// strtrim( ESI) --- removes "blank" characters (\r, \n and space)
|
// strltrim(dword text) --- removes "blank" characters on the left (\r, \n and space)
|
||||||
|
// strrtrim(dword text) --- removes "blank" characters on the right (\r, \n and space)
|
||||||
|
// strtrim(dword text) --- delete "empty" characters (\ r \ n and space) on both sides
|
||||||
// chrnum(dword searchin, char symbol)
|
// chrnum(dword searchin, char symbol)
|
||||||
// strcpyb(dword searchin, copyin, startstr, endstr) --- copy string between strings
|
// strcpyb(dword searchin, copyin, startstr, endstr) --- copy string between strings
|
||||||
// strnumb(dword searchin, startstr, endstr) --- get number between strings
|
// strnumb(dword searchin, startstr, endstr) --- get number between strings
|
||||||
|
// strdup(dword text) --- allocation under the text
|
||||||
//------------------------------------------------------------------------------
|
//------------------------------------------------------------------------------
|
||||||
|
|
||||||
|
/*
|
||||||
inline fastcall signed int strcmp( ESI, EDI)
|
inline fastcall signed int strcmp( ESI, EDI)
|
||||||
{
|
{
|
||||||
loop()
|
loop()
|
||||||
@ -29,6 +35,7 @@ inline fastcall signed int strcmp( ESI, EDI)
|
|||||||
EDI++;
|
EDI++;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
inline fastcall signed int strncmp( ESI, EDI, ECX)
|
inline fastcall signed int strncmp( ESI, EDI, ECX)
|
||||||
@ -62,6 +69,31 @@ inline fastcall unsigned int strlen( EDI)
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
signed int strcmp(dword text1, text2)
|
||||||
|
{
|
||||||
|
char s1,s2;
|
||||||
|
dword p1,p2;
|
||||||
|
p1 = text1;
|
||||||
|
p2 = text2;
|
||||||
|
loop()
|
||||||
|
{
|
||||||
|
s1 = DSBYTE[text1];
|
||||||
|
s2 = DSBYTE[text2];
|
||||||
|
if(s1==s2)
|
||||||
|
{
|
||||||
|
if(s1==0) return 0;
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
|
||||||
|
return -1;
|
||||||
|
}
|
||||||
|
$inc text1
|
||||||
|
$inc text2
|
||||||
|
}
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
inline fastcall void strcpy( EDI, ESI)
|
inline fastcall void strcpy( EDI, ESI)
|
||||||
{
|
{
|
||||||
$cld
|
$cld
|
||||||
@ -72,6 +104,24 @@ L2:
|
|||||||
$jnz L2
|
$jnz L2
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void strncpy(dword text1, text2, signed len)
|
||||||
|
signed o1,o2;
|
||||||
|
{
|
||||||
|
o1 = len/4;
|
||||||
|
o2 = len-4*o1;
|
||||||
|
while(o1){
|
||||||
|
ESDWORD[text1] = ESDWORD[text2];
|
||||||
|
text1 += 4;
|
||||||
|
text2 += 4;
|
||||||
|
$dec o1
|
||||||
|
}
|
||||||
|
while(o2){
|
||||||
|
ESBYTE[text1] = ESBYTE[text2];
|
||||||
|
$inc text1
|
||||||
|
$inc text2
|
||||||
|
$dec o2
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
inline fastcall int strlcpy(dword ESI, EDI, EBX)
|
inline fastcall int strlcpy(dword ESI, EDI, EBX)
|
||||||
{
|
{
|
||||||
@ -87,7 +137,8 @@ inline fastcall int strlcpy(dword ESI, EDI, EBX)
|
|||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
inline fastcall strtrim( ESI)
|
/*
|
||||||
|
inline fastcall void strtrim( ESI)
|
||||||
{
|
{
|
||||||
EDI = ESI;
|
EDI = ESI;
|
||||||
do{
|
do{
|
||||||
@ -95,13 +146,90 @@ inline fastcall strtrim( ESI)
|
|||||||
if (AL != '\32') && (AL != '\13') && (AL != '\10')
|
if (AL != '\32') && (AL != '\13') && (AL != '\10')
|
||||||
{
|
{
|
||||||
DSBYTE[ESI]=AL;
|
DSBYTE[ESI]=AL;
|
||||||
ESI++;
|
$inc ESI
|
||||||
}
|
}
|
||||||
EDI++;
|
$inc EDI
|
||||||
}while(AL!=0);
|
}while(AL!=0);
|
||||||
DSBYTE[ESI] = '\0';
|
DSBYTE[ESI] = '\0';
|
||||||
}
|
}
|
||||||
|
*/
|
||||||
|
|
||||||
|
byte __isWhite(int s){ if (s==13)||(s==32)||(s==10)||(s==9) return true; return false; }
|
||||||
|
void strltrim(dword text){
|
||||||
|
int s;
|
||||||
|
dword back_text;
|
||||||
|
back_text = text;
|
||||||
|
s = ESBYTE[text];
|
||||||
|
while(__isWhite(s))
|
||||||
|
{
|
||||||
|
$inc text
|
||||||
|
s = ESBYTE[text];
|
||||||
|
}
|
||||||
|
loop()
|
||||||
|
{
|
||||||
|
ESBYTE[back_text] = s;
|
||||||
|
$inc back_text
|
||||||
|
if(!s) break;
|
||||||
|
$inc text
|
||||||
|
s = ESBYTE[text];
|
||||||
|
};
|
||||||
|
}
|
||||||
|
|
||||||
|
void strrtrim(dword text)
|
||||||
|
{
|
||||||
|
int s;
|
||||||
|
dword p;
|
||||||
|
do {
|
||||||
|
s = ESBYTE[text];
|
||||||
|
if(__isWhite(s))
|
||||||
|
{
|
||||||
|
p = text;
|
||||||
|
while(__isWhite(s))
|
||||||
|
{
|
||||||
|
$inc text;
|
||||||
|
s = ESBYTE[text];
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else $inc text
|
||||||
|
} while(s);
|
||||||
|
$dec text
|
||||||
|
s = ESBYTE[text];
|
||||||
|
if(__isWhite(s)) ESBYTE[p] = 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
void strtrim(dword text){
|
||||||
|
int s;
|
||||||
|
dword p,back_text;
|
||||||
|
back_text = text;
|
||||||
|
s = ESBYTE[text];
|
||||||
|
while(__isWhite(s))
|
||||||
|
{
|
||||||
|
$inc text
|
||||||
|
s = ESBYTE[text];
|
||||||
|
}
|
||||||
|
do {
|
||||||
|
s = ESBYTE[text];
|
||||||
|
if(__isWhite(s))
|
||||||
|
{
|
||||||
|
p = back_text;
|
||||||
|
while(__isWhite(s))
|
||||||
|
{
|
||||||
|
ESBYTE[back_text] = s;
|
||||||
|
$inc back_text
|
||||||
|
$inc text;
|
||||||
|
s = ESBYTE[text];
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
ESBYTE[back_text] = s;
|
||||||
|
$inc back_text
|
||||||
|
$inc text
|
||||||
|
}
|
||||||
|
} while(s);
|
||||||
|
$dec text
|
||||||
|
s = ESBYTE[text];
|
||||||
|
if(__isWhite(s)) ESBYTE[p] = 0;
|
||||||
|
}
|
||||||
|
|
||||||
inline fastcall void strcat( EDI, ESI)
|
inline fastcall void strcat( EDI, ESI)
|
||||||
{
|
{
|
||||||
@ -131,6 +259,31 @@ inline fastcall void strcat( EDI, ESI)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void strncat(dword text1, text2, signed len)
|
||||||
|
signed o1,o2;
|
||||||
|
char s;
|
||||||
|
{
|
||||||
|
s = ESBYTE[text1];
|
||||||
|
while(s){
|
||||||
|
$inc text1
|
||||||
|
s = ESBYTE[text1];
|
||||||
|
}
|
||||||
|
o1 = len/4;
|
||||||
|
o2 = len-4*o1;
|
||||||
|
while(o1){
|
||||||
|
ESDWORD[text1] = ESDWORD[text2];
|
||||||
|
text1 += 4;
|
||||||
|
text2 += 4;
|
||||||
|
$dec o1
|
||||||
|
}
|
||||||
|
while(o2){
|
||||||
|
ESBYTE[text1] = ESBYTE[text2];
|
||||||
|
$inc text1
|
||||||
|
$inc text2
|
||||||
|
$dec o2
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
inline fastcall void chrcat(ESI, BL)
|
inline fastcall void chrcat(ESI, BL)
|
||||||
{
|
{
|
||||||
EDI = strlen(ESI);
|
EDI = strlen(ESI);
|
||||||
@ -346,7 +499,7 @@ inline fastcall strttl( EDX)
|
|||||||
}while(AL!=0);
|
}while(AL!=0);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
dword itoa( ESI)
|
dword itoa( ESI)
|
||||||
{
|
{
|
||||||
unsigned char buffer[11];
|
unsigned char buffer[11];
|
||||||
@ -380,6 +533,49 @@ F3:
|
|||||||
$popa
|
$popa
|
||||||
return #buffer;
|
return #buffer;
|
||||||
}
|
}
|
||||||
|
*/
|
||||||
|
|
||||||
|
dword itoa(signed long number)
|
||||||
|
{
|
||||||
|
unsigned char buf[11];
|
||||||
|
dword ret;
|
||||||
|
byte cmd;
|
||||||
|
long mask,tmp;
|
||||||
|
mask = 1000000000;
|
||||||
|
cmd = true;
|
||||||
|
if(!number){
|
||||||
|
ESBYTE[buf] = '0';
|
||||||
|
ESBYTE[buf+1] = 0;
|
||||||
|
return buf;
|
||||||
|
}
|
||||||
|
ret = buf;
|
||||||
|
if(number<0)
|
||||||
|
{
|
||||||
|
$neg number
|
||||||
|
ESBYTE[buf] = '-';
|
||||||
|
$inc buf
|
||||||
|
}
|
||||||
|
while(mask)
|
||||||
|
{
|
||||||
|
tmp = number / mask;
|
||||||
|
tmp = tmp%10;
|
||||||
|
|
||||||
|
if(cmd){
|
||||||
|
if(tmp){
|
||||||
|
ESBYTE[buf] = tmp + '0';
|
||||||
|
$inc buf
|
||||||
|
cmd = false;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
ESBYTE[buf] = tmp + '0';
|
||||||
|
$inc buf
|
||||||
|
}
|
||||||
|
mask /= 10;
|
||||||
|
}
|
||||||
|
ESBYTE[buf] = 0;
|
||||||
|
return ret;
|
||||||
|
}
|
||||||
|
|
||||||
inline fastcall itoa_(signed int EDI, ESI)
|
inline fastcall itoa_(signed int EDI, ESI)
|
||||||
{
|
{
|
||||||
@ -414,6 +610,14 @@ F3:
|
|||||||
return EBX;
|
return EBX;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
dword strdup(dword text)
|
||||||
|
{
|
||||||
|
dword l = strlen(text);
|
||||||
|
dword ret = malloc(l+1);
|
||||||
|
strncpy(ret,text,l);
|
||||||
|
return ret;
|
||||||
|
}
|
||||||
|
|
||||||
void debugi(dword d_int)
|
void debugi(dword d_int)
|
||||||
{
|
{
|
||||||
char tmpch[12];
|
char tmpch[12];
|
||||||
@ -422,7 +626,7 @@ void debugi(dword d_int)
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
#define strncpy strcpyn
|
//#define strncpy strcpyn
|
||||||
#define strnmov strmovn
|
#define strnmov strmovn
|
||||||
#define stricmp strcmpi
|
#define stricmp strcmpi
|
||||||
#define strcmpn strncmp
|
#define strcmpn strncmp
|
||||||
|
Loading…
Reference in New Issue
Block a user