Subversion Repositories Kolibri OS

Rev

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