Chilkat HOME Android™ AutoIt C C# C++ Chilkat2-Python CkPython Classic ASP DataFlex Delphi DLL Go Java Node.js Objective-C PHP Extension Perl PowerBuilder PowerShell PureBasic Ruby SQL Server Swift Tcl Unicode C Unicode C++ VB.NET VBScript Visual Basic 6.0 Visual FoxPro Xojo Plugin
(AutoIt) Async FTP Progress InfoDemonstrates checking for progress info updates when running a task asynchronously. This example demonstrates an FTP download.
; This example assumes the Chilkat API to have been previously unlocked. ; See Global Unlock Sample for sample code. $oFtp = ObjCreate("Chilkat.Ftp2") $oFtp.Hostname = "ftp.someFtpServer.com" Local $bSuccess = $oFtp.ConnectOnly() If ($bSuccess <> True) Then ConsoleWrite($oFtp.LastErrorText & @CRLF) Exit EndIf $oFtp.Username = "myLogin" $oFtp.Password = "myPassword" $bSuccess = $oFtp.LoginAfterConnectOnly() If ($bSuccess <> True) Then ConsoleWrite($oFtp.LastErrorText & @CRLF) Exit EndIf ; Change to the remote directory where the file is located. ; This step is only necessary if the file is not in the root directory ; for the FTP account. $bSuccess = $oFtp.ChangeRemoteDir("someRemoteDirectory") If ($bSuccess <> True) Then ConsoleWrite($oFtp.LastErrorText & @CRLF) Exit EndIf Local $sLocalFilename = "/temp/romeo.xml" Local $sRemoteFilename = "romeo.xml" ; -------------------- ; Download a file ; -------------------- ; Call the async version of the GetFile method to return a task object. ; The task object is loaded, but is in the Inert state -- meaning it is ; not yet scheduled to run on Chilkat's background thread pool. Local $oTask = $oFtp.GetFileAsync($sRemoteFilename,$sLocalFilename) If ($oFtp.LastMethodSuccess = False) Then ConsoleWrite($oFtp.LastErrorText & @CRLF) Exit EndIf ; Before starting the task, tell it to keep an in-memory log of what would've been ; ProgressInfo callbacks. $oTask.KeepProgressLog = True ; Schedule the task for running on the thread pool. This changes the task's state ; from Inert to Live. $bSuccess = $oTask.Run() If ($bSuccess <> True) Then ConsoleWrite($oTask.LastErrorText & @CRLF) Exit EndIf ; The application is now free to do anything else ; while the file is being downloaded. ; For this example, we'll simply sleep and periodically ; check to see if the download is finished, and report the progress ; along the way. Local $iCurPctDone = 0 Local $sName Local $sValue While $oTask.Finished <> True If ($oTask.PercentDone <> $iCurPctDone) Then $iCurPctDone = $oTask.PercentDone ConsoleWrite($iCurPctDone & " percent done" & @CRLF) EndIf ; Check the progress info log. ; Emit any log entries.. While ($oTask.ProgressLogSize > 0) ; Get the 1st entry, emit it, and then remove it.. $sName = $oTask.ProgressInfoName(0) $sValue = $oTask.ProgressInfoValue(0) ; Entries reporting the received byte count will have the name "RcvByteCount" ; Entries reporting the current bytes-per-second will have the name "RcvBytesPerSec" ConsoleWrite($sName & ": " & $sValue & @CRLF) $oTask.RemoveProgressInfo 0 Wend ; Sleep 100 ms. $oTask.SleepMs 100 Wend ; Just in case there are any remaining entries... While ($oTask.ProgressLogSize > 0) ; Get the 1st entry, emit it, and then remove it.. $sName = $oTask.ProgressInfoName(0) $sValue = $oTask.ProgressInfoValue(0) ConsoleWrite($sName & ": " & $sValue & @CRLF) $oTask.RemoveProgressInfo 0 Wend ; A finished task could be one that was canceled, aborted, or truly finished. ; If the task was "canceled", it was canceled prior to actually starting. This could ; happen if the task was canceled while waiting in a thread pool queue to be scheduled by Chilkat's ; background thread pool scheduler. ; If the task was "aborted", it indicates that it was canceled while running in a background thread. ; The ResultErrorText will likely indicate that the task was aborted. ; If the task "completed", then it ran to completion, but the actual success/failure of the method ; is determined by the result obtained via a GetResult* method. (A "completed" task will ; have a StatusInt equal to 7. If the task finished, but was not completed, then it must've ; been aborted or canceled: If ($oTask.StatusInt <> 7) Then ConsoleWrite("Task did not complete." & @CRLF) ConsoleWrite("task status: " & $oTask.Status & @CRLF) Exit EndIf ; The GetFile method returns a boolean. Therefore, after the task is finished, ; we can get the boolean result by calling GetResultBool. This is the return value had ; we called GetFile synchronously. $bSuccess = $oTask.GetResultBool() If ($bSuccess <> True) Then ; The task's ResultErrorText contains what would have been in the LastErrorText property had ; the GetFile method been called synchronously. ConsoleWrite($oTask.ResultErrorText & @CRLF) Else ConsoleWrite("File downloaded asynchronously." & @CRLF) EndIf $bSuccess = $oFtp.Disconnect() |
© 2000-2025 Chilkat Software, Inc. All Rights Reserved.