Sample code for 30+ languages & platforms
Unicode C

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 Unicode C Downloads

Unicode C
#include <C_CkZipW.h>

void ChilkatSample(void)
    {
    BOOL success;
    HCkZipW zip;
    BOOL recurse;

    success = FALSE;

    zip = CkZipW_Create();

    // Create a new ZIP archive.
    success = CkZipW_NewZip(zip,L"myApp.zip");
    if (success == FALSE) {
        wprintf(L"%s\n",CkZipW_lastErrorText(zip));
        CkZipW_Dispose(zip);
        return;
    }

    // Set the AppendFromDir property.
    // 
    // Paths stored in the ZIP archive will be relative to:
    // 
    //     c:/abc/123
    // 
    CkZipW_putAppendFromDir(zip,L"c:/abc/123");

    // Recursively add files beneath:
    // 
    //     c:/abc/123/myAppDir
    // 
    // Because AppendFromDir = "c:/abc/123",
    // the ZIP paths will begin with:
    // 
    //     myAppDir/
    // 
    recurse = TRUE;
    success = CkZipW_AppendFiles(zip,L"c:/abc/123/myAppDir/*",recurse);

    if (success == FALSE) {
        wprintf(L"%s\n",CkZipW_lastErrorText(zip));
        CkZipW_Dispose(zip);
        return;
    }

    // Write the ZIP archive and close it.
    success = CkZipW_WriteZipAndClose(zip);
    if (success == FALSE) {
        wprintf(L"%s\n",CkZipW_lastErrorText(zip));
        CkZipW_Dispose(zip);
        return;
    }

    wprintf(L"ZIP archive created successfully.\n");


    CkZipW_Dispose(zip);

    }