Subversion Repositories Kolibri OS

Rev

Rev 5962 | 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 Copy(dword pcth, char cut)
  11. {
  12.     dword selected_offset2;
  13.     byte copy_t[4096];
  14.     dword buff_data;
  15.     dword path_len = 0;
  16.     dword buffer_len = 0;
  17.     dword size_buf = 0;
  18.     int ind = 0;
  19.     if (selected_count)
  20.         {
  21.         for (i=0; i<files.count; i++)
  22.         {
  23.             selected_offset2 = file_mas[i]*304 + buf+32 + 7;
  24.             if (ESBYTE[selected_offset2]) {
  25.                 strcpy(#copy_t, #path);
  26.                 strcat(#copy_t, file_mas[i]*304+buf+72);
  27.                 path_len = strlen(#copy_t);
  28.                 size_buf = size_buf + path_len;
  29.             }
  30.         }
  31.        
  32.         buff_data = malloc(size_buf);
  33.         ESDWORD[buff_data] = size_buf;
  34.         ESDWORD[buff_data+4] = 3;
  35.         ESINT[buff_data+8] = selected_count;    
  36.        
  37.         for (i=0; i<files.count; i++)
  38.         {
  39.             selected_offset2 = file_mas[i]*304 + buf+32 + 7;
  40.             if (ESBYTE[selected_offset2]) {
  41.                 strcpy(#copy_t, #path);
  42.                 strcat(#copy_t, file_mas[i]*304+buf+72);
  43.                 path_len = strlen(#copy_t);
  44.                 strlcpy(buff_data+10+buffer_len+1, #copy_t, path_len);
  45.                 buffer_len = buffer_len + path_len;
  46.                 ind++;
  47.             }
  48.         }
  49.                 clipboard.SetSlotData(size_buf+10, buff_data);
  50.         }
  51.         else
  52.         {
  53.                 buff_data = malloc(4106);
  54.         ESDWORD[buff_data] = 4106;
  55.         ESDWORD[buff_data+4] = 3;
  56.         ESINT[buff_data+8] = 1;
  57.         strlcpy(buff_data+10, #file_path, 4096);;
  58.                 clipboard.SetSlotData(4106, buff_data);
  59.         }
  60.         cut_active = cut;
  61.         free(buff_data);
  62. }
  63.  
  64.  
  65. void Paste() {
  66.         copy_stak = malloc(64000);
  67.         CreateThread(#PasteThread,copy_stak+64000-4);
  68. }
  69.  
  70. void PasteThread()
  71. {
  72.         char copy_rezult;
  73.         int j;
  74.         int cnt = 0;
  75.         dword buf;
  76.         dword path_len = 0;
  77.     dword buffer_len = 0;
  78.     file_count_copy = 0;
  79.         copy_bar.value = 0;
  80.    
  81.     buf = clipboard.GetSlotData(clipboard.GetSlotCount()-1);
  82.         if (DSDWORD[buf+4] != 3) return;
  83.         cnt = ESINT[buf+8];
  84.         for (j = 0; j < cnt; j++) {
  85.                 if (j==0) strlcpy(#copy_from, buf+10+buffer_len);
  86.                 else strlcpy(#copy_from, buf+10+buffer_len+1);
  87.                 buffer_len = buffer_len + path_len;
  88.                 GetFileInfo(#copy_from, #file_info_count);
  89.                 if ( file_info_count.isfolder ) DirFileCount(#copy_from);
  90.                 else file_count_copy++;
  91.         }
  92.         copy_bar.max = file_count_copy;
  93.        
  94.         if (cut_active)  operation_flag = MOVE_FLAG;
  95.         else  operation_flag = COPY_FLAG;
  96.        
  97.         path_len = 0;
  98.     buffer_len = 0;
  99.     DisplayOperationForm();
  100.         for (j = 0; j < cnt; j++) {
  101.                 if (j==0) strlcpy(#copy_from, buf+10+buffer_len);
  102.                 else strlcpy(#copy_from, buf+10+buffer_len+1);
  103.                 path_len = strlen(#copy_from);
  104.                 buffer_len = buffer_len + path_len;
  105.                 if (!copy_from) DialogExit();
  106.                 strcpy(#copy_to, #path);
  107.                 strcat(#copy_to, #copy_from+strrchr(#copy_from,'/'));
  108.                 if (!strcmp(#copy_from,#copy_to))
  109.                 {
  110.                         strcpy(#copy_to, #path);
  111.                         strcat(#copy_to, "new_");
  112.                         strcat(#copy_to, #copy_from+strrchr(#copy_from,'/'));
  113.                 }
  114.                 if (strstr(#copy_to, #copy_from))
  115.                 {
  116.                         notify("Copy directory into itself is a bad idea...");
  117.                         DialogExit();
  118.                 }
  119.  
  120.                 if (copy_rezult = copyf(#copy_from,#copy_to))
  121.                 {
  122.                         Write_Error(copy_rezult);
  123.                 }
  124.                 else if (cut_active)
  125.                 {
  126.                         strcpy(#file_path, #copy_from);
  127.                         Del_File2(#copy_from, 0);
  128.                        
  129.                 }
  130.         }
  131.         if (cut_active)
  132.         {
  133.                 cut_active=false;
  134.         }
  135.         if (info_after_copy) notify(INFO_AFTER_COPY);
  136.         DialogExit();
  137. }
  138.  
  139. //Another version of the function copy/paste
  140.  
  141. /*
  142. void Copy(dword pcth, char cut)
  143. {
  144.     dword selected_offset2;
  145.     byte copy_t[4096];
  146.     dword buff_data;
  147.     dword path_len = 0;
  148.     dword buffer_len = 0;
  149.     dword size_buf = 0;
  150.     int ind = 0;
  151.     if (selected_count)
  152.         {
  153.         for (i=0; i<files.count; i++)
  154.         {
  155.             selected_offset2 = file_mas[i]*304 + buf+32 + 7;
  156.             if (ESBYTE[selected_offset2]) {
  157.                 strcpy(#copy_t, #path);
  158.                 strcat(#copy_t, file_mas[i]*304+buf+72);
  159.                 path_len = strlen(#copy_t);
  160.                 size_buf = size_buf + path_len + 4;
  161.             }
  162.         }
  163.        
  164.         buff_data = malloc(size_buf);
  165.         ESDWORD[buff_data] = size_buf;
  166.         ESDWORD[buff_data+4] = 3;
  167.         ESINT[buff_data+8] = selected_count;    
  168.        
  169.         for (i=0; i<files.count; i++)
  170.         {
  171.             selected_offset2 = file_mas[i]*304 + buf+32 + 7;
  172.             if (ESBYTE[selected_offset2]) {
  173.                 strcpy(#copy_t, #path);
  174.                 strcat(#copy_t, file_mas[i]*304+buf+72);
  175.                 path_len = strlen(#copy_t);
  176.                 ESDWORD[buff_data+10+buffer_len] = path_len;
  177.                 strlcpy(buff_data+10+4+buffer_len, #copy_t, path_len);
  178.                 buffer_len = buffer_len + 4 + path_len;
  179.                 ind++;
  180.             }
  181.         }
  182.                 clipboard.SetSlotData(size_buf+10, buff_data);
  183.         }
  184.         else
  185.         {
  186.                 buff_data = malloc(4106);
  187.         ESDWORD[buff_data] = 4106;
  188.         ESDWORD[buff_data+4] = 3;
  189.         ESINT[buff_data+8] = 1;
  190.         strlcpy(buff_data+10, #file_path, 4096);;
  191.                 clipboard.SetSlotData(4106, buff_data);
  192.         }
  193.         cut_active = cut;
  194.         free(buff_data);
  195. }
  196.  
  197.  
  198. void PasteThread()
  199. {
  200.         char copy_rezult;
  201.         int j;
  202.         int cnt = 0;
  203.         dword buf;
  204.         dword path_len = 0;
  205.     dword buffer_len = 0;
  206.     file_count_copy = 0;
  207.         copy_bar.value = 0;
  208.    
  209.     buf = clipboard.GetSlotData(clipboard.GetSlotCount()-1);
  210.         if (DSDWORD[buf+4] != 3) return;
  211.         cnt = ESINT[buf+8];
  212.         for (j = 0; j < cnt; j++) {
  213.                 path_len = ESDWORD[buf+10+buffer_len];
  214.                 strlcpy(#copy_from, buf+10+buffer_len+4, path_len);
  215.                 buffer_len = buffer_len + 4 + path_len;
  216.                 GetFileInfo(#copy_from, #file_info_count);
  217.                 if ( file_info_count.isfolder ) DirFileCount(#copy_from);
  218.                 else file_count_copy++;
  219.         }
  220.         copy_bar.max = file_count_copy;
  221.        
  222.         if (cut_active)  operation_flag = MOVE_FLAG;
  223.         else  operation_flag = COPY_FLAG;
  224.        
  225.         path_len = 0;
  226.     buffer_len = 0;
  227.     DisplayOperationForm();
  228.         for (j = 0; j < cnt; j++) {
  229.                 path_len = ESDWORD[buf+10+buffer_len];
  230.                 strlcpy(#copy_from, buf+10+buffer_len+4, path_len);
  231.                 buffer_len = buffer_len + 4 + path_len;
  232.                 if (!copy_from) DialogExit();
  233.                 strcpy(#copy_to, #path);
  234.                 strcat(#copy_to, #copy_from+strrchr(#copy_from,'/'));
  235.                 if (!strcmp(#copy_from,#copy_to))
  236.                 {
  237.                         strcpy(#copy_to, #path);
  238.                         strcat(#copy_to, "new_");
  239.                         strcat(#copy_to, #copy_from+strrchr(#copy_from,'/'));
  240.                 }
  241.                 if (strstr(#copy_to, #copy_from))
  242.                 {
  243.                         notify("Copy directory into itself is a bad idea...");
  244.                         DialogExit();
  245.                 }
  246.  
  247.                 if (copy_rezult = copyf(#copy_from,#copy_to))
  248.                 {
  249.                         Write_Error(copy_rezult);
  250.                 }
  251.                 else if (cut_active)
  252.                 {
  253.                         strcpy(#file_path, #copy_from);
  254.                         Del_File2(#copy_from, 0);
  255.                        
  256.                 }
  257.         }
  258.         if (cut_active)
  259.         {
  260.                 cut_active=false;
  261.         }
  262.         if (info_after_copy) notify(INFO_AFTER_COPY);
  263.         DialogExit();
  264. }
  265. */
  266.