Sample code for 30+ languages & platforms
Unicode C

Create Empty File and Directory Entries in a ZIP

See more Zip Examples

This example demonstrates how to use the AddEmpty method to create both empty directory entries and empty file entries within a ZIP archive.

The example creates:

  • A truly empty directory named emptyDir
  • An empty file named empty.txt located beneath the docs subdirectory

When the ZIP archive is extracted:

  • emptyDir will be created as an empty directory.
  • docs/empty.txt will be created as an empty file under the docs subdirectory.

It is not necessary to explicitly create the docs directory beforehand. The directory structure implied by the file path is created automatically when extracting.

Chilkat Unicode C Downloads

Unicode C
#include <C_CkZipW.h>

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

    success = FALSE;

    zip = CkZipW_Create();

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

    // Add an empty directory entry named "emptyDir".
    success = CkZipW_AddEmpty(zip,TRUE,L"emptyDir");
    if (success == FALSE) {
        wprintf(L"%s\n",CkZipW_lastErrorText(zip));
        CkZipW_Dispose(zip);
        return;
    }

    // Add an empty file entry named "docs/empty.txt".
    success = CkZipW_AddEmpty(zip,FALSE,L"docs/empty.txt");
    if (success == FALSE) {
        wprintf(L"%s\n",CkZipW_lastErrorText(zip));
        CkZipW_Dispose(zip);
        return;
    }

    // Write the ZIP archive to disk 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);

    }