Sample code for 30+ languages & platforms
Delphi ActiveX

Ftp2 Debug Log File Path

See more FTP Examples

Demonstrates how to use the DebugLogFilePath property to get information if a Chilkat method crashes or hangs.

Chilkat Delphi ActiveX Downloads

Delphi ActiveX
uses
    Winapi.Windows, Winapi.Messages, System.SysUtils, System.Variants, System.Classes, Vcl.Graphics,
    Vcl.Controls, Vcl.Forms, Vcl.Dialogs, Vcl.StdCtrls, Chilkat_TLB;

...

procedure TForm1.Button1Click(Sender: TObject);
var
success: Integer;
ftp: TChilkatFtp2;
remoteFilePath: WideString;
localFilePath: WideString;

begin
success := 0;

ftp := TChilkatFtp2.Create(Self);

// ...
// ...

// Insert this code just before the method call that crashes or hangs.
ftp.VerboseLogging := 1;
ftp.DebugLogFilePath := '/some/file/path/sftp_debug_log.txt';

// Make the call that crashes or hangs,
// for example, if the method is PutFile:

remoteFilePath := '...';
localFilePath := '...';
success := ftp.PutFile(localFilePath,remoteFilePath);

// Note: If the method returns control to your application code, then it did not crash within Chilkat.
// The DebugLogFilePath property causes all information that would be recorded in the LastErrorText to be emitted to the
// log file (with immediate file write flushing, i.e. no buffering).  Thus, in a crash situation,
// the log file will contain information up to the point of the crash.

if (success = 0) then
  begin
    Memo1.Lines.Add(ftp.LastErrorText);
    Exit;
  end;
end;