Subversion Repositories Kolibri OS

Rev

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