Sample code for 30+ languages & platforms
Tcl

Restart/Resume FTP Upload

See more FTP Examples

Demonstrates how to restart / resume an FTP upload.

Chilkat Tcl Downloads

Tcl

load ./chilkat.dll

set success 0

# This example requires the Chilkat API to have been previously unlocked.
# See Global Unlock Sample for sample code.

set ftp [new_CkFtp2]

CkFtp2_put_Hostname $ftp "ftp.example.com"
CkFtp2_put_Username $ftp "login"
CkFtp2_put_Password $ftp "password"

# Connect and login to the FTP server.
set success [CkFtp2_Connect $ftp]
if {$success != 1} then {
    puts [CkFtp2_lastErrorText $ftp]
    delete_CkFtp2 $ftp
    exit
}

# Change to the remote directory where the file will be uploaded.
set success [CkFtp2_ChangeRemoteDir $ftp "temp"]
if {$success != 1} then {
    puts [CkFtp2_lastErrorText $ftp]
    delete_CkFtp2 $ftp
    exit
}

# In this example, assume that a previous FTP upload failed,
# and the incomplete file (bigFile.zip) exists on the FTP server.
# You only need to set the RestartNext property to resume
# the upload.  When RestartNext is set, the next call
# to PutFile (or PutFileFromBinaryData, PutFileFromTextData)
# will automatically resume the upload from the point of failure.
# (The way it works is that the FTP component sends a "SIZE"
# command to the FTP server to find out how many bytes of
# the file already exist on the server.  It then begins
# uploading from that point.

# Note: After PutFile is called, the RestartNext property
# is automatically set to false.
CkFtp2_put_RestartNext $ftp 1

# Upload a file with restart.
set localFilename "bigFile.zip"
set remoteFilename "bigFile.zip"

set success [CkFtp2_PutFile $ftp $localFilename $remoteFilename]
if {$success != 1} then {
    puts [CkFtp2_lastErrorText $ftp]
    delete_CkFtp2 $ftp
    exit
}

set success [CkFtp2_Disconnect $ftp]

puts "File Uploaded!"

delete_CkFtp2 $ftp