Subversion Repositories Kolibri OS

Rev

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