Scripting DLL » History » Version 19
  Per Amundsen, 08/13/2014 07:28 AM 
  
| 1 | 19 | Per Amundsen | h1. DLL Support | 
|---|---|---|---|
| 2 | 2 | Per Amundsen | |
| 3 | The [[/dll]], [[$dll]] and [[$dllcall]] features allow you to make calls to DLL's designed to work with AdiIRC. The main reason you would want to do this is that processing information in a DLL can be far faster than doing so in a script, so for intensive data processing a DLL would be more efficient. | ||
| 4 | |||
| 5 | 17 | Per Amundsen | If you want to create a DLL for use with AdiIRC you need to create a specific routine like this in your DLL file. | 
| 6 | 3 | Per Amundsen | |
| 7 | 18 | Per Amundsen | _For technical reasons, the DLL must be compiled for 64 bit on 64 bit versions of Windows, regardless of using the 32 bit AdiIRC version._ | 
| 8 | |||
| 9 | 3 | Per Amundsen | *int __stdcall procname(HWND mWnd, HWND aWnd, char *data, char *parms, BOOL show, BOOL nopause)* | 
| 10 | |||
| 11 | 9 | Per Amundsen | "procname" is the name of the routine you will call from AdiIRC, you can create as many as you need and they can be named anything. | 
| 12 | 3 | Per Amundsen | |
| 13 | 10 | Per Amundsen | _You may need to create a .def file with the "procname" names exported when compiling your DLL._ | 
| 14 | 3 | Per Amundsen | |
| 15 | *Parameters* | ||
| 16 | 5 | Per Amundsen | |
| 17 | 3 | Per Amundsen | mWnd - The handle to the main AdiIRC window. | 
| 18 | aWnd - The handle of the window in which the command is being issued, this might not be the currently active window if the command is being called by a remote script. | ||
| 19 | data - The information that you wish to send to the DLL. On return, the DLL can fill this variable with the command it wants AdiIRC to perform if any. | ||
| 20 | parms - Can be filled by the DLL on return with parameters that it wants AdiIRC to use when performing the command that it returns in the data variable. | ||
| 21 | show - Is FALSE if the . prefix was specified to make the command quiet, or TRUE otherwise. | ||
| 22 | nopause - Is TRUE if AdiIRC is in a critical routine and the DLL must not do anything that pauses processing in AdiIRC, eg. the DLL should not pop up a dialog. | ||
| 23 | |||
| 24 | *Returns* | ||
| 25 | |||
| 26 | The routine can return an integer to indicate what it wants AdiIRC to do: | ||
| 27 | |||
| 28 | 0 - Means that AdiIRC should /halt processing. | ||
| 29 | 1 - Means that AdiIRC should continue processing. | ||
| 30 | 2 - Means that it has filled the data variable with a command which it wants AdiIRC to perform, and has filled parms with the parameters to use, if any, when performing the command. | ||
| 31 | 3 - Means that the DLL has filled the data variable with the result that [[$dll]] as an identifier should return. | ||
| 32 | |||
| 33 | *Keeping a DLL Loaded after a call* | ||
| 34 | |||
| 35 | By default a DLL is unloaded immediately after you make the [[/dll]], [[$dll]] or [[$dllcall]] call. You can keep a DLL loaded by including a LoadDll() routine in your DLL, which AdiIRC calls the first time you load the DLL: | ||
| 36 | |||
| 37 | 16 | Per Amundsen | *void __stdcall LoadDll(LOADINFO*);* | 
| 38 | 1 | Per Amundsen | |
| 39 | 3 | Per Amundsen |  typedef struct { | 
| 40 | DWORD mVersion; | ||
| 41 | HWND mHwnd; | ||
| 42 | BOOL mKeep; | ||
| 43 | 1 | Per Amundsen | BOOL mUnicode; | 
| 44 | 16 | Per Amundsen | } LOADINFO; | 
| 45 | 6 | Per Amundsen | |
| 46 | *Struct parameters* | ||
| 47 | |||
| 48 | 3 | Per Amundsen | mVersion - Contains the AdiIRC version number in the low and high words. | 
| 49 | mHwnd - Contains the window handle to the main AdiIRC window. | ||
| 50 | mKeep - Set to TRUE by default, indicating that AdiIRC will keep the DLL loaded after the call. You can set mKeep to FALSE to make AdiiRC unload the DLL after the call. | ||
| 51 | mUnicode - Indicates that text is in unicode as opposed to ansi. | ||
| 52 | |||
| 53 | *Unloading a DLL* | ||
| 54 | You can unload a loaded DLL by using the -u switch: | ||
| 55 | |||
| 56 | <pre> | ||
| 57 | /dll -u <filename> | ||
| 58 | </pre> | ||
| 59 | |||
| 60 | AdiIRC will automatically unload a DLL if it is not used for ten minutes, or when AdiIRC exits. | ||
| 61 | |||
| 62 | You can also define an UnloadDll() routine in your DLL which AdiIRC will call when unloading a DLL to allow it to clean up. | ||
| 63 | 1 | Per Amundsen | |
| 64 | *int __stdcall UnloadDll(int mTimeout);* | ||
| 65 | 6 | Per Amundsen | |
| 66 | 3 | Per Amundsen | mTimeout can be: | 
| 67 | 8 | Per Amundsen | |
| 68 | 3 | Per Amundsen | 0 - UnloadDll() is being called due to a DLL being unloaded with [[/dll]] -u | 
| 69 | 1 - UnloadDll() is being called due to a DLL not being used for ten minutes. The UnloadDll() routine can return 0 to keep the DLL loaded, or 1 to allow it to be unloaded. | ||
| 70 | 2 - UnloadDll() is being called due to a DLL being unloaded when AdiIRC exits. |