Sample code for 30+ languages & platforms
DataFlex

Control Stored ZIP Paths Using AppendFromDir

See more Zip Examples

This example demonstrates how to use the AppendFromDir property to control which portion of a local filesystem path is stored within a ZIP archive.

When files are added using methods such as AppendFiles, AppendFilesEx, or AddFile, the stored ZIP path is determined relative to the AppendFromDir directory.

This property is especially useful when:

  • Creating ZIP archives with clean relative paths
  • Excluding unwanted leading directory portions from ZIP entries
  • Packaging projects or directory trees while preserving selected relative path information

Suppose the local filesystem contains:

c:/abc/123/myAppDir/readme.txt
c:/abc/123/myAppDir/config/settings.json
c:/abc/123/myAppDir/images/logo.png

And suppose:

zip.AppendFromDir = "c:/abc/123";

Then the following call:

zip.AppendFiles("c:/abc/123/myAppDir/*",_TRUE_);

Will store these paths in the ZIP archive:

myAppDir/readme.txt
myAppDir/config/settings.json
myAppDir/images/logo.png

Without AppendFromDir, the ZIP archive paths would instead begin relative to the append root:

readme.txt
config/settings.json
images/logo.png

The AppendFromDir property affects subsequently added filesystem entries.

Chilkat DataFlex Downloads

DataFlex
Use ChilkatAx-win32.pkg

Procedure Test
    Boolean iSuccess
    Handle hoZip
    Boolean iRecurse
    String sTemp1

    Move False To iSuccess

    Get Create (RefClass(cComChilkatZip)) To hoZip
    If (Not(IsComObjectCreated(hoZip))) Begin
        Send CreateComObject of hoZip
    End

    // Create a new ZIP archive.
    Get ComNewZip Of hoZip "myApp.zip" To iSuccess
    If (iSuccess = False) Begin
        Get ComLastErrorText Of hoZip To sTemp1
        Showln sTemp1
        Procedure_Return
    End

    // Set the AppendFromDir property.
    // 
    // Paths stored in the ZIP archive will be relative to:
    // 
    //     c:/abc/123
    // 
    Set ComAppendFromDir Of hoZip To "c:/abc/123"

    // Recursively add files beneath:
    // 
    //     c:/abc/123/myAppDir
    // 
    // Because AppendFromDir = "c:/abc/123",
    // the ZIP paths will begin with:
    // 
    //     myAppDir/
    // 
    Move True To iRecurse
    Get ComAppendFiles Of hoZip "c:/abc/123/myAppDir/*" iRecurse To iSuccess

    If (iSuccess = False) Begin
        Get ComLastErrorText Of hoZip To sTemp1
        Showln sTemp1
        Procedure_Return
    End

    // Write the ZIP archive and close it.
    Get ComWriteZipAndClose Of hoZip To iSuccess
    If (iSuccess = False) Begin
        Get ComLastErrorText Of hoZip To sTemp1
        Showln sTemp1
        Procedure_Return
    End

    Showln "ZIP archive created successfully."


End_Procedure