forked from KolibriOS/kolibrios
4b416faa6e
git-svn-id: svn://kolibrios.org@2825 a494cfbc-eb01-0410-851d-a64ba20cac60
189 lines
2.9 KiB
C
189 lines
2.9 KiB
C
//------------------------------------------------------------------------------
|
|
// strlen( EDI)
|
|
// strcpy( EDI, ESI)
|
|
// strcat( EDI, ESI)
|
|
// IntToStr( ESI)
|
|
// StrToInt()
|
|
// strcmp( ESI, EDI)
|
|
// find_symbol( ESI,BL)
|
|
// upcase( ESI)
|
|
// lowcase( ESI)
|
|
// strstr( EBX, EDX)
|
|
//------------------------------------------------------------------------------
|
|
|
|
inline fastcall unsigned int strlen( EDI)
|
|
{
|
|
$xor eax, eax
|
|
$mov ecx, -1
|
|
$REPNE $SCASB
|
|
EAX-=2+ECX;
|
|
}
|
|
|
|
|
|
inline fastcall strcpy( EDI, ESI)
|
|
{
|
|
$cld
|
|
l2:
|
|
$lodsb
|
|
$stosb
|
|
$test al,al
|
|
$jnz l2
|
|
}
|
|
|
|
|
|
inline fastcall strcat( EDI, ESI)
|
|
{
|
|
asm {
|
|
mov ebx, edi
|
|
xor ecx, ecx
|
|
xor eax, eax
|
|
dec ecx
|
|
repne scasb
|
|
dec edi
|
|
mov edx, edi
|
|
mov edi, esi
|
|
xor ecx, ecx
|
|
xor eax, eax
|
|
dec ecx
|
|
repne scasb
|
|
xor ecx, 0ffffffffh
|
|
mov edi, edx
|
|
mov edx, ecx
|
|
mov eax, edi
|
|
shr ecx, 2
|
|
rep movsd
|
|
mov ecx, edx
|
|
and ecx, 3
|
|
rep movsb
|
|
mov eax, ebx
|
|
}
|
|
}
|
|
|
|
char buffer[11]="";
|
|
inline fastcall dword IntToStr( ESI)
|
|
{
|
|
$mov edi, #buffer
|
|
$mov ecx, 10
|
|
$test esi, esi
|
|
$jns f1
|
|
$mov al, '-'
|
|
$stosb
|
|
$neg esi
|
|
f1:
|
|
$mov eax, esi
|
|
$push -'0'
|
|
f2:
|
|
$xor edx, edx
|
|
$div ecx
|
|
$push edx
|
|
$test eax, eax
|
|
$jnz f2
|
|
f3:
|
|
$pop eax
|
|
$add al, '0'
|
|
$stosb
|
|
$jnz f3
|
|
$mov eax, #buffer
|
|
$ret
|
|
}
|
|
|
|
|
|
inline fastcall dword StrToInt()
|
|
{
|
|
ESI=EDI=EAX;
|
|
IF(DSBYTE[ESI]=='-')ESI++;
|
|
EAX=0;
|
|
BH=AL;
|
|
do{
|
|
BL=DSBYTE[ESI]-'0';
|
|
EAX=EAX*10+EBX;
|
|
ESI++;
|
|
}while(DSBYTE[ESI]>0);
|
|
IF(DSBYTE[EDI]=='-') -EAX;
|
|
}
|
|
|
|
|
|
inline fastcall signed int strcmp( ESI, EDI)
|
|
{
|
|
loop()
|
|
{
|
|
IF (DSBYTE[ESI]<DSBYTE[EDI]) RETURN -1;
|
|
IF (DSBYTE[ESI]>DSBYTE[EDI]) RETURN 1;
|
|
IF (DSBYTE[ESI]=='\0') RETURN 0;
|
|
ESI++;
|
|
EDI++;
|
|
}
|
|
}
|
|
|
|
inline fastcall unsigned int find_symbol( ESI,BL)
|
|
{
|
|
int jj=0, last=-1;
|
|
do{
|
|
jj++;
|
|
$lodsb
|
|
IF(AL==BL) last=jj;
|
|
} while(AL!=0);
|
|
return last;
|
|
}
|
|
|
|
|
|
inline fastcall upcase( ESI)
|
|
{
|
|
do{
|
|
AL=DSBYTE[ESI];
|
|
IF(AL>='a')IF(AL<='z')DSBYTE[ESI]=AL&0x5f;
|
|
ESI++;
|
|
}while(AL!=0);
|
|
}
|
|
|
|
inline fastcall lowcase( ESI)
|
|
{
|
|
do{
|
|
$LODSB
|
|
IF(AL>='A')&&(AL<='Z'){
|
|
AL+=0x20;
|
|
DSBYTE[ESI-1]=AL;
|
|
CONTINUE;
|
|
}
|
|
}while(AL!=0);
|
|
}
|
|
|
|
|
|
inline fastcall unsigned int strstr( EBX, EDX)
|
|
{
|
|
asm {
|
|
mov edi, edx
|
|
xor ecx, ecx
|
|
xor eax, eax
|
|
dec ecx
|
|
repne scasb
|
|
not ecx
|
|
dec ecx
|
|
je ls2
|
|
mov esi, ecx
|
|
xor ecx, ecx
|
|
mov edi, ebx
|
|
dec ecx
|
|
repne scasb
|
|
not ecx
|
|
sub ecx, esi
|
|
jbe ls2
|
|
mov edi, ebx
|
|
lea ebx, dsdword[ esi-1]
|
|
ls1: mov esi, edx
|
|
lodsb
|
|
repne scasb
|
|
jne ls2
|
|
mov eax, ecx
|
|
push edi
|
|
mov ecx, ebx
|
|
repe cmpsb
|
|
pop edi
|
|
mov ecx, eax
|
|
jne ls1
|
|
lea eax, dsdword[ edi-1]
|
|
jmp short ls3
|
|
ls2: xor eax, eax
|
|
ls3:
|
|
}
|
|
} |