Subversion Repositories Kolibri OS

Rev

Rev 6041 | Rev 6058 | Go to most recent revision | Blame | Compare with Previous | Last modification | View Log | Download | RSS feed

  1. //CODED by Veliant, Leency, Nable, Pavelyakov. GNU GPL licence.
  2.  
  3. #ifndef INCLUDE_KOLIBRI_H
  4. #define INCLUDE_KOLIBRI_H
  5. #print "[include <kolibri.h>]\n"
  6.  
  7. #pragma option OST
  8. #pragma option ON
  9. #pragma option cri-
  10. #pragma option -CPA
  11. #initallvar 0
  12. #jumptomain FALSE
  13.  
  14. #startaddress 0
  15.  
  16. #code32 TRUE
  17.  
  18. char   os_name[8]   = {'M','E','N','U','E','T','0','1'};
  19. dword  os_version   = 0x00000001;
  20. dword  start_addr   = #______INIT______;
  21. dword  final_addr   = #______STOP______+32;
  22. dword  alloc_mem    = MEMSIZE;
  23. dword  x86esp_reg   = MEMSIZE;
  24. dword  I_Param      = #param;
  25. dword  I_Path       = #program_path;
  26. char param[4096];
  27. char program_path[4096];
  28.  
  29. #define bool      char
  30.  
  31. #define NULL      0
  32. #define OLD      -1
  33. #define true      1
  34. #define false     0
  35.  
  36. //Process Events
  37. #define evReDraw  1
  38. #define evKey     2
  39. #define evButton  3
  40. #define evDesktop 5
  41. #define evMouse   6
  42. #define evIPC     7
  43. #define evNetwork 8
  44. #define evDebug   9
  45.  
  46. //Button options
  47. #define BT_DEL      0x80000000
  48. #define BT_HIDE     0x40000000
  49. #define BT_NOFRAME  0x20000000
  50.  
  51. //ASCII KEYS
  52. #define ASCII_KEY_BS    008
  53. #define ASCII_KEY_TAB   009
  54. #define ASCII_KEY_ENTER 013
  55. #define ASCII_KEY_ESC   027
  56. #define ASCII_KEY_DEL   182
  57. #define ASCII_KEY_INS   185
  58. #define ASCII_KEY_SPACE 032
  59.  
  60. #define ASCII_KEY_LEFT  176
  61. #define ASCII_KEY_RIGHT 179
  62. #define ASCII_KEY_DOWN  177
  63. #define ASCII_KEY_UP    178
  64. #define ASCII_KEY_HOME  180
  65. #define ASCII_KEY_END   181
  66. #define ASCII_KEY_PGDN  183
  67. #define ASCII_KEY_PGUP  184
  68.  
  69. //SCAN CODE KEYS
  70. #define SCAN_CODE_BS    014
  71. #define SCAN_CODE_TAB   015
  72. #define SCAN_CODE_ENTER 028
  73. #define SCAN_CODE_ESC   001
  74. #define SCAN_CODE_DEL   083
  75. #define SCAN_CODE_INS   082
  76. #define SCAN_CODE_SPACE 057
  77.            
  78. #define SCAN_CODE_LEFT  075
  79. #define SCAN_CODE_RIGHT 077
  80. #define SCAN_CODE_DOWN  080
  81. #define SCAN_CODE_UP    072
  82. #define SCAN_CODE_HOME  071
  83. #define SCAN_CODE_END   079
  84. #define SCAN_CODE_PGDN  081
  85. #define SCAN_CODE_PGUP  073
  86.  
  87. #define KEY_LSHIFT     00000000001b
  88. #define KEY_RSHIFT     00000000010b
  89. #define KEY_LCTRL      00000000100b
  90. #define KEY_RCTRL      00000001000b
  91. #define KEY_LALT       00000010000b
  92. #define KEY_RALT       00000100000b
  93. #define KEY_CAPSLOCK   00001000000b
  94. #define KEY_NUMLOCK    00010000000b
  95. #define KEY_SCROLLLOCK 00100000000b
  96. #define KEY_LWIN       01000000000b
  97. #define KEY_RWIN       10000000000b
  98.  
  99. dword calc(EAX) { return EAX; }
  100.  
  101. inline fastcall word GetKey()  //+Gluk fix
  102. {
  103.                 $push edx
  104. GETKEY:
  105.                 $mov  eax,2
  106.                 $int  0x40
  107.                 $cmp eax,1
  108.                 $jne GETKEYI
  109.                 $mov ah,dh
  110.                 $jmp GETKEYII //jz?
  111. GETKEYI:
  112.                 $mov dh,ah
  113.                 $jmp GETKEY
  114. GETKEYII:
  115.                 $pop edx
  116.                 $shr eax,8
  117. }
  118.  
  119.  
  120. unsigned char key_ascii;
  121. dword key_scancode, key_modifier;
  122. int GetKeys()
  123. {
  124.                 $push edx
  125. GETKEY:
  126.                 $mov  eax,2
  127.                 $int  0x40
  128.                 $cmp eax,1
  129.                 $jne GETKEYI
  130.                 $mov eax,edx
  131.                 $jmp GETKEYII
  132. GETKEYI:
  133.                 $mov edx,eax
  134.                 $jmp GETKEY
  135. GETKEYII:
  136.                 $pop edx
  137.         key_ascii = AH;
  138.         $shr  eax,16
  139.         key_scancode = AL;
  140.         //get alt/shift/ctrl key status
  141.         $mov eax,66
  142.         $mov ebx,3
  143.         $int 0x40
  144.         key_modifier = EAX;
  145. }
  146.  
  147. //allow event mask
  148. #define EVENT_MASK_REDRAW   000000001b
  149. #define EVENT_MASK_KEYBOARD 000000010b
  150. #define EVENT_MASK_BUTTONS  000000100b
  151. #define EVENT_MASK_DESKTOP  000010000b
  152. #define EVENT_MASK_MOUSE    000100000b
  153. #define EVENT_MASK_IPC      001000000b
  154. #define EVENT_MASK_NETWORK  010000000b
  155. #define EVENT_MASK_DEBUG    100000000b
  156.  
  157. //ARGS FUNCTION
  158. #define END_ARGS 0xFF00FF
  159. //-------------------------------------------------------------------------
  160.  
  161. #ifndef INCLUDE_SYSTEM_H
  162. #include "../lib/system.h"
  163. #endif
  164.  
  165. #ifndef INCLUDE_MOUSE_H
  166. #include "../lib/mouse.h"
  167. #endif
  168.  
  169. :struct raw_image {
  170.         dword w, h, data;
  171. };
  172.  
  173.  
  174.  
  175. //------------------------------------------------------------------------------
  176. :dword wait_event_code;
  177. inline fastcall dword WaitEvent()
  178. {
  179.         $mov eax,10
  180.         $int 0x40
  181.         wait_event_code = EAX;
  182.         //if(wait_event_code==evMouse) MOUSE.get();
  183.         //return wait_event_code;
  184. }
  185.  
  186. inline fastcall dword CheckEvent()
  187. {
  188.         $mov eax,11
  189.         $int 0x40
  190. }
  191.  
  192. inline fastcall dword WaitEventTimeout(EBX)
  193. {
  194.         $mov eax,23
  195.         $int 0x40
  196. }
  197.  
  198. inline fastcall SetEventMask(EBX)
  199. {
  200.         $mov eax,40
  201.         $int 0x40
  202. }
  203.  
  204.  
  205. inline fastcall pause(EBX)
  206. {
  207.         $mov eax, 5
  208.         $int 0x40
  209. }
  210.  
  211. inline fastcall word GetButtonID()
  212. {
  213.         $mov eax,17
  214.         $int  0x40
  215.         $shr eax,8
  216. }
  217.  
  218. inline fastcall dword GetFreeRAM()
  219. {
  220.         $mov eax, 18
  221.         $mov ebx, 16
  222.         $int 0x40
  223.         //return eax = ЁрчьхЁ ётюсюфэющ ярь Єш т ъшыюсрщЄрї
  224. }
  225.  
  226. inline void draw_line(dword x1,y1,x2,y2,color)
  227. {
  228.         x2--;y2--;y1--;
  229.         $mov EAX,38
  230.         EBX = x1<<16;
  231.         EBX |= x2;
  232.         ECX = y1<<16;
  233.         ECX |= y2;
  234.         $mov EDX,color
  235.         $int 0x40
  236. }
  237.  
  238. inline fastcall dword LoadDriver(ECX) //ECX - шь  фЁрщтхЁр
  239. {
  240.         $mov eax, 68
  241.         $mov ebx, 16
  242.         $int 0x40
  243.         //return 0 - эхєфрўр, шэрўх eax = ї¤эфы фЁрщтхЁр
  244. }
  245.  
  246. inline fastcall dword RuleDriver(ECX) //єърчрЄхы№ эр єяЁрты ■∙є■ ёЄЁєъЄєЁє
  247. {
  248.         $mov eax, 68
  249.         $mov ebx, 17
  250.         $int 0x40
  251.         //return eax = юяЁхфхы хЄё  фЁрщтхЁюь
  252. }
  253.  
  254. struct proc_info
  255. {
  256.         #define SelfInfo -1
  257.         dword   use_cpu;
  258.         word    pos_in_stack,num_slot,rezerv1;
  259.         unsigned char name[11];
  260.         char    rezerv2;
  261.         dword   adress,use_memory,ID,left,top,width,height;
  262.         word    status_slot,rezerv3;
  263.         dword   work_left,work_top,work_width,work_height;
  264.         char    status_window;
  265.         dword   cwidth,cheight;
  266.         byte    reserved[1024-71-8];
  267. };
  268.  
  269. inline fastcall void GetProcessInfo(EBX, ECX)
  270. {
  271.         $mov eax,9;
  272.         $int  0x40
  273.         DSDWORD[EBX+71] = DSDWORD[EBX+42] - 9; //set cwidth
  274.         DSDWORD[EBX+75] = DSDWORD[EBX+46] - GetSkinHeight() - 4; //set cheight
  275. }
  276.  
  277. inline fastcall int GetPointOwner( EBX, ECX) //ebx=m.x, ecx=m.y
  278. {
  279.         $mov eax,34
  280.         $int 0x40
  281. }
  282.  
  283. inline fastcall int GetProcessSlot( ECX)
  284. {
  285.         EAX = 18;
  286.         EBX = 21;
  287.         $int 0x40
  288. }
  289.  
  290. inline fastcall int GetActiveProcess()
  291. {
  292.         EAX = 18;
  293.         EBX = 7;
  294.         $int 0x40
  295. }
  296.  
  297. :int CheckActiveProcess(int Form_ID)
  298. {
  299.         int id9=GetProcessSlot(Form_ID);
  300.         if (id9==GetActiveProcess()) return 1;
  301.         return 0;
  302. }
  303.  
  304. inline fastcall void ActivateWindow( ECX)
  305. {
  306.         EAX = 18;
  307.         EBX = 3;
  308.         $int 0x40
  309. }
  310.  
  311. inline fastcall int MinimizeWindow()
  312. {
  313.         EAX = 18;
  314.         EBX = 10;
  315.         $int 0x40
  316. }
  317.  
  318. inline fastcall int CreateThread(ECX,EDX)
  319. {
  320.         $mov eax,51
  321.         $mov ebx,1
  322.         $int 0x40
  323. }
  324.  
  325. inline fastcall void SwitchToAnotherThread()
  326. {
  327.         $mov eax,68
  328.         $mov ebx,1
  329.         $int 0x40
  330. }
  331.  
  332. inline fastcall int SendWindowMessage( ECX, EDX)
  333. {
  334.         $mov eax, 72
  335.         $mov ebx, 1
  336.         $int 0x40
  337. }
  338.  
  339. inline fastcall int KillProcess( ECX)
  340. {
  341.         $mov eax,18;
  342.         $mov ebx,18;
  343.         $int 0x40
  344. }
  345.  
  346. #define TURN_OFF 2
  347. #define REBOOT 3
  348. #define KERNEL 4
  349. inline fastcall int ExitSystem( ECX)
  350. {
  351.         $mov eax, 18
  352.         $mov ebx, 9
  353.         $int 0x40
  354. }
  355.  
  356. inline fastcall ExitProcess()
  357. {
  358.         $mov eax,-1;
  359.         $int 0x40
  360. }
  361.  
  362. //------------------------------------------------------------------------------
  363.  
  364. //eax =  ч√ъ ёшёЄхь√ (1=eng, 2=fi, 3=ger, 4=rus)
  365. inline fastcall int GetSystemLanguage()
  366. {
  367.         EAX = 26;
  368.         EBX = 5;
  369.         $int 0x40
  370. }
  371.  
  372. inline fastcall GetSkinHeight()
  373. {
  374.         $push ebx
  375.         $mov  eax,48
  376.         $mov  ebx,4
  377.         $int 0x40
  378.         $pop  ebx
  379. }
  380.  
  381. inline fastcall void SetSystemSkin( ECX)
  382. {
  383.         EAX = 48;
  384.         EBX = 8;
  385.         $int 0x40
  386. }
  387.  
  388. inline fastcall int GetScreenWidth()
  389. {
  390.         $mov eax, 14
  391.         $int 0x40
  392.         $shr eax, 16
  393. }
  394.  
  395. inline fastcall int GetScreenHeight()
  396. {
  397.         $mov eax, 14
  398.         $int 0x40
  399.         $and eax,0x0000FFFF
  400. }
  401.  
  402. inline fastcall int GetClientTop()
  403. {
  404.         $mov eax, 48
  405.         $mov ebx, 5
  406.         $int 0x40
  407.     $mov eax, ebx
  408.     $shr eax, 16
  409. }
  410.  
  411. inline fastcall int GetClientHeight()
  412. {
  413.         $mov eax, 48
  414.         $mov ebx, 5
  415.         $int 0x40
  416.     $mov eax, ebx
  417. }
  418.  
  419.  
  420. inline fastcall dword LoadLibrary( ECX)
  421. {
  422.         $mov eax, 68
  423.         $mov ebx, 19
  424.         $int  0x40
  425. }
  426.  
  427. inline fastcall int TestBit( EAX, CL)
  428. {
  429.         $shr eax,cl
  430.         $and eax,1
  431. }
  432.  
  433. inline fastcall int PlaySpeaker( ESI)
  434. {
  435.         $mov eax, 55
  436.         $mov ebx, 55
  437.         $int 0x40
  438. }
  439.  
  440. inline fastcall void debugln( EDX)
  441. {
  442.         $push eax
  443.         $push ebx
  444.         $push ecx
  445.         $mov eax, 63
  446.         $mov ebx, 1
  447. NEXT_CHAR:
  448.         $mov ecx, DSDWORD[edx]
  449.         $or      cl, cl
  450.         $jz  DONE
  451.         $int 0x40
  452.         $inc edx
  453.         $jmp NEXT_CHAR
  454. DONE:
  455.         $mov cl, 13
  456.         $int 0x40
  457.         $mov cl, 10
  458.         $int 0x40
  459.         $pop ecx
  460.         $pop ebx
  461.         $pop eax
  462. }
  463.  
  464. inline fastcall void debug( EDX)
  465. {
  466.         $push eax
  467.         $push ebx
  468.         $push ecx
  469.         $mov eax, 63
  470.         $mov ebx, 1
  471. NEXT_CHAR:
  472.         $mov ecx, DSDWORD[edx]
  473.         $or      cl, cl
  474.         $jz  DONE
  475.         $int 0x40
  476.         $inc edx
  477.         $jmp NEXT_CHAR
  478. DONE:
  479.         $pop ecx
  480.         $pop ebx
  481.         $pop eax
  482. }
  483.  
  484.  
  485. inline fastcall void debugch( ECX)
  486. {
  487.         $push eax
  488.         $push ebx
  489.         $mov eax,63
  490.         $mov ebx,1
  491.         $int 0x40
  492.         $pop ebx
  493.         $pop eax
  494. }
  495. //------------------------------------------------------------------------------
  496.  
  497. void DefineAndDrawWindow(dword x, y, size_w, size_h, byte WindowType,dword WindowAreaColor, EDI, ESI)
  498. {
  499.         EAX = 12;              // function 12:tell os about windowdraw
  500.         EBX = 1;
  501.         $int 0x40
  502.        
  503.         $xor EAX,EAX
  504.         EBX = x << 16 + size_w;
  505.         ECX = y << 16 + size_h;
  506.  
  507.         EDX = WindowType << 24 | WindowAreaColor;
  508.         $int 0x40
  509.  
  510.         EAX = 12;              // function 12:tell os about windowdraw
  511.         EBX = 2;
  512.         $int 0x40
  513. }
  514.  
  515. inline fastcall MoveSize( EBX,ECX,EDX,ESI)
  516. {
  517.         $mov eax, 67
  518.         $int 0x40
  519. }
  520.  
  521. inline fastcall void DrawTitle( ECX)
  522. {
  523.         EAX = 71;
  524.         EBX = 1;
  525.         $int 0x40;
  526. }
  527.  
  528. void WriteTextB(dword x,y,byte fontType, dword color, EDX)
  529. {
  530.         EAX = 4;
  531.         EBX = x<<16+y;
  532.         ECX = fontType<<24+color;
  533.         ESI = 0;
  534.         $int 0x40;
  535.         $add ebx, 1<<16
  536.         $int 0x40
  537. }
  538.  
  539. void WriteText(dword x,y,byte fontType, dword color, EDX)
  540. {
  541.         EAX = 4;
  542.         EBX = x<<16+y;
  543.         ECX = fontType<<24+color;
  544.         $int 0x40;
  545. }
  546.  
  547. dword WriteBufText(dword x,y,byte fontType, dword color, EDX, EDI)
  548. {
  549.         EAX = 4;
  550.         EBX = x<<16+y;
  551.         ECX = fontType<<24+color;
  552.         $int 0x40;
  553. }
  554.  
  555. void WriteNumber(dword x,y,byte fontType, dword color, count, ECX)
  556. {
  557.         EAX = 47;
  558.         EBX = count<<16;
  559.         EDX = x<<16+y;
  560.         ESI = fontType<<24+color;
  561.         $int 0x40;
  562. }
  563.  
  564. void CopyScreen(dword EBX, x, y, w, h)
  565. {
  566.   EAX = 36;
  567.   ECX = w << 16 + h;
  568.   EDX = x << 16 + y;
  569.   $int  0x40;
  570. }
  571.  
  572. :dword GetPixelColor(dword x, x_size, y)
  573. {
  574.         $mov eax, 35
  575.         EBX= y*x_size+x;
  576.         $int 0x40
  577. }
  578.  
  579.  
  580. void _PutImage(dword x,y, w,h, EBX)
  581. {
  582.         EAX = 7;
  583.         ECX = w<<16+h;
  584.         EDX = x<<16+y;
  585.         $int 0x40
  586. }
  587.  
  588. void PutPaletteImage(dword EBX,w,h,x,y,ESI,EDI)
  589. {
  590.         EAX = 65;
  591.         ECX = w<<16+h;
  592.         EDX = x<<16+y;
  593.         EBP = 0;
  594.         $int 0x40
  595. }
  596.  
  597. inline fastcall void PutPixel( EBX,ECX,EDX)
  598. {
  599.   EAX=1;
  600.   $int 0x40
  601. }
  602.  
  603. void DrawBar(dword x,y,w,h,EDX)
  604. {
  605.         if (h<=0) || (h>60000) || (w<=0) || (w>60000) return; //bad boy :)
  606.         EAX = 13;
  607.         EBX = x<<16+w;
  608.         ECX = y<<16+h;
  609.         $int 0x40
  610. }
  611.  
  612. void DefineButton(dword x,y,w,h,EDX,ESI)
  613. {
  614.         EAX = 8;
  615.         $push edx
  616.         EDX += BT_DEL;
  617.         $int 0x40;
  618.         $pop edx
  619.         EBX = x<<16+w;
  620.         ECX = y<<16+h;
  621.         $int 0x40
  622. }
  623.  
  624. inline RefreshWindow(dword ID_REFRESH,ID_ACTIVE)
  625. {
  626.         EAX = 18;
  627.         EBX = 22;
  628.         ECX = 3;
  629.         EDX = ID_REFRESH;
  630.         $int 0x40
  631.         EAX = 18;
  632.         EBX = 3;
  633.         EDX = ID_ACTIVE;
  634.         $int 0x40
  635. }
  636.  
  637. inline getIPC(ECX,EDX)
  638. {
  639.         $mov EAX,60
  640.         $mov EBX,2
  641.         $int 0x40
  642. }
  643.  
  644. inline sendIPC(ECX,EDX,ESI)
  645. {
  646.         $mov EAX,60
  647.         $mov EBX,1
  648.         $int 0x40
  649. }
  650.  
  651. void UnsafeDefineButton(dword x,y,w,h,EDX,ESI)
  652. {
  653.         EAX = 8;
  654.         EBX = x<<16+w;
  655.         ECX = y<<16+h;
  656.         $int 0x40
  657. }
  658.  
  659. inline fastcall void DeleteButton( EDX)
  660. {
  661.         EAX = 8;
  662.         EDX += BT_DEL;
  663.         $int 0x40
  664. }
  665.  
  666. inline fastcall dword GetStartTime()
  667. {
  668.         $mov eax,26
  669.         $mov ebx,9
  670.         $int 0x40
  671. }
  672.  
  673. :dword X_EventRedrawWindow,Y_EventRedrawWindow;
  674. :void _EventRedrawWindow()
  675. {
  676.         loop()switch(WaitEvent())
  677.         {
  678.                 case evReDraw:
  679.                         DefineAndDrawWindow(X_EventRedrawWindow,Y_EventRedrawWindow,100,1,1,0x34,0xFFFFFF,"");
  680.                         pause(10);
  681.                         ExitProcess();
  682.                         break;
  683.         }
  684. }
  685. :char REDRAW_BUFF_EVENT_[4096];
  686. :void EventRedrawWindow(dword x,y)
  687. {
  688.         X_EventRedrawWindow = x;
  689.         Y_EventRedrawWindow = y;
  690.         CreateThread(#_EventRedrawWindow,#REDRAW_BUFF_EVENT_+4092);
  691. }
  692.  
  693. :dword ALERT_TEXT;
  694. :void dialog_alert()
  695. {
  696.         byte id;
  697.         loop()switch(WaitEvent())
  698.         {
  699.                 case evReDraw:
  700.                         DefineAndDrawWindow(215,100,250,200,0x34,0xFFFFFF,"Alert");
  701.                         WriteTextB(5,5,0x90,0x0,ALERT_TEXT);
  702.                 break;
  703.                 case evKey:
  704.                 case evButton:
  705.                         id=GetButtonID();
  706.                         if (id==1) ExitProcess();
  707.                 break;
  708.         }
  709. }
  710. :dword alert(dword text)
  711. {
  712.         dword mem = malloc(4096);
  713.         ALERT_TEXT = text;
  714.         CreateThread(#dialog_alert,mem+4092);
  715.         return mem;
  716. }
  717.  
  718. :struct _screen
  719. {
  720.         dword width,height;
  721. } screen;
  722.  
  723. :byte skin_height;
  724.  
  725. :void DrawDate(dword x, y, color, in_date)
  726. {
  727.         //char text[15];
  728.         EDI = in_date;
  729.         EAX = 47;
  730.         EBX = 2<<16;
  731.         EDX = x<<16+y;
  732.         ESI = 0x80<<24+color;
  733.         ECX = EDI.date.day;
  734.         $int 0x40;
  735.         EDX += 18<<16;
  736.         ECX = EDI.date.month;
  737.         $int 0x40;
  738.         EDX += 18<<16;
  739.         EBX = 4<<16;
  740.         ECX = EDI.date.year;
  741.         $int 0x40;
  742.         PutPixel(x+14,y+6,color);
  743.         PutPixel(x+32,y+6,color);
  744.         //sprintf(#text,"%d",EDI.date.year);
  745.         //WriteText(x, y, 0x80, 0x000000, #text);
  746. }
  747.  
  748. :void __path_name__(dword BUF,PATH)
  749. {
  750.         dword beg = PATH;
  751.         dword pos = PATH;
  752.         dword sav = PATH;
  753.         dword i;
  754.         while(DSBYTE[pos])
  755.         {
  756.                 if(DSBYTE[pos]=='/')sav = pos;
  757.                 pos++;
  758.         }
  759.         i = sav-beg;
  760.         while(i)
  761.         {
  762.                 DSBYTE[BUF] = DSBYTE[beg];
  763.                 beg++;
  764.                 BUF++;
  765.                 i--;
  766.         }
  767.         /*while(DSBYTE[beg])
  768.         {
  769.                 DSBYTE[BUF1] = DSBYTE[beg];
  770.                 beg++;
  771.                 BUF1++;
  772.         }*/
  773.         //DSBYTE[BUF1] = 0;
  774.         DSBYTE[BUF] = 0;
  775. }
  776. char __BUF_DIR__[4096];
  777. :struct SELF
  778. {
  779.         dword dir;
  780.         dword file;
  781.         dword path;
  782. } self;
  783.  
  784. dword __generator;  // random number generator - фы  ухэхЁрЎшш ёыєўрщэ√ї ўшёхы
  785.  
  786. :dword program_path_length;
  787.  
  788. //The initialization of the initial data before running
  789. void ______INIT______()
  790. {
  791.         self.dir = #__BUF_DIR__;
  792.         self.file = 0;
  793.         self.path = I_Path;
  794.         __path_name__(#__BUF_DIR__,I_Path);
  795.        
  796.         skin_height   = GetSkinHeight();
  797.         screen.width  = GetScreenWidth();
  798.         screen.height = GetScreenHeight();
  799.        
  800.         //program_path_length = strlen(I_Path);
  801.         DOUBLE_CLICK_DELAY = GetMouseDoubleClickDelay();
  802.         __generator = GetStartTime();
  803.        
  804.         mem_init();
  805.  
  806.         main();
  807.         ExitProcess();
  808. }
  809. ______STOP______:
  810. #endif
  811.  
  812. #ifndef INCLUDE_MEM_H
  813. #include "../lib/mem.h"
  814. #endif
  815.