Subversion Repositories Kolibri OS

Rev

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