Sample code for 30+ languages & platforms
Delphi DLL

Zip Append Files Verbose Logging

See more Zip Examples

An application can check verbose LastErrorText if the zip.AppendFiles method does not append the expected files, or if it appends nothing.

Chilkat Delphi DLL Downloads

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

...

procedure TForm1.Button1Click(Sender: TObject);
var
success: Boolean;
zip: HCkZip;
recurse: Boolean;

begin
success := False;

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

zip := CkZip_Create();
CkZip_NewZip(zip,'qa_output/test1.zip');

// Turn on verbose logging to get more informaiton in the LastErrorText property.
CkZip_putVerboseLogging(zip,True);

recurse := True;
CkZip_putAppendFromDir(zip,'qa_data/syncTree');
success := CkZip_AppendFiles(zip,'*',recurse);

// Even if AppendFiles is successful, we can examine the LastErrorText property
// to see what happend.  (This is true for all Chilkat methods.  The LastErrorText always
// contains information even when the method call is successful.  If you have a difficult
// time understanding what happened, then turn on VerboseLogging and have a look at it.
// Make sure to turn off VerboseLogging for production because it could slow down your application.)
Memo1.Lines.Add(CkZip__lastErrorText(zip));

// Here is a sample of the LastErrorText for this test:

// ChilkatLog:
//   AppendFiles(62ms):
//     DllDate: Feb 10 2019
//     ChilkatVersion: 9.5.0.76
//     UnlockPrefix: ***
//     Architecture: Little Endian; 64-bit
//     Language: .NET 4.5 / x64 / VS2012
//     VerboseLogging: 1
//     Component successfully unlocked using purchased unlock code.
//     appendFileEx(62ms):
//       FilePattern: *
//       AppendFromDir: qa_data/syncTree
//       PathPrefix: 
//       BaseDir: c:\appData\UnitTest\qa_data\syncTree\
//       InzipBase: 
//       FilenamePart: *
//       IsSpecificFile: 0
//       recurse: 1
//       saveExtraPath: 0
//       archiveOnly: 0
//       includeHidden: 1
//       includeSystem: 1
//       ignoreAccessDenied: 1
//       addFilesMax:
//         addDirNonRecursive:
//           ffWin32OpenDir_fileSpec: [c:\appData\UnitTest\qa_data\syncTree\*]
//           ffWin32OpenDir_fileSpec: [c:\appData\UnitTest\qa_data\syncTree\abc\*]
//           ffWin32OpenDir_fileSpec: [c:\appData\UnitTest\qa_data\syncTree\data\*]
//           ffWin32OpenDir_fileSpec: [c:\appData\UnitTest\qa_data\syncTree\text\*]
//           ffWin32OpenDir_fileSpec: [c:\appData\UnitTest\qa_data\syncTree\abc\ghk\*]
//           ffWin32OpenDir_fileSpec: [c:\appData\UnitTest\qa_data\syncTree\data\xyz\*]
//           ffWin32OpenDir_fileSpec: [c:\appData\UnitTest\qa_data\syncTree\text\something\*]
//         --addDirNonRecursive
//       --addFilesMax
//       No exclusion patterns.
//       numAdded: 20
//     --appendFileEx
//     Success.
//   --AppendFiles
// --ChilkatLog

success := CkZip_WriteZipAndClose(zip);
if (success <> True) then
  begin
    Memo1.Lines.Add(CkZip__lastErrorText(zip));
    Exit;
  end;

CkZip_Dispose(zip);

end;