Subversion Repositories Kolibri OS

Rev

Rev 8826 | Rev 8868 | Go to most recent revision | Details | Compare with Previous | Last modification | View Log | RSS feed

Rev Author Line No. Line
4042 leency 1
 
7878 leency 2
//                                                   //
3
//                   MASS ACTIONS                    //
4
//                                                   //
5
//===================================================//
6
4896 punk_joker 7
 
6646 leency 8
	dword selected_offset = items.get(n)*304 + buf+32 + 7;
7972 leency 9
	ESBYTE[selected_offset] = state;
6602 leency 10
	if (n==0) && (strncmp(items.get(n)*304+buf+72,"..",2)==0) {
7972 leency 11
		ESBYTE[selected_offset] = false; //do not selec ".." directory
7278 leency 12
		return;
13
	}
14
	if (state==true) selected_count++;
6602 leency 15
	if (state==false) selected_count--;
16
	if (selected_count<0) selected_count=0;
7804 leency 17
}
4042 leency 18
19
 
6646 leency 20
	dword selected_offset = items.get(n)*304 + buf+32 + 7;
7972 leency 21
	return ESBYTE[selected_offset];
6646 leency 22
}
23
24
 
7878 leency 25
{
4042 leency 26
	int j;
7878 leency 27
	BDVK file_info_count;
28
	DIR_SIZE paste_dir_size;
29
30
 
31
	if ( file_info_count.isfolder ) {
32
		return paste_dir_size.get(_in_path);
33
	} else {
34
		return 1;
35
	}
36
}
37
38
 
39
//                                                   //
40
//                  COPY AND PASTE                   //
41
//                                                   //
42
//===================================================//
43
byte copy_to[4096];
44
byte copy_from[4096];
45
bool cut_active = false;
46
47
 
8861 leency 48
7878 leency 49
 
8861 leency 50
{
7878 leency 51
	byte copy_t[4096];
6602 leency 52
	dword buff_data;
53
	dword path_len = 0;
6597 punk_joker 54
	dword size_buf = 0;
6602 leency 55
	dword copy_buf_offset = 0;
56
	dword i;
7422 leency 57
6597 punk_joker 58
 
6602 leency 59
7278 leency 60
 
8861 leency 61
7878 leency 62
 
7278 leency 63
	if (!selected_count) {
7878 leency 64
		setElementSelectedFlag(files.cur_y, true);
7278 leency 65
	}
7878 leency 66
7278 leency 67
 
68
69
 
6602 leency 70
	for (i=0; i
71
	{
72
		if (getElementSelectedFlag(i) == true) {
6646 leency 73
			sprintf(#copy_t,"%s/%s",#path,items.get(i)*304+buf+72);
7972 leency 74
			path_len = strlen(#copy_t);
6602 leency 75
			size_buf += path_len + 1;
76
		}
6597 punk_joker 77
	}
78
	size_buf += 20;
6602 leency 79
	buff_data = malloc(size_buf);
80
	ESDWORD[buff_data] = size_buf;
81
	ESDWORD[buff_data+4] = SLOT_DATA_TYPE_RAW;
6791 leency 82
	ESINT[buff_data+8] = selected_count;
6602 leency 83
	copy_buf_offset = buff_data + 10;
84
	for (i=0; i
85
	{
6597 punk_joker 86
		if (getElementSelectedFlag(i) == true) {
6646 leency 87
			sprintf(copy_buf_offset,"%s/%s",#path,items.get(i)*304+buf+72);
7972 leency 88
			copy_buf_offset += strlen(copy_buf_offset) + 1;
6602 leency 89
7998 leency 90
 
91
				if (i>=files.first) && (i
92
					PutShadow(files.x+4,i-files.first*files.item_h+files.y,16,files.item_h,1,-3);
93
			}
94
		}
6602 leency 95
	}
6597 punk_joker 96
	if (cut_active) {
7998 leency 97
		pause(20);
98
		List_ReDraw();
7999 leency 99
	}
7998 leency 100
	if (selected_count==1) setElementSelectedFlag(files.cur_y, false);
6602 leency 101
	Clipboard__SetSlotData(size_buf, buff_data);
7038 leency 102
	free(buff_data);
6597 punk_joker 103
}
104
105
 
6600 punk_joker 106
 
6597 punk_joker 107
{
108
	char copy_rezult;
109
	int j, i, slash_count=0;
8826 leency 110
	int paste_elements_count = 0;
6602 leency 111
	dword buf;
6597 punk_joker 112
	dword path_offset;
6602 leency 113
114
 
7038 leency 115
	if (DSDWORD[buf+4] != 3) return;
5514 leency 116
	paste_elements_count = ESINT[buf+8];
6602 leency 117
	path_offset = buf + 10;
118
7878 leency 119
 
120
		DisplayOperationForm(MOVE_FLAG);
121
	} else {
122
		DisplayOperationForm(COPY_FLAG);
123
	}
124
125
 
8826 leency 126
		for (j = 0; j < paste_elements_count; j++) {
127
			sprintf(#copy_to, "%s/%s", #path, path_offset+strrchr(path_offset,'/'));
128
			slash_count = 0;
129
			for (i=0; i<=10; i++) {
130
				if (copy_to[i]=='/') slash_count++;
131
				if (slash_count==3) break;
132
			}
133
			if (strncmp(#copy_to, path_offset, i)!=0) goto _DIFFERENT_DRIVES;
134
			RenameMove(#copy_to+i, path_offset);
135
			if (EAX!=0) goto _DIFFERENT_DRIVES;
136
			path_offset += strlen(path_offset) + 1;
137
		}
138
		DialogExit();
139
	}
140
141
 
142
	path_offset = buf + 10;
143
	for (j = 0; j < paste_elements_count; j++) {
6602 leency 144
		copy_bar.max += GetFilesCount(path_offset);
7878 leency 145
		path_offset += strlen(path_offset) + 1;
6602 leency 146
	}
5957 punk_joker 147
5804 punk_joker 148
 
6602 leency 149
	for (j = 0; j < paste_elements_count; j++) {
150
		strcpy(#copy_from, path_offset);
151
		if (!copy_from) DialogExit();
5804 punk_joker 152
		sprintf(#copy_to, "%s/%s", #path, #copy_from+strrchr(#copy_from,'/'));
6635 leency 153
		if (streq(#copy_from,#copy_to))
8015 leency 154
		{
5957 punk_joker 155
			if (cut_active) continue;
8015 leency 156
			sprintf(#copy_to, "%s/NEW_%s", #path, #copy_from+strrchr(#copy_from,'/'));
6635 leency 157
		}
5957 punk_joker 158
		if (strstr(#copy_to, #copy_from))
4698 punk_joker 159
		{
160
			notify("'Not possible to copy directory into itself.\nProcess terminated.' -E");
8861 leency 161
			DialogExit();
5804 punk_joker 162
		}
4698 punk_joker 163
5957 punk_joker 164
 
165
		{
166
			Write_Error(copy_rezult);
167
			if (copy_rezult==8) DialogExit(); //not enough space
7491 leency 168
		}
5957 punk_joker 169
		else if (cut_active)
170
		{
171
			strcpy(#file_path, #copy_from);
6597 punk_joker 172
			RecursiveDelete(#copy_from, false);
8861 leency 173
5957 punk_joker 174
 
175
		path_offset += strlen(path_offset) + 1;
6602 leency 176
	}
5931 punk_joker 177
	DialogExit();
178
}
6602 leency 179
6600 punk_joker 180
 
7878 leency 181
 
182
//                                                   //
183
//                     DELETE                        //
184
//                                                   //
185
//===================================================//
186
187
 
188
int RecursiveDelete(dword way, bool show_progress)
8861 leency 189
{
7878 leency 190
	dword dirbuf, fcount, i, filename;
191
	int error;
192
	char del_from[4096];
193
	if (dir_exists(way))
194
	{
195
		if (error = GetDir(#dirbuf, #fcount, way, DIRS_ONLYREAL)) del_error = error;
196
		for (i=0; i
197
		{
198
			//if (CheckEvent()==evReDraw) draw_window();
199
			filename = i*304+dirbuf+72;
200
			sprintf(#del_from,"%s/%s",way,filename);
201
			if ( TestBit(ESDWORD[filename-40], 4) )
202
			{
203
				RecursiveDelete(#del_from, true);
8861 leency 204
			}
7878 leency 205
			else
206
			{
207
				if (show_progress) Operation_Draw_Progress(filename);
8861 leency 208
				if (error = DeleteFile(#del_from)) del_error = error;
7878 leency 209
			}
210
		}
211
	}
212
	if (error = DeleteFile(way)) del_error = error;
213
}
214
215
 
8861 leency 216
{
217
	int j;
218
	int elements_count = 0;
219
	dword buf;
220
	dword path_offset;
221
7878 leency 222
 
223
224
 
8861 leency 225
	Clipboard__DeleteLastSlot();
226
	if (DSDWORD[buf+4] != 3) return;
227
	elements_count = ESINT[buf+8];
228
7878 leency 229
 
8861 leency 230
	for (j = 0; j < elements_count; j++) {
231
		copy_bar.max += GetFilesCount(path_offset);
232
		path_offset += strlen(path_offset) + 1;
233
	}
7878 leency 234
8861 leency 235
 
236
	for (j = 0; j < elements_count; j++) {
237
		RecursiveDelete(path_offset, true);
238
		path_offset += strlen(path_offset) + 1;
239
	}
240
	if (del_error) Write_Error(del_error);
7878 leency 241
	DialogExit();
242
}
8861 leency 243
>