Delphi DLL
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
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;