Swift
Swift
Iterate Through Matching ZIP Entries Using EntryMatching and ZipEntry.GetNextMatch
See more Zip Examples
This example demonstrates how to iterate through ZIP entries matching a wildcard pattern using:
-
Zip.EntryMatchingto obtain the first matching entry -
ZipEntry.GetNextMatchto advance to subsequent matching entries
The wildcard character * matches zero or more characters. Matching is performed against the full stored ZIP entry path.
The example searches for all entries beneath the docs/ directory.
Suppose the ZIP archive contains:
docs/
docs/readme.txt
docs/manual.pdf
docs/sub1/notes.txt
images/logo.png
hello.txt The wildcard pattern:
docs/* Matches:
docs/
docs/readme.txt
docs/manual.pdf
docs/sub1/notes.txt Note that ZIP archives may optionally contain separate directory entries. Therefore, the first matching entry may be the directory entry docs/ rather than a file entry.
Chilkat Swift Downloads
func chilkatTest() {
var success: Bool = false
let zip = CkoZip()!
// Open an existing ZIP archive.
success = zip.open(zipPath: "c:/temp/sample.zip")
if success == false {
print("\(zip.lastErrorText!)")
return
}
// ------------------------------------------------------------
// Find the first ZIP entry matching the wildcard pattern:
//
// docs/*
//
// Matching is performed against the full stored ZIP path.
//
let entry = CkoZipEntry()!
success = zip.entry(matching: "docs/*", entry: entry)
if success == false {
print("No matching entries found.")
zip.close()
return
}
// ------------------------------------------------------------
// Iterate through all matching entries.
//
// GetNextMatch updates the same ZipEntry object so that
// it represents the next matching entry.
//
while (success == true) {
if entry.isDirectory == true {
print("[Directory] \(entry.fileName!)")
}
else {
print("[File] \(entry.fileName!)")
}
// Advance to the next matching entry.
success = entry.getNextMatch(pattern: "docs/*")
}
zip.close()
print("Done.")
}