ViciousXUSMC Posted August 5, 2014 Posted August 5, 2014 Most specifically I am wondering about DirRemove() In my use it seems like it will start the deletion process and instantly move onto the next line of code even if the computer still has a good while to go before it has actually deleted all of the files. The other commands of similar feature that I also wondered about are. DirCopy() DirMove() FileCopy() FileMove() FileDelete() It seems to me the copy/move commands do wait but the delete commands I think do not. Just looking for verification so I know if I need to add some extra code to account for waiting on the machine to finish a process before trying to work with that file space. I have searched and there is a thread just like this almost already but nobody actually answered the question just came up with some code that could work around the problem if it did exist. Plus AutoIT is always changing how it works, some of those older threads are not even accurate compared to the newer versions we have now. Thanks Guys,
Bert Posted August 5, 2014 Posted August 5, 2014 You could simply put in loops to verify the command ran and have the loop be in effect until the command is complete The Vollatran project My blog: http://www.vollysinterestingshit.com/
ViciousXUSMC Posted August 5, 2014 Author Posted August 5, 2014 Yes there is bound to be 100 different ways to code it to work around it. But I want to know how the function is supposed to operate out of box. My largest "hunch" right now is that in many cases say you were deleting a folder with 10GB of info. The folder may disappear in 5 seconds but the drive may be doing "background" tasks to finish off all that data deletion for the next 20 seconds. So if you were trying to call a loop to check for the folder it may appear as if its gone but if you tried to work with that file space and install something the installer will fail and tell you that files are on the disk and ask to overwrite. Perhaps once the question is answered we can discuss some ways to script a good and easy work around. I imagine loops or a simple if fileexsist() are easy solutions, if my theory above is true about waiting on "invisible" tasks it may be best to go cave man style and simply Sleep()
guinness Posted August 5, 2014 Posted August 5, 2014 The next line in your script won't be completed until DirRemove() has done its job, just like most native/UDF functions. So on to the workarounds. 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
ViciousXUSMC Posted August 5, 2014 Author Posted August 5, 2014 Well then if it wont move on until its done, we would not need a work around correct? I am only going by memory but I remember doing an Oracle install and using DirRemove() to take out the old install because if I tried to repair an installation and install over it I would get dozens of additional windows at random asking me to overwrite the old files. Originally just throwing in DirRemove() by itself, I seem to recall getting some issues with the installer failing after because part of the deletion process was still in use. But I was in a pinch working fast and long hours, put Sleep() in there as the easy fix and have not had issues since. Deciding now to revisit it so I can perfect my methods.
guinness Posted August 5, 2014 Posted August 5, 2014 Well then if it wont move on until its done, we would not need a work around correct? Well I don't need a workaround, I thought you do? 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
computergroove Posted August 5, 2014 Posted August 5, 2014 I can't see a good reason not to put in @error If statements after all of these if it's mission critical to the program running. I am really curious to know why it is important to delete a folder super fast. What if it takes 2 seconds? Get Scite to add a popup when you use a 3rd party UDF -> http://www.autoitscript.com/autoit3/scite/docs/SciTE4AutoIt3/user-calltip-manager.html
jchd Posted August 5, 2014 Posted August 5, 2014 There are some cases where a computer is lying to you. The most common is the disk subsystem lying to the OS, returning a "Done" status while in fact the data supposedly written still hasn't reached the magnetic or solid-state media safely and in full. Typical consumer-grade disks lie thusly, sacrifying integrity to speed. A corollary of slightly higher level is the command queuing and reordering by the disk firmware and cache. One level higher, there is the OS (and admin) allowing a write cache. The data and commands stored there are not even passed yet to the disk firmware. What you observe is yet another level of OS lie: a complex filesystem operation is requested and after acceptance a "Done" status is returned to the caller. It's really hard to protect agains such multi-level lies over which you can have little or no control, short of using subsequent and reliable mean to check that the requested action has indeed taken place. The term "reliable mean" is important: reaing back some cache means nothing! In all cases you can't guard against the disk firmware lying to you except if you use exclusively serious server-grade hardware (disks + controller) allowing control over disk write cache setting, (i.e. not all) AND accept the huge accompanying disk subsystem slowdown. These issues are of premium significance to databases engines, which are compelled to perform ACID transactions. This wonderful site allows debugging and testing regular expressions (many flavors available). An absolute must have in your bookmarks.Another excellent RegExp tutorial. Don't forget downloading your copy of up-to-date pcretest.exe and pcregrep.exe hereRegExp tutorial: enough to get startedPCRE v8.33 regexp documentation latest available release and currently implemented in AutoIt beta. SQLitespeed is another feature-rich premier SQLite manager (includes import/export). Well worth a try.SQLite Expert (freeware Personal Edition or payware Pro version) is a very useful SQLite database manager.An excellent eBook covering almost every aspect of SQLite3: a must-read for anyone doing serious work.SQL tutorial (covers "generic" SQL, but most of it applies to SQLite as well)A work-in-progress SQLite3 tutorial. Don't miss other LxyzTHW pages!SQLite official website with full documentation (may be newer than the SQLite library that comes standard with AutoIt)
computergroove Posted August 5, 2014 Posted August 5, 2014 That was super deep. If there is a high level of importance for this then all the more reason to put in @error loops. Get Scite to add a popup when you use a 3rd party UDF -> http://www.autoitscript.com/autoit3/scite/docs/SciTE4AutoIt3/user-calltip-manager.html
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