Subversion Repositories Kolibri OS

Rev

Rev 5631 | Rev 7422 | Go to most recent revision | Only display areas with differences | Regard whitespace | Details | Blame | Last modification | View Log | RSS feed

Rev 5631 Rev 7278
1
//Áûñòðàÿ ñîðòèðîâêà. Leency 2008.
-
 
2
 
1
void Sort_by_Size(int a, b)   // äëÿ ïåðâîãî âûçîâà: a = 0, b = <ýëåìåíòîâ â ìàññèâå> - 1
3
void Sort_by_Size(int a, b)   // äëÿ ïåðâîãî âûçîâà: a = 0, b = <ýëåìåíòîâ â ìàññèâå> - 1
2
{                                        
4
{                                        
3
	int iss = a;
5
	int iss = a;
4
	if (a >= b) return;
6
	if (a >= b) return;
5
	for (j = a; j <= b; j++)
7
	for (j = a; j <= b; j++)
6
		if (ESDWORD[file_mas[j]*304 + buf+64] <= ESDWORD[file_mas[b]*304 + buf+64])	{ file_mas[iss] >< file_mas[j];   iss++;}
8
		if (ESDWORD[file_mas[j]*304 + buf+64] <= ESDWORD[file_mas[b]*304 + buf+64])	{ file_mas[iss] >< file_mas[j];   iss++;}
7
	Sort_by_Size (a, iss-2);
9
	Sort_by_Size (a, iss-2);
8
	Sort_by_Size (iss, b);
10
	Sort_by_Size (iss, b);
9
}
11
}
10
 
12
 
11
 
13
 
12
void Sort_by_Name(int a, b)   // äëÿ ïåðâîãî âûçîâà: a = 0, b = <ýëåìåíòîâ â ìàññèâå> - 1
14
void Sort_by_Name(int a, b)   // äëÿ ïåðâîãî âûçîâà: a = 0, b = <ýëåìåíòîâ â ìàññèâå> - 1
13
{                                        
15
{                                        
14
	int isn = a;
16
	int isn = a;
15
	if (a >= b) return;
17
	if (a >= b) return;
16
	for (j = a; j <= b; j++)
18
	for (j = a; j <= b; j++)
17
		if (strcmp(file_mas[j]*304 + buf+72, file_mas[b]*304 + buf+72)<=0) { file_mas[isn] >< file_mas[j];   isn++;}
19
		if (strcmp(file_mas[j]*304 + buf+72, file_mas[b]*304 + buf+72)<=0) { file_mas[isn] >< file_mas[j];   isn++;}
18
	Sort_by_Name(a, isn-2);
20
	Sort_by_Name(a, isn-2);
19
	Sort_by_Name(isn, b);
21
	Sort_by_Name(isn, b);
20
}
22
}
21
 
23
 
22
	
24
	
23
void Sort_by_Type(int a, b)   // äëÿ ïåðâîãî âûçîâà: a = 0, b = <ýëåìåíòîâ â ìàññèâå> - 1
25
void Sort_by_Type(int a, b)   // äëÿ ïåðâîãî âûçîâà: a = 0, b = <ýëåìåíòîâ â ìàññèâå> - 1
24
{               
26
{               
25
	dword filename1, filename2, ext1, ext2;
27
	dword filename1, filename2, ext1, ext2;
26
	int n, isn = a;
28
	int n, isn = a;
27
	if (a >= b) return;
29
	if (a >= b) return;
28
	for (j = a; j <= b; j++)
30
	for (j = a; j <= b; j++)
29
	{
31
	{
30
		filename1 = file_mas[j]*304 + buf+72;
32
		filename1 = file_mas[j]*304 + buf+72;
31
		filename2 = file_mas[b]*304 + buf+72;
33
		filename2 = file_mas[b]*304 + buf+72;
32
 
34
 
33
		n=strlen(filename1)-1;
35
		n=strlen(filename1)-1;
34
		WHILE (n>0) && (ESBYTE[filename1+n]!='.') n--;
36
		WHILE (n>0) && (ESBYTE[filename1+n]!='.') n--;
35
		if (n) ext1 = filename1+n+1; else ext1=0;
37
		if (n) ext1 = filename1+n+1; else ext1=0;
36
		n=strlen(filename2);
38
		n=strlen(filename2);
37
		n--;
39
		n--;
38
		WHILE (n>0) && (ESBYTE[filename2+n]!='.') n--;
40
		WHILE (n>0) && (ESBYTE[filename2+n]!='.') n--;
39
		if (n) ext2 = filename2+n+1; else ext2=0;
41
		if (n) ext2 = filename2+n+1; else ext2=0;
40
 
42
 
41
		n=strcmp(ext1, ext2);
43
		n=strcmp(ext1, ext2);
42
		if (n<0) { file_mas[isn] >< file_mas[j];   isn++;} 
44
		if (n<0) { file_mas[isn] >< file_mas[j];   isn++;} 
43
		if (!n) && (strcmp(filename1, filename2)<=0) { file_mas[isn] >< file_mas[j];   isn++;}
45
		if (!n) && (strcmp(filename1, filename2)<=0) { file_mas[isn] >< file_mas[j];   isn++;}
44
	}
46
	}
45
	Sort_by_Type(a, isn-2);
47
	Sort_by_Type(a, isn-2);
46
	Sort_by_Type(isn, b);
48
	Sort_by_Type(isn, b);
47
}
49
}
-