forked from KolibriOS/kolibrios
Eolite 2.4: fix copy one file; other small fix
git-svn-id: svn://kolibrios.org@5209 a494cfbc-eb01-0410-851d-a64ba20cac60
This commit is contained in:
parent
0feb6fbe0b
commit
27b5fdd406
@ -83,8 +83,8 @@
|
|||||||
|
|
||||||
enum {ONLY_SHOW, WITH_REDRAW, ONLY_OPEN}; //OpenDir
|
enum {ONLY_SHOW, WITH_REDRAW, ONLY_OPEN}; //OpenDir
|
||||||
|
|
||||||
#define TITLE "Eolite File Manager v2.39"
|
#define TITLE "Eolite File Manager v2.4"
|
||||||
#define ABOUT_TITLE "Eolite v2.39"
|
#define ABOUT_TITLE "Eolite v2.4"
|
||||||
dword col_padding, col_selec, col_lpanel;
|
dword col_padding, col_selec, col_lpanel;
|
||||||
|
|
||||||
int toolbar_buttons_x[7]={9,46,85,134,167,203};
|
int toolbar_buttons_x[7]={9,46,85,134,167,203};
|
||||||
|
@ -20,23 +20,36 @@ void Copy(dword pcth, char cut)
|
|||||||
selected_offset2 = file_mas[i]*304 + buf+32 + 7;
|
selected_offset2 = file_mas[i]*304 + buf+32 + 7;
|
||||||
if (ESBYTE[selected_offset2]) cont++;
|
if (ESBYTE[selected_offset2]) cont++;
|
||||||
}
|
}
|
||||||
buff_data = malloc(cont*4096+10);
|
if (!cont)
|
||||||
ESDWORD[buff_data] = cont*4096+10;
|
{
|
||||||
ESDWORD[buff_data+4] = 3;
|
buff_data = malloc(4106);
|
||||||
ESINT[buff_data+8] = cont;
|
ESDWORD[buff_data] = 4106;
|
||||||
for (i=0; i<files.count; i++)
|
ESDWORD[buff_data+4] = 3;
|
||||||
{
|
ESINT[buff_data+8] = 1;
|
||||||
selected_offset2 = file_mas[i]*304 + buf+32 + 7;
|
strlcpy(buff_data+10, #file_path, 4096);;
|
||||||
if (ESBYTE[selected_offset2]) {
|
clipboard.SetSlotData(4106, buff_data);
|
||||||
strcpy(#copy_t, #path);
|
}
|
||||||
strcat(#copy_t, file_mas[i]*304+buf+72);
|
else
|
||||||
|
{
|
||||||
|
buff_data = malloc(cont*4096+10);
|
||||||
|
ESDWORD[buff_data] = cont*4096+10;
|
||||||
|
ESDWORD[buff_data+4] = 3;
|
||||||
|
ESINT[buff_data+8] = cont;
|
||||||
|
for (i=0; i<files.count; i++)
|
||||||
|
{
|
||||||
|
selected_offset2 = file_mas[i]*304 + buf+32 + 7;
|
||||||
|
if (ESBYTE[selected_offset2]) {
|
||||||
|
strcpy(#copy_t, #path);
|
||||||
|
strcat(#copy_t, file_mas[i]*304+buf+72);
|
||||||
|
|
||||||
strlcpy(ind*4096+buff_data+10, #copy_t, 4096);
|
strlcpy(ind*4096+buff_data+10, #copy_t, 4096);;
|
||||||
ind++;
|
ind++;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
clipboard.SetSlotData(cont*4096+10, buff_data);
|
clipboard.SetSlotData(cont*4096+10, buff_data);
|
||||||
|
}
|
||||||
cut_active = cut;
|
cut_active = cut;
|
||||||
|
free(buff_data);
|
||||||
}
|
}
|
||||||
|
|
||||||
void copyf_Draw_Progress(dword filename) {
|
void copyf_Draw_Progress(dword filename) {
|
||||||
@ -58,14 +71,16 @@ void Paste()
|
|||||||
char copy_rezult;
|
char copy_rezult;
|
||||||
byte copy_from[4096];
|
byte copy_from[4096];
|
||||||
int j;
|
int j;
|
||||||
int cnt = 0;
|
int cnt = 0;
|
||||||
dword buf;
|
dword buf;
|
||||||
|
|
||||||
buf = clipboard.GetSlotData(clipboard.GetSlotCount()-1);
|
buf = clipboard.GetSlotData(clipboard.GetSlotCount()-1);
|
||||||
if (DSDWORD[buf+4] != 3) return;
|
if (DSDWORD[buf+4] != 3) return;
|
||||||
cnt = ESINT[buf+8];
|
cnt = ESINT[buf+8];
|
||||||
for (j = 0; j < cnt; j++) {
|
for (j = 0; j < cnt; j++) {
|
||||||
|
debugi(j);
|
||||||
strlcpy(#copy_from, j*4096+buf+10, 4096);
|
strlcpy(#copy_from, j*4096+buf+10, 4096);
|
||||||
|
debugln(#copy_from);
|
||||||
if (!copy_from) CopyExit();
|
if (!copy_from) CopyExit();
|
||||||
strcpy(#copy_to, #path);
|
strcpy(#copy_to, #path);
|
||||||
strcat(#copy_to, #copy_from+strrchr(#copy_from,'/'));
|
strcat(#copy_to, #copy_from+strrchr(#copy_from,'/'));
|
||||||
@ -96,7 +111,6 @@ void Paste()
|
|||||||
{
|
{
|
||||||
cut_active=false;
|
cut_active=false;
|
||||||
}
|
}
|
||||||
//mark_default();
|
|
||||||
CopyExit();
|
CopyExit();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user