Subversion Repositories Kolibri OS

Rev

Rev 7491 | Go to most recent revision | Blame | Last modification | View Log | Download | RSS feed

  1.  
  2. byte copy_to[4096];
  3. byte copy_from[4096];
  4. byte cut_active=0;
  5.  
  6. enum {NOCUT, CUT};
  7.  
  8. void setElementSelectedFlag(dword n, int state) {
  9.         dword selected_offset = file_mas[n]*304 + buf+32 + 7;
  10.         ESBYTE[selected_offset] = state;
  11.         if (n==0) && (strncmp(file_mas[n]*304+buf+72,"..",2)==0) {
  12.                 ESBYTE[selected_offset] = false; //do not selec ".." directory
  13.                 return;
  14.         }
  15.         if (state==true) selected_count++;
  16.         if (state==false) selected_count--;
  17.         if (selected_count<0) selected_count=0;
  18. }
  19.  
  20. int getElementSelectedFlag(dword n) {
  21.         dword selected_offset = file_mas[n]*304 + buf+32 + 7;
  22.         return ESBYTE[selected_offset];
  23. }
  24.  
  25. void Copy(dword pcth, char cut)
  26. {
  27.         byte copy_t[4096];
  28.         dword buff_data;
  29.         dword path_len = 0;
  30.         dword size_buf = 0;
  31.         dword copy_buf_offset = 0;
  32.         dword i;
  33.  
  34.         if (files.count<=0) return; //no files
  35.  
  36.         //if no element selected by "Insert" key, then we copy current element
  37.         if (!selected_count)
  38.                 setElementSelectedFlag(files.cur_y, true);
  39.  
  40.         if (!selected_count) return;
  41.        
  42.         size_buf = 4;
  43.         for (i=0; i<files.count; i++)
  44.         {
  45.                 if (getElementSelectedFlag(i) == true) {
  46.                         sprintf(#copy_t,"%s/%s",#path,file_mas[i]*304+buf+72);
  47.                         path_len = strlen(#copy_t);
  48.                         size_buf += path_len + 1;
  49.                 }
  50.         }
  51.         size_buf += 20;
  52.         buff_data = malloc(size_buf);
  53.         ESDWORD[buff_data] = size_buf;
  54.         ESDWORD[buff_data+4] = SLOT_DATA_TYPE_RAW;
  55.         ESINT[buff_data+8] = selected_count;
  56.         copy_buf_offset = buff_data + 10;
  57.         for (i=0; i<files.count; i++)
  58.         {
  59.                 if (getElementSelectedFlag(i) == true) {
  60.                         sprintf(copy_buf_offset,"%s/%s",#path,file_mas[i]*304+buf+72);
  61.                         copy_buf_offset += strlen(copy_buf_offset) + 1;
  62.                 }
  63.         }
  64.         if (selected_count==1) setElementSelectedFlag(files.cur_y, false);
  65.         Clipboard__SetSlotData(size_buf, buff_data);
  66.         cut_active = cut;
  67.         free(buff_data);
  68. }
  69.  
  70. void Paste() {
  71.         copy_stak = free(copy_stak);
  72.         copy_stak = malloc(64000);
  73.         CreateThread(#PasteThread,copy_stak+64000-4);
  74. }
  75.  
  76. void PasteThread()
  77. {
  78.         char copy_rezult;
  79.         int j;
  80.         int paste_elements_count = 0;
  81.         dword buf;
  82.         dword path_offset;
  83.         dword file_count_paste = 0;
  84.         _dir_size paste_dir_size;
  85.         BDVK file_info_count;
  86.  
  87.         copy_bar.value = 0;
  88.        
  89.         buf = Clipboard__GetSlotData(Clipboard__GetSlotCount()-1);
  90.         if (DSDWORD[buf+4] != 3) return;
  91.         paste_elements_count = ESINT[buf+8];
  92.         path_offset = buf + 10;
  93.         //calculate copy files count for progress bar
  94.         for (j = 0; j < paste_elements_count; j++) {
  95.                 GetFileInfo(path_offset, #file_info_count);
  96.                 if ( file_info_count.isfolder ) {
  97.                         paste_dir_size.get(path_offset);
  98.                         file_count_paste += paste_dir_size.files;
  99.                 }
  100.                 else file_count_paste++;
  101.                 path_offset += strlen(path_offset) + 1;
  102.         }
  103.         copy_bar.max = file_count_paste;
  104.        
  105.         if (cut_active)  operation_flag = MOVE_FLAG;
  106.         else  operation_flag = COPY_FLAG;
  107.        
  108.         path_offset = buf + 10;
  109.         DisplayOperationForm();
  110.         for (j = 0; j < paste_elements_count; j++) {
  111.                 strcpy(#copy_from, path_offset);
  112.                 if (!copy_from) DialogExit();
  113.                 sprintf(#copy_to, "%s/%s", #path, #copy_from+strrchr(#copy_from,'/'));
  114.                 if (!strcmp(#copy_from,#copy_to))
  115.                 {
  116.                         sprintf(#copy_to, "%s/NEW_%s", #path, #copy_from+strrchr(#copy_from,'/'));
  117.                 }
  118.                 if (strstr(#copy_to, #copy_from))
  119.                 {
  120.                         notify("Copy directory into itself is a bad idea...");
  121.                         DialogExit();
  122.                 }
  123.  
  124.                 if (copy_rezult = copyf(#copy_from,#copy_to))
  125.                 {
  126.                         Write_Error(copy_rezult);
  127.                         if (copy_rezult==8) DialogExit(); //not enough space
  128.                 }
  129.                 else if (cut_active)
  130.                 {
  131.                         strcpy(#file_path, #copy_from);
  132.                         Del_File2(#copy_from, 0);
  133.                        
  134.                 }
  135.                 path_offset += strlen(path_offset) + 1;
  136.         }
  137.         cut_active=false;
  138.         if (info_after_copy.checked) notify(INFO_AFTER_COPY);
  139.         DialogExit();
  140. }
  141.  
  142.