Subversion Repositories Kolibri OS

Rev

Rev 5689 | 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. progress_bar copy_bar = {0,16,49,50,20,0,0,1,0xFFFFFF,0x00FF00,0x000000};
  7.  
  8. enum {NOCUT, CUT, COPY_PASTE_END};
  9.  
  10. Clipboard clipboard;
  11.  
  12. void Copy(dword pcth, char cut)
  13. {
  14.     dword selected_offset2;
  15.     byte copy_t[4096];
  16.     dword buff_data;
  17.     int ind = 0;
  18.     if (selected_count)
  19.         {
  20.         buff_data = malloc(selected_count*4096+10);
  21.         ESDWORD[buff_data] = selected_count*4096+10;
  22.         ESDWORD[buff_data+4] = 3;
  23.         ESINT[buff_data+8] = selected_count;
  24.         for (i=0; i<files.count; i++)
  25.         {
  26.             selected_offset2 = file_mas[i]*304 + buf+32 + 7;
  27.             if (ESBYTE[selected_offset2]) {
  28.                 strcpy(#copy_t, #path);
  29.                 strcat(#copy_t, file_mas[i]*304+buf+72);                        
  30.                 strlcpy(ind*4096+buff_data+10, #copy_t, 4096);;
  31.                 ind++;
  32.             }
  33.         }
  34.                 clipboard.SetSlotData(selected_count*4096+10, buff_data);
  35.         }
  36.         else
  37.         {
  38.                 buff_data = malloc(4106);
  39.         ESDWORD[buff_data] = 4106;
  40.         ESDWORD[buff_data+4] = 3;
  41.         ESINT[buff_data+8] = 1;
  42.         strlcpy(buff_data+10, #file_path, 4096);;
  43.                 clipboard.SetSlotData(4106, buff_data);
  44.         }
  45.         cut_active = cut;
  46.         free(buff_data);
  47. }
  48.  
  49.  
  50. void Paste() {
  51.         copy_stak = malloc(20000);
  52.         CreateThread(#PasteThread,copy_stak+20000-4);
  53. }
  54.  
  55. BDVK file_info_count;
  56. int file_count_copy;
  57.  
  58. void DirFileCount(dword way)
  59. {
  60.         dword dirbuf, fcount, i, filename;
  61.         dword cur_file;
  62.         if (isdir(way))
  63.         {
  64.                 cur_file = malloc(4096);
  65.                 // In the process of recursive descent, memory must be allocated dynamically, because the static memory -> was a bug !!! But unfortunately pass away to sacrifice speed.
  66.                 GetDir(#dirbuf, #fcount, way, DIRS_ONLYREAL);
  67.                 for (i=0; i<fcount; i++)
  68.                 {
  69.                         filename = i*304+dirbuf+72;
  70.                         sprintf(cur_file,"%s/%s",way,filename);
  71.                        
  72.                         if (TestBit(ESDWORD[filename-40], 4) )
  73.                         {
  74.                                 file_count_copy++;
  75.                                 DirFileCount(cur_file);
  76.                         }
  77.                         else
  78.                         {
  79.                                 file_count_copy++;
  80.                         }
  81.                 }
  82.                 free(cur_file);
  83.         }
  84. }
  85.  
  86. void PasteThread()
  87. {
  88.         char copy_rezult;
  89.         int j;
  90.         int cnt = 0;
  91.         dword buf;
  92.         file_count_copy = 0;
  93.         copy_bar.value = 0;
  94.        
  95.         buf = clipboard.GetSlotData(clipboard.GetSlotCount()-1);
  96.         if (DSDWORD[buf+4] != 3) return;
  97.         cnt = ESINT[buf+8];
  98.         for (j = 0; j < cnt; j++) {
  99.                 strlcpy(#copy_from, j*4096+buf+10, 4096);
  100.                 GetFileInfo(#copy_from, #file_info_count);
  101.                 if ( file_info_count.isfolder ) DirFileCount(#copy_from);
  102.                 else file_count_copy++;
  103.         }
  104.         copy_bar.max = file_count_copy;
  105.         DisplayCopyfForm();
  106.         for (j = 0; j < cnt; j++) {
  107.                 strlcpy(#copy_from, j*4096+buf+10, 4096);
  108.                 if (!copy_from) CopyExit();
  109.                 strcpy(#copy_to, #path);
  110.                 strcat(#copy_to, #copy_from+strrchr(#copy_from,'/'));
  111.                 if (!strcmp(#copy_from,#copy_to))
  112.                 {
  113.                         strcpy(#copy_to, #path);
  114.                         strcat(#copy_to, "new_");
  115.                         strcat(#copy_to, #copy_from+strrchr(#copy_from,'/'));
  116.                 }
  117.                 if (strstr(#copy_to, #copy_from))
  118.                 {
  119.                         notify("Copy directory into itself is a bad idea...");
  120.                         CopyExit();
  121.                 }
  122.  
  123.                 if (copy_rezult = copyf(#copy_from,#copy_to))
  124.                 {
  125.                         Write_Error(copy_rezult);
  126.                 }
  127.                 else if (cut_active)
  128.                 {
  129.                         strcpy(#file_path, #copy_from);
  130.                         Del_File(true);
  131.                        
  132.                 }
  133.         }
  134.         if (cut_active)
  135.         {
  136.                 cut_active=false;
  137.         }
  138.         if (info_after_copy) notify(INFO_AFTER_COPY);
  139.         CopyExit();
  140. }
  141.  
  142. #define WIN_COPY_W 345
  143. #define WIN_COPY_H 110
  144. proc_info Copy_Form;
  145.  
  146. void DisplayCopyfForm()
  147. {
  148.           switch(CheckEvent())
  149.           {
  150.                  case evButton:
  151.                         notify(T_CANCEL_PASTE);
  152.                         CopyExit();
  153.                         break;
  154.                  
  155.                 case evReDraw:
  156.                         DefineAndDrawWindow(Form.left+Form.width-200,Form.top+90,WIN_COPY_W,GetSkinHeight()+WIN_COPY_H,0x34,0xFFFFFF,T_PASTE_WINDOW_TITLE);
  157.                         GetProcessInfo(#Copy_Form, SelfInfo);
  158.                         WriteText(45, 11, 0x80, system.color.work_text, T_PASTE_WINDOW_TEXT);
  159.                         DrawFlatButton(Copy_Form.cwidth - 96, Copy_Form.cheight - 32, 80, 22, 10, system.color.work_button, T_PASTE_WINDOW_BUTTON);
  160.                         DrawBar(8, 10, 32, 32, 0xFFFfff);
  161.                         break;
  162.           }
  163. }
  164.  
  165. void CopyExit() {
  166.         action_buf = COPY_PASTE_END;
  167.         ActivateWindow(GetProcessSlot(Form.ID));
  168.         ExitProcess();
  169. }
  170.  
  171.  
  172. void copyf_Draw_Progress(dword copying_filename) {
  173.         if (Copy_Form.cwidth==0)
  174.         {
  175.                 copy_bar.value++;
  176.                 return;
  177.         }
  178.         copy_bar.width = Copy_Form.cwidth-32;
  179.         DisplayCopyfForm();
  180.         Put_icon(copying_filename+strrchr(copying_filename,'.'), 16, 19, 0xFFFfff, 0);
  181.         DrawBar(45, 29, Copy_Form.cwidth-45, 10, 0xFFFFFF);
  182.         WriteText(45, 29, 0x80, 0x000000, copying_filename);
  183.         progressbar_draw stdcall (#copy_bar);
  184.         progressbar_progress stdcall (#copy_bar);
  185.         //copy_bar.value++;
  186.         pause(100);
  187. }