Subversion Repositories Kolibri OS

Rev

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