Yashied Posted September 6, 2010 Author Posted September 6, 2010 (edited) Thanks, will be added in the next version. Edited September 9, 2010 by Yashied My UDFs: iKey | FTP Uploader | Battery Checker | Boot Manager | Font Viewer | UDF Keyword Manager | Run Dialog Replacement | USBProtect | 3D Axis | Calculator | Sleep | iSwitcher | TM | NetHelper | File Types Manager | Control Viewer | SynFolders | DLL Helper Animated Tray Icons UDF Library | Hotkeys UDF Library | Hotkeys Input Control UDF Library | Caret Shape UDF Library | Context Help UDF Library | Most Recently Used List UDF Library | Icons UDF Library | FTP UDF Library | Script Communications UDF Library | Color Chooser UDF Library | Color Picker Control UDF Library | IPHelper (Vista/7) UDF Library | WinAPI Extended UDF Library | WinAPIVhd UDF Library | Icon Chooser UDF Library | Copy UDF Library | Restart UDF Library | Event Log UDF Library | NotifyBox UDF Library | Pop-up Windows UDF Library | TVExplorer UDF Library | GuiHotKey UDF Library | GuiSysLink UDF Library | Package UDF Library | Skin UDF Library | AITray UDF Library | RDC UDF Library Appropriate path | Button text color | Gaussian random numbers | Header's styles (Vista/7) | ICON resource enumeration | Menu & INI | Tabbed string size | Tab's skin | Pop-up circular menu | Progress Bar without animation (Vista/7) | Registry export | Registry path jumping | Unique hardware ID | Windows alignment More...
guinness Posted September 8, 2010 Posted September 8, 2010 (edited) Excellent! It's just an observation but I noticed that in the AutoIt HelpFile the UDF examples they have use #AutoIt3Wrapper_Au3Check_Parameters=-d -w 1 -w 2 -w 3 -w 4 -w 5 -w 6 to ensure all variables are declared/used etc. correctly. Because I have started to use #AutoIt3Wrapper_Au3Check_Parameters= within my scripts, the other day it reported (non-disastrous) 17 warnings with WinAPIEx.. I was wondering with the next release coming has it been something you have considered looking at in the past? Of course these are non-script breaking warnings, but it would make the UDF 100% Tidy Edited September 8, 2010 by guinness UDF List: _AdapterConnections() • _AlwaysRun() • _AppMon() • _AppMonEx() • _ArrayFilter/_ArrayReduce • _BinaryBin() • _CheckMsgBox() • _CmdLineRaw() • _ContextMenu() • _ConvertLHWebColor()/_ConvertSHWebColor() • _DesktopDimensions() • _DisplayPassword() • _DotNet_Load()/_DotNet_Unload() • _Fibonacci() • _FileCompare() • _FileCompareContents() • _FileNameByHandle() • _FilePrefix/SRE() • _FindInFile() • _GetBackgroundColor()/_SetBackgroundColor() • _GetConrolID() • _GetCtrlClass() • _GetDirectoryFormat() • _GetDriveMediaType() • _GetFilename()/_GetFilenameExt() • _GetHardwareID() • _GetIP() • _GetIP_Country() • _GetOSLanguage() • _GetSavedSource() • _GetStringSize() • _GetSystemPaths() • _GetURLImage() • _GIFImage() • _GoogleWeather() • _GUICtrlCreateGroup() • _GUICtrlListBox_CreateArray() • _GUICtrlListView_CreateArray() • _GUICtrlListView_SaveCSV() • _GUICtrlListView_SaveHTML() • _GUICtrlListView_SaveTxt() • _GUICtrlListView_SaveXML() • _GUICtrlMenu_Recent() • _GUICtrlMenu_SetItemImage() • _GUICtrlTreeView_CreateArray() • _GUIDisable() • _GUIImageList_SetIconFromHandle() • _GUIRegisterMsg() • _GUISetIcon() • _Icon_Clear()/_Icon_Set() • _IdleTime() • _InetGet() • _InetGetGUI() • _InetGetProgress() • _IPDetails() • _IsFileOlder() • _IsGUID() • _IsHex() • _IsPalindrome() • _IsRegKey() • _IsStringRegExp() • _IsSystemDrive() • _IsUPX() • _IsValidType() • _IsWebColor() • _Language() • _Log() • _MicrosoftInternetConnectivity() • _MSDNDataType() • _PathFull/GetRelative/Split() • _PathSplitEx() • _PrintFromArray() • _ProgressSetMarquee() • _ReDim() • _RockPaperScissors()/_RockPaperScissorsLizardSpock() • _ScrollingCredits • _SelfDelete() • _SelfRename() • _SelfUpdate() • _SendTo() • _ShellAll() • _ShellFile() • _ShellFolder() • _SingletonHWID() • _SingletonPID() • _Startup() • _StringCompact() • _StringIsValid() • _StringRegExpMetaCharacters() • _StringReplaceWholeWord() • _StringStripChars() • _Temperature() • _TrialPeriod() • _UKToUSDate()/_USToUKDate() • _WinAPI_Create_CTL_CODE() • _WinAPI_CreateGUID() • _WMIDateStringToDate()/_DateToWMIDateString() • Au3 script parsing • AutoIt Search • AutoIt3 Portable • AutoIt3WrapperToPragma • AutoItWinGetTitle()/AutoItWinSetTitle() • Coding • DirToHTML5 • FileInstallr • FileReadLastChars() • GeoIP database • GUI - Only Close Button • GUI Examples • GUICtrlDeleteImage() • GUICtrlGetBkColor() • GUICtrlGetStyle() • GUIEvents • GUIGetBkColor() • Int_Parse() & Int_TryParse() • IsISBN() • LockFile() • Mapping CtrlIDs • OOP in AutoIt • ParseHeadersToSciTE() • PasswordValid • PasteBin • Posts Per Day • PreExpand • Protect Globals • Queue() • Resource Update • ResourcesEx • SciTE Jump • Settings INI • SHELLHOOK • Shunting-Yard • Signature Creator • Stack() • Stopwatch() • StringAddLF()/StringStripLF() • StringEOLToCRLF() • VSCROLL • WM_COPYDATA • More Examples... Updated: 22/04/2018
Yashied Posted September 9, 2010 Author Posted September 9, 2010 Excellent! It's just an observation but I noticed that in the AutoIt HelpFile the UDF examples they have use #AutoIt3Wrapper_Au3Check_Parameters=-d -w 1 -w 2 -w 3 -w 4 -w 5 -w 6 to ensure all variables are declared/used etc. correctly. Because I have started to use #AutoIt3Wrapper_Au3Check_Parameters= within my scripts, the other day it reported (non-disastrous) 17 warnings with WinAPIEx..I was wondering with the next release coming has it been something you have considered looking at in the past? Of course these are non-script breaking warnings, but it would make the UDF 100% Tidy OK, will be done in the next version. Thanks. My UDFs: iKey | FTP Uploader | Battery Checker | Boot Manager | Font Viewer | UDF Keyword Manager | Run Dialog Replacement | USBProtect | 3D Axis | Calculator | Sleep | iSwitcher | TM | NetHelper | File Types Manager | Control Viewer | SynFolders | DLL Helper Animated Tray Icons UDF Library | Hotkeys UDF Library | Hotkeys Input Control UDF Library | Caret Shape UDF Library | Context Help UDF Library | Most Recently Used List UDF Library | Icons UDF Library | FTP UDF Library | Script Communications UDF Library | Color Chooser UDF Library | Color Picker Control UDF Library | IPHelper (Vista/7) UDF Library | WinAPI Extended UDF Library | WinAPIVhd UDF Library | Icon Chooser UDF Library | Copy UDF Library | Restart UDF Library | Event Log UDF Library | NotifyBox UDF Library | Pop-up Windows UDF Library | TVExplorer UDF Library | GuiHotKey UDF Library | GuiSysLink UDF Library | Package UDF Library | Skin UDF Library | AITray UDF Library | RDC UDF Library Appropriate path | Button text color | Gaussian random numbers | Header's styles (Vista/7) | ICON resource enumeration | Menu & INI | Tabbed string size | Tab's skin | Pop-up circular menu | Progress Bar without animation (Vista/7) | Registry export | Registry path jumping | Unique hardware ID | Windows alignment More...
guinness Posted September 9, 2010 Posted September 9, 2010 Look forward to the next release UDF List: _AdapterConnections() • _AlwaysRun() • _AppMon() • _AppMonEx() • _ArrayFilter/_ArrayReduce • _BinaryBin() • _CheckMsgBox() • _CmdLineRaw() • _ContextMenu() • _ConvertLHWebColor()/_ConvertSHWebColor() • _DesktopDimensions() • _DisplayPassword() • _DotNet_Load()/_DotNet_Unload() • _Fibonacci() • _FileCompare() • _FileCompareContents() • _FileNameByHandle() • _FilePrefix/SRE() • _FindInFile() • _GetBackgroundColor()/_SetBackgroundColor() • _GetConrolID() • _GetCtrlClass() • _GetDirectoryFormat() • _GetDriveMediaType() • _GetFilename()/_GetFilenameExt() • _GetHardwareID() • _GetIP() • _GetIP_Country() • _GetOSLanguage() • _GetSavedSource() • _GetStringSize() • _GetSystemPaths() • _GetURLImage() • _GIFImage() • _GoogleWeather() • _GUICtrlCreateGroup() • _GUICtrlListBox_CreateArray() • _GUICtrlListView_CreateArray() • _GUICtrlListView_SaveCSV() • _GUICtrlListView_SaveHTML() • _GUICtrlListView_SaveTxt() • _GUICtrlListView_SaveXML() • _GUICtrlMenu_Recent() • _GUICtrlMenu_SetItemImage() • _GUICtrlTreeView_CreateArray() • _GUIDisable() • _GUIImageList_SetIconFromHandle() • _GUIRegisterMsg() • _GUISetIcon() • _Icon_Clear()/_Icon_Set() • _IdleTime() • _InetGet() • _InetGetGUI() • _InetGetProgress() • _IPDetails() • _IsFileOlder() • _IsGUID() • _IsHex() • _IsPalindrome() • _IsRegKey() • _IsStringRegExp() • _IsSystemDrive() • _IsUPX() • _IsValidType() • _IsWebColor() • _Language() • _Log() • _MicrosoftInternetConnectivity() • _MSDNDataType() • _PathFull/GetRelative/Split() • _PathSplitEx() • _PrintFromArray() • _ProgressSetMarquee() • _ReDim() • _RockPaperScissors()/_RockPaperScissorsLizardSpock() • _ScrollingCredits • _SelfDelete() • _SelfRename() • _SelfUpdate() • _SendTo() • _ShellAll() • _ShellFile() • _ShellFolder() • _SingletonHWID() • _SingletonPID() • _Startup() • _StringCompact() • _StringIsValid() • _StringRegExpMetaCharacters() • _StringReplaceWholeWord() • _StringStripChars() • _Temperature() • _TrialPeriod() • _UKToUSDate()/_USToUKDate() • _WinAPI_Create_CTL_CODE() • _WinAPI_CreateGUID() • _WMIDateStringToDate()/_DateToWMIDateString() • Au3 script parsing • AutoIt Search • AutoIt3 Portable • AutoIt3WrapperToPragma • AutoItWinGetTitle()/AutoItWinSetTitle() • Coding • DirToHTML5 • FileInstallr • FileReadLastChars() • GeoIP database • GUI - Only Close Button • GUI Examples • GUICtrlDeleteImage() • GUICtrlGetBkColor() • GUICtrlGetStyle() • GUIEvents • GUIGetBkColor() • Int_Parse() & Int_TryParse() • IsISBN() • LockFile() • Mapping CtrlIDs • OOP in AutoIt • ParseHeadersToSciTE() • PasswordValid • PasteBin • Posts Per Day • PreExpand • Protect Globals • Queue() • Resource Update • ResourcesEx • SciTE Jump • Settings INI • SHELLHOOK • Shunting-Yard • Signature Creator • Stack() • Stopwatch() • StringAddLF()/StringStripLF() • StringEOLToCRLF() • VSCROLL • WM_COPYDATA • More Examples... Updated: 22/04/2018
Yashied Posted September 20, 2010 Author Posted September 20, 2010 (edited) The library has been updated.v3.0ChangesAdded the following functions. _WinAPI_AddFontMemResourceEx _WinAPI_BeginUpdateResource _WinAPI_ClipCursor _WinAPI_CreateFileMapping _WinAPI_CreateIcon _WinAPI_CreateIconFromResourceEx _WinAPI_DllGetVersion _WinAPI_EndUpdateResource _WinAPI_FlushViewOfFile _WinAPI_GetClipCursor _WinAPI_GetConnectedDlg _WinAPI_GetDCEx _WinAPI_GetErrorMessage _WinAPI_GetOutlineTextMetrics _WinAPI_GetTextAlign _WinAPI_IsInternetConnected _WinAPI_LookupIconIdFromDirectoryEx _WinAPI_MapViewOfFile _WinAPI_OpenFileMapping _WinAPI_PathRelativePathTo (Thanks Mat) _WinAPI_RegQueryMultipleValues _WinAPI_RemoveFontMemResourceEx _WinAPI_ReplaceFile _WinAPI_SetTextAlign _WinAPI_UnmapViewOfFile _WinAPI_UpdateResourceAdded examples for the functions above.Removed the following functions. _WinAPI_FileTimeToLocalFileTime (use Date.au3) _WinAPI_FileTimeToSystemTime (use Date.au3) _WinAPI_GetIconBitmap (use _WinAPI_GetIconInfo()) _WinAPI_GetIconMask (use _WinAPI_GetIconInfo()) _WinAPI_GetProfilesDirectory (use _WinAPI_ShellGetKnownFolderPath()) Changed header for the following functions. _WinAPI_FindResource _WinAPI_FindResourceEx _WinAPI_PathSearchAndQualify (added parameter) Changed few internal function.Changed elementname in the $tagTEXTMETRIC structure.Removed some unused local variables. (Thanks guinness)Prevented the unloading some DLLs (such as sensapi.dll) after using its functions.Fixed a bug related to returning incorrect error code in the _WinAPI_AdjustTokenPrivileges() function.Fixed several bugs related to incorrect definition of data types.Fixed several minor bugs.Updated documentation (WinAPIEx Help). Edited October 4, 2010 by Yashied My UDFs: iKey | FTP Uploader | Battery Checker | Boot Manager | Font Viewer | UDF Keyword Manager | Run Dialog Replacement | USBProtect | 3D Axis | Calculator | Sleep | iSwitcher | TM | NetHelper | File Types Manager | Control Viewer | SynFolders | DLL Helper Animated Tray Icons UDF Library | Hotkeys UDF Library | Hotkeys Input Control UDF Library | Caret Shape UDF Library | Context Help UDF Library | Most Recently Used List UDF Library | Icons UDF Library | FTP UDF Library | Script Communications UDF Library | Color Chooser UDF Library | Color Picker Control UDF Library | IPHelper (Vista/7) UDF Library | WinAPI Extended UDF Library | WinAPIVhd UDF Library | Icon Chooser UDF Library | Copy UDF Library | Restart UDF Library | Event Log UDF Library | NotifyBox UDF Library | Pop-up Windows UDF Library | TVExplorer UDF Library | GuiHotKey UDF Library | GuiSysLink UDF Library | Package UDF Library | Skin UDF Library | AITray UDF Library | RDC UDF Library Appropriate path | Button text color | Gaussian random numbers | Header's styles (Vista/7) | ICON resource enumeration | Menu & INI | Tabbed string size | Tab's skin | Pop-up circular menu | Progress Bar without animation (Vista/7) | Registry export | Registry path jumping | Unique hardware ID | Windows alignment More...
KaFu Posted September 21, 2010 Posted September 21, 2010 Again, definitely a must have ! OS: Win10-22H2 - 64bit - German, AutoIt Version: 3.3.16.1, AutoIt Editor: SciTE, Website: https://funk.eu AMT - Auto-Movie-Thumbnailer (2024-Oct-13) BIC - Batch-Image-Cropper (2023-Apr-01) COP - Color Picker (2009-May-21) DCS - Dynamic Cursor Selector (2024-Oct-13) HMW - Hide my Windows (2024-Oct-19) HRC - HotKey Resolution Changer (2012-May-16) ICU - Icon Configuration Utility (2018-Sep-16) SMF - Search my Files (2024-Oct-20) - THE file info and duplicates search tool SSD - Set Sound Device (2017-Sep-16)
UEZ Posted September 21, 2010 Posted September 21, 2010 Fully agree! Must have library! Thanks again for your efforts Yashied! Br, UEZ Please don't send me any personal message and ask for support! I will not reply! Selection of finest graphical examples at Codepen.io The own fart smells best! ✌Her 'sikim hıyar' diyene bir avuç tuz alıp koşma!¯\_(ツ)_/¯ ٩(●̮̮̃•̃)۶ ٩(-̮̮̃-̃)۶ૐ
Yashied Posted September 22, 2010 Author Posted September 22, 2010 (edited) A small update without changing UDF version.ChangesAdded the following functions. _WinAPI_GetProcessHandleCount _WinAPI_GetSystemTimesAdded examples for the functions above.Renamed the following functions. _WinAPI_GetModuleFileNameEx => _WinAPI_GetProcessFileName _WinAPI_GetWindowModuleFileName => _WinAPI_GetWindowFileName The following functions returns now array instead of structure (see documentation). _WinAPI_GetProcessIoCounters _WinAPI_GetProcessMemoryInfo Removed $tagPROCESS_MEMORY_COUNTERS structure.Fixed a bug related to memory leak in _WinAPI_UpdateLayeredWindowEx() function.Updated documentation. Edited September 22, 2010 by Yashied My UDFs: iKey | FTP Uploader | Battery Checker | Boot Manager | Font Viewer | UDF Keyword Manager | Run Dialog Replacement | USBProtect | 3D Axis | Calculator | Sleep | iSwitcher | TM | NetHelper | File Types Manager | Control Viewer | SynFolders | DLL Helper Animated Tray Icons UDF Library | Hotkeys UDF Library | Hotkeys Input Control UDF Library | Caret Shape UDF Library | Context Help UDF Library | Most Recently Used List UDF Library | Icons UDF Library | FTP UDF Library | Script Communications UDF Library | Color Chooser UDF Library | Color Picker Control UDF Library | IPHelper (Vista/7) UDF Library | WinAPI Extended UDF Library | WinAPIVhd UDF Library | Icon Chooser UDF Library | Copy UDF Library | Restart UDF Library | Event Log UDF Library | NotifyBox UDF Library | Pop-up Windows UDF Library | TVExplorer UDF Library | GuiHotKey UDF Library | GuiSysLink UDF Library | Package UDF Library | Skin UDF Library | AITray UDF Library | RDC UDF Library Appropriate path | Button text color | Gaussian random numbers | Header's styles (Vista/7) | ICON resource enumeration | Menu & INI | Tabbed string size | Tab's skin | Pop-up circular menu | Progress Bar without animation (Vista/7) | Registry export | Registry path jumping | Unique hardware ID | Windows alignment More...
ivan Posted September 23, 2010 Posted September 23, 2010 ***** + Thanks for sharing. I've read the entire thread trying to find an objective justification for not seeing this in the Autoit UFDs, but I honestly have found nothing. Perhaps a discussion on splitting this script and a subjective discussion on error reporting. Furthermore, there are no objections from community members. I can also point that Yashied has maintained the code, frequently added functionality and kept a neat record of script versions. The chm documentation and examples are complete, practical and illustrating. I have tested a few functions and in a matter of minutes found enormous benefits and enhancements. Not to mention that I found a solution to a resource issue that has been bugging me for days... but that's off the point. I must agree here that the reason for this not being fully incorporated to Autoit is, as Yashied pointed out at the outset, "unknown". Again, thank you and well done! Think out of the boxGrabber: Yet another WinInfo tool_CSVLib (still alpha)Dynamic html in au3
Mat Posted September 23, 2010 Posted September 23, 2010 It's size probably doesn't help. This thing is huge. AutoIt Project Listing
pierrotm777 Posted September 23, 2010 Posted September 23, 2010 It's a great job. Thanks for this share
Ascend4nt Posted September 23, 2010 Posted September 23, 2010 Re: Including this as a Standard UDF:I agree with Mat about the size. It absolutely *needs* to be split into separate files. Plus, the standard UDF's have a mostly-standardized form of calling them, where the type of the function being performed comes before the rest of the function name. (_Date_Time, _Mem, _Net, _Security, _Timer etc).That's my major gripe with this all-in-one module thinking. It is far too large, and besides the problem of it all being jumbled into one file, I believe its far easier to find the type of function you would need more easily using MSDN or Google. I don't see any structure in the Help file either. '_WinAPI_*' doesn't do anything for me, and while I've often used similar conventions for some functions in the past, I seriously try to avoid doing that anymore unless I can't think of a category, or just don't have anything related to that category.Other things that didn't agree with me the last time I looked over it:- There's a lot of internal function calls, unnecessary variable checking or 'fixing' (like operations involving paths will call PathCanonicalize or something similar). Most all standard AutoIt UDF's don't bother check parameters and just jump right to the DLLCall.- Type safety - I've seen areas the last time I looked where functions aren't x64 safe, and I wasn't about to go checking every single function and reporting on them.- Error returns - there's no standards for them. But this is actually typical of AutoIt UDF's so it wouldn't affect the feasibility of including them. I just prefer a standard return scheme in my own UDF's.And hmm.. I can't recall, but I believe I disagreed with the parameter form for some functions. But that's just a small personal preference also - I mean seriously, think about '_IsPressed()' - who's bright idea was it to require a STRING to be passed to a function that must then convert it into a number? Seems moronic to me.Lastly, and this is my main thing.. why include *every* single API function that there is for Windows. Seriously - why? The UDF will probably continue to grow past its already massive size 'just because' there's another API function in Windows he missed. I know the whole point of the UDF is basically 'every API call for Windows'.. but I still don't get it. Most all API functions are documented well enough out there, and DLLCall doesn't have to be wrapped for every little thing.If I personally need something, I can easily code any API function myself, which is what I currently do. All I need is MSDN. When I feel I have a number of functions that relate to a certain theme, I'll create a UDF, sure - but I'll also create a standardized interface for calling them.Blah.. I'm not trying to bash Yashied here. I actually know that he's put a LOT of effort into this and it is to be applauded for sure, especially with included example code and a Help file to boot! I just don't see how it could ever be included in AutoIt as it is, and I certainly don't have or see a use for it myself.HOWEVER, having said that though, I will say this:For newbs, I can see this as being quite helpful. That is its one saving grace and why I'll occasionally tell people to check this out. For people that have no clue about DLLStruct's and DLLCall's, this is probably as great a place to start learning about it as any.Additionally, with examples included - it might open people's eyes as to what certain API calls really accomplish.So yes - I think this UDF is awesome, as is Yashied for putting so much effort into it. But for it to be included in AutoIt UDF's, not gonna happen any time soon. My contributions: Performance Counters in Windows - Measure CPU, Disk, Network etc Performance | Network Interface Info, Statistics, and Traffic | CPU Multi-Processor Usage w/o Performance Counters | Disk and Device Read/Write Statistics | Atom Table Functions | Process, Thread, & DLL Functions UDFs | Process CPU Usage Trackers | PE File Overlay Extraction | A3X Script Extract | File + Process Imports/Exports Information | Windows Desktop Dimmer Shade | Spotlight + Focus GUI - Highlight and Dim for Eyestrain Relief | CrossHairs (FullScreen) | Rubber-Band Boxes using GUI's (_GUIBox) | GUI Fun! | IE Embedded Control Versioning (use IE9+ and HTML5 in a GUI) | Magnifier (Vista+) Functions UDF | _DLLStructDisplay (Debug!) | _EnumChildWindows (controls etc) | _FileFindEx | _ClipGetHTML | _ClipPutHTML + ClipPutHyperlink | _FileGetShortcutEx | _FilePropertiesDialog | I/O Port Functions | File(s) Drag & Drop | _RunWithReducedPrivileges | _ShellExecuteWithReducedPrivileges | _WinAPI_GetSystemInfo | dotNETGetVersions | Drive(s) Power Status | _WinGetDesktopHandle | _StringParseParameters | Screensaver, Sleep, Desktop Lock Disable | Full-Screen Crash Recovery Wrappers/Modifications of others' contributions: _DOSWildcardsToPCRegEx (original code: RobSaunder's) | WinGetAltTabWinList (original: Authenticity) UDF's added support/programming to: _ExplorerWinGetSelectedItems | MIDIEx UDF (original code: eynstyne) (All personal code/wrappers centrally located at Ascend4nt's AutoIT Code)
Yashied Posted September 23, 2010 Author Posted September 23, 2010 (edited) I tried to include into this UDF only basic functions. I have not touched on topics such as GDI+, DirectX, Networking, and many, many others. This is really a separate topics and separate UDF. Split WinAPIEx into pieces will be quite problematic. Will needs to duplicate many functions, for example, _WinAPI_CloseHandle(), _WinAPI_DeleteObject(), etc., or to include other UDFs. Anyway, if I split WinAPIEx, for example, WinAPIEx1, WinAPIEx2, etc. then many the ready-made programs will begin with the following lines. #Include <WinAPIEx1.au3> #Include <WinAPIEx2.au3> ... #Include <WinAPIExN.au3> This would be similar to the situation with a GUI. If I were to include in my project the small GUI, begin to multiply #Include... #Include <Constants.au3> #Include <EditConstants.au3> #Include <FontConstants.au3> #Include <GUIButton.au3> #Include <GUIComboBox.au3> #Include <GUIConstantsEx.au3> #Include <GUIImageList.au3> #Include <GUIListView.au3> #Include <GUIMenu.au3> #Include <GUITreeView.au3> #Include <MenuConstants.au3> #Include <StaticConstants.au3> #Include <WindowsConstants.au3> It's very inconvenient. '_WinAPI_*' doesn't do anything for me, and while I've often used similar conventions for some functions in the past, I seriously try to avoid doing that anymore unless I can't think of a category, or just don't have anything related to that category. Do you often look for functions in the MSDN by categories? Even in MSDN changed several times a categories. Though perhaps it needs be done in documentation. There's a lot of internal function calls, unnecessary variable checking or 'fixing'... Only where it's really necessary. Most all API functions are documented well enough out there, and DLLCall doesn't have to be wrapped for every little thing. It's a trancexx's programming style. I think the code which consist only of the DllCall() functions, not a good idea to general perceptions, and debug programs. Though, it's a private matter. Thanks to all for your comments. P.S Ascend4nt, we are software developers (I think), and we each have their own preferences regarding the code design, methods of it writing, etc. So it should be. Glad to see you again. Edited September 23, 2010 by Yashied My UDFs: iKey | FTP Uploader | Battery Checker | Boot Manager | Font Viewer | UDF Keyword Manager | Run Dialog Replacement | USBProtect | 3D Axis | Calculator | Sleep | iSwitcher | TM | NetHelper | File Types Manager | Control Viewer | SynFolders | DLL Helper Animated Tray Icons UDF Library | Hotkeys UDF Library | Hotkeys Input Control UDF Library | Caret Shape UDF Library | Context Help UDF Library | Most Recently Used List UDF Library | Icons UDF Library | FTP UDF Library | Script Communications UDF Library | Color Chooser UDF Library | Color Picker Control UDF Library | IPHelper (Vista/7) UDF Library | WinAPI Extended UDF Library | WinAPIVhd UDF Library | Icon Chooser UDF Library | Copy UDF Library | Restart UDF Library | Event Log UDF Library | NotifyBox UDF Library | Pop-up Windows UDF Library | TVExplorer UDF Library | GuiHotKey UDF Library | GuiSysLink UDF Library | Package UDF Library | Skin UDF Library | AITray UDF Library | RDC UDF Library Appropriate path | Button text color | Gaussian random numbers | Header's styles (Vista/7) | ICON resource enumeration | Menu & INI | Tabbed string size | Tab's skin | Pop-up circular menu | Progress Bar without animation (Vista/7) | Registry export | Registry path jumping | Unique hardware ID | Windows alignment More...
Mat Posted September 23, 2010 Posted September 23, 2010 Of course obfuscator will strip unused functions if you ask nicely... AutoIt Project Listing
Yashied Posted September 23, 2010 Author Posted September 23, 2010 For information. If you use Aut2Exe with UPX, inclusion the WinAPIEx UDF adds only ~150 KB. My UDFs: iKey | FTP Uploader | Battery Checker | Boot Manager | Font Viewer | UDF Keyword Manager | Run Dialog Replacement | USBProtect | 3D Axis | Calculator | Sleep | iSwitcher | TM | NetHelper | File Types Manager | Control Viewer | SynFolders | DLL Helper Animated Tray Icons UDF Library | Hotkeys UDF Library | Hotkeys Input Control UDF Library | Caret Shape UDF Library | Context Help UDF Library | Most Recently Used List UDF Library | Icons UDF Library | FTP UDF Library | Script Communications UDF Library | Color Chooser UDF Library | Color Picker Control UDF Library | IPHelper (Vista/7) UDF Library | WinAPI Extended UDF Library | WinAPIVhd UDF Library | Icon Chooser UDF Library | Copy UDF Library | Restart UDF Library | Event Log UDF Library | NotifyBox UDF Library | Pop-up Windows UDF Library | TVExplorer UDF Library | GuiHotKey UDF Library | GuiSysLink UDF Library | Package UDF Library | Skin UDF Library | AITray UDF Library | RDC UDF Library Appropriate path | Button text color | Gaussian random numbers | Header's styles (Vista/7) | ICON resource enumeration | Menu & INI | Tabbed string size | Tab's skin | Pop-up circular menu | Progress Bar without animation (Vista/7) | Registry export | Registry path jumping | Unique hardware ID | Windows alignment More...
linus Posted September 23, 2010 Posted September 23, 2010 ... If I personally need something, I can easily code any API function myself, ...... not dealing with API functions every day maybe I could, but why figure out on myself when it's provided ready to use with nice help/example ... From this point, size of UDF doesn't really matter, only nice-to-have (and time saving) would be division of the help file into categories.
Ascend4nt Posted September 23, 2010 Posted September 23, 2010 Split WinAPIEx into pieces will be quite problematic. Will needs to duplicate many functions, for example, _WinAPI_CloseHandle(), _WinAPI_DeleteObject(), etc., or to include other UDFs. Anyway, if I split WinAPIEx, for example, WinAPIEx1, WinAPIEx2, etc. then many the ready-made programs will begin with the following lines. #Include <WinAPIEx1.au3> #Include <WinAPIEx2.au3> ... #Include <WinAPIExN.au3>With CloseHandle/DeleteObject etc, you can always have a 'base' include that includes the most common API calls in it. I wouldn't name the separate modules as numbers, as that's just plain confusing. This is where categories would make sense. However, even if you were to do 'WinAPIEx_User32' or 'WinAPIEx_Kernel32', you could cut it down in some pieces. Of course, the problem with that though is that Microsoft spreads common 'categories' across multiple DLL's (GUI elements functions can be found in I believe 3 separate DLL's). Perhaps at the minimum you could separate constants out.. but those are probably used inside the functions. Do you often look for functions in the MSDN by categories? Even in MSDN changed several times a categories. Though perhaps it needs be done in documentation.No, of course not - MSDN isn't very consistent. I can usually find what I'm looking for within one or two searches though. Naming your own functions with categories may be a huge inconvenience, no doubt, but it would be a great approach IMO. It would suck for those that are already using your UDF though lol. But this is, as you point out, personal preference. Still - it would carry weight if you were to do that and ask for it to be included as a set of standard UDF's. It's a trancexx's programming style. I think the code which consist only of the DllCall() functions, not a good idea to general perceptions, and debug programs. Though, it's a private matter.Indeed, I would feel better if the standard UDF's had at least *minimal* parameter/return checking - however, like a number of built-in functions, debugging lies with the programmer. At least, that's my theory on the standard UDF's. Still - I hate that some functions return values that pass tests like 'IsPtr()' when in fact the API call returned a 0 result, and 0 is certainly an invalid pointer. Things like that still bother me with the standard API's. On a whole, I agree this stuff is really personal preference. I was just trying to view it from the perspective of it being included in the AutoIt standard UDF's. With the standard UDF's, the burden of checking/debugging things is on the programmer, but with UDF's like mine or yours, we include some parameter checking. To what extent those parameters should be tested is based on our programming styles I suppose. Anyway, I do see this UDF as a very nice community contribution, and obviously something you've worked very hard on. I also see people getting much use out of, so its definitely a big help to others. I'll probably continue to point newbs to this UDF as it would save them alot of time, in addition to giving them some insight into what things do. So while I may have my reservations about things (especially about the possibility of it being added to AutoIt), I do acknowledge that its a great UDF to be recommended to others. Keep up the good work Yashied. @Mat: If any UDF there ever was to require it, this is certainly the one to use the 'strip' Obfuscation compile-time option on. I would also recommend allowing function renaming with the '/om' option to shrink it down further. ~150KB on disk, while not huge, is still to me more than is needed. Plus we can't forget that in-memory requirements will be different, as probably would execution-time. AutoIt has to of course parse through all that stuff AND store it in memory somehow. My contributions: Performance Counters in Windows - Measure CPU, Disk, Network etc Performance | Network Interface Info, Statistics, and Traffic | CPU Multi-Processor Usage w/o Performance Counters | Disk and Device Read/Write Statistics | Atom Table Functions | Process, Thread, & DLL Functions UDFs | Process CPU Usage Trackers | PE File Overlay Extraction | A3X Script Extract | File + Process Imports/Exports Information | Windows Desktop Dimmer Shade | Spotlight + Focus GUI - Highlight and Dim for Eyestrain Relief | CrossHairs (FullScreen) | Rubber-Band Boxes using GUI's (_GUIBox) | GUI Fun! | IE Embedded Control Versioning (use IE9+ and HTML5 in a GUI) | Magnifier (Vista+) Functions UDF | _DLLStructDisplay (Debug!) | _EnumChildWindows (controls etc) | _FileFindEx | _ClipGetHTML | _ClipPutHTML + ClipPutHyperlink | _FileGetShortcutEx | _FilePropertiesDialog | I/O Port Functions | File(s) Drag & Drop | _RunWithReducedPrivileges | _ShellExecuteWithReducedPrivileges | _WinAPI_GetSystemInfo | dotNETGetVersions | Drive(s) Power Status | _WinGetDesktopHandle | _StringParseParameters | Screensaver, Sleep, Desktop Lock Disable | Full-Screen Crash Recovery Wrappers/Modifications of others' contributions: _DOSWildcardsToPCRegEx (original code: RobSaunder's) | WinGetAltTabWinList (original: Authenticity) UDF's added support/programming to: _ExplorerWinGetSelectedItems | MIDIEx UDF (original code: eynstyne) (All personal code/wrappers centrally located at Ascend4nt's AutoIT Code)
ivan Posted September 26, 2010 Posted September 26, 2010 (edited) Linus is the first one to place a strong objection. I personally think that a run time memory increase is a small price to pay for greater functionality, depending on what your program does. It definitely cuts down on developing time, and for this I'm quite grateful. I'm quite honest here and admit that it would take me ages to write a single function in this library, so to me, it's significantly useful. I'm probably more concerned with whether using it accomplishes a particular job, but then this is practical thinking. I must say, I've only started looking at this script and in a relatively short time I have learned lots from it. Anyway, if you plan to abuse resource (mem + processor) usage by embedding lots of objects (browsers, multimedia players, power point, to mention a few) you're asking for trouble, in which case you should watch it. Otherwise, loading this library will never reach a fraction of the resource usage of embedding a browser object in a gui. With this I mean to point out that a discussion of resource usage is only relevant with a specific program in mind. If you were to account the number of functions in the script you should probably add those in the WinAPI.au3 while you're at it, since this lib already includes it: #Include <WinAPI.au3> On the other hand, I have found that reading this script is painful. I'd probably start with a little suggestion for a split, if this is feasible, move: #Region Global Variables and Constants ...... #EndRegion Global Variables and Constants to a "WinAPIEx_VARS.au3" file. In any case, the decision on whether this is included in Autoit is not up to me. This really is down to the good judgement of the autoit team. Ivan Edited September 26, 2010 by ivan Think out of the boxGrabber: Yet another WinInfo tool_CSVLib (still alpha)Dynamic html in au3
131738 Posted September 27, 2010 Posted September 27, 2010 (edited) _WinAPI_GetConnectedDlg -------------------------------------------------------------------------------- Launches the Get Connected wizard within the calling application to enable network connectivity. _WinAPI_GetConnectedDlg ( $iDlg [, $iFlags [, $hParent]] ) $iDlg - Specifies which the dialog should be launched, valid values: |0 - Local area network connectivity. |1 - Internet connectivity. |2 - Virtual private network (VPN) connectivity. ********************************************************* _WinAPI_PathRelativePathTo Return Value Success - Failure - Empty string and sets the @error flag to non-zero. Edited September 27, 2010 by 131738
Yashied Posted September 27, 2010 Author Posted September 27, 2010 _WinAPI_GetConnectedDlg -------------------------------------------------------------------------------- Launches the Get Connected wizard within the calling application to enable network connectivity. _WinAPI_GetConnectedDlg ( $iDlg [, $iFlags [, $hParent]] ) $iDlg - Specifies which the dialog should be launched, valid values: |0 - Local area network connectivity. |1 - Internet connectivity. |2 - Virtual private network (VPN) connectivity. And what? _WinAPI_PathRelativePathTo Return Value Success - Failure - Empty string and sets the @error flag to non-zero. OK. My UDFs: iKey | FTP Uploader | Battery Checker | Boot Manager | Font Viewer | UDF Keyword Manager | Run Dialog Replacement | USBProtect | 3D Axis | Calculator | Sleep | iSwitcher | TM | NetHelper | File Types Manager | Control Viewer | SynFolders | DLL Helper Animated Tray Icons UDF Library | Hotkeys UDF Library | Hotkeys Input Control UDF Library | Caret Shape UDF Library | Context Help UDF Library | Most Recently Used List UDF Library | Icons UDF Library | FTP UDF Library | Script Communications UDF Library | Color Chooser UDF Library | Color Picker Control UDF Library | IPHelper (Vista/7) UDF Library | WinAPI Extended UDF Library | WinAPIVhd UDF Library | Icon Chooser UDF Library | Copy UDF Library | Restart UDF Library | Event Log UDF Library | NotifyBox UDF Library | Pop-up Windows UDF Library | TVExplorer UDF Library | GuiHotKey UDF Library | GuiSysLink UDF Library | Package UDF Library | Skin UDF Library | AITray UDF Library | RDC UDF Library Appropriate path | Button text color | Gaussian random numbers | Header's styles (Vista/7) | ICON resource enumeration | Menu & INI | Tabbed string size | Tab's skin | Pop-up circular menu | Progress Bar without animation (Vista/7) | Registry export | Registry path jumping | Unique hardware ID | Windows alignment More...
Recommended Posts
Create an account or sign in to comment
You need to be a member in order to leave a comment
Create an account
Sign up for a new account in our community. It's easy!
Register a new accountSign in
Already have an account? Sign in here.
Sign In Now