🗳A library to create, read and modify ZIP archive files, written in Swift.
:name: Zipper
:author: Elias Abel
:author_esc: Elias%20Abel
:mail: [email protected]
:desc: a Effortless ZIP Handling in Swift
:icon: {name}.png
:version: 1.2.0
:na: N/A
:ios: 9.0
:macos: 10.11
:watchos: 2.0
:tvos: 9.0
:linux: with zlib
:xcode: 10.2
:swift: 5
:license: MIT
:sep: %20%7C%20
:platform: iOS{sep}macOS{sep}watchOS{sep}tvOS{sep}Linux
= Meet {name}
{author} <{mail}>
v{version}, 2019-04-16
[subs=“attributes”]
++++
:toc:
== 🏵 Introduction
{name} is {desc}.
== 📋 Requirements
[%header]
|===
2+^m|Type 1+^m|Requirement
1.5+.|Platform ^|iOS ^|{ios}+
^|macOS ^|{macos}
^|tvOS ^|{tvos}
^|watchOS ^|{watchos}
^|Linux ^|{linux}
^|IDE ^|Xcode ^| {xcode}+
^|Language ^|Swift ^| {swift}+
|===
== 📲 Installation
=== CocoaPods
{name}
is available on link:https://cocoapods.org[CocoaPods].
=== Manually
Copy all files in the {name}
directory into your project.
== 🛌 Dependency
{na}
== ❤️ Contribution
You are welcome to fork and submit pull requests.
== 🔖 License
{name}
is open-sourced software, licensed under the link:./LICENSE.md[{license}
] license.
== 🔫 Usage
import {name}
=== Zipping
var archiveURL = currentDirectoryURL.appendPathComponent(“archive.zip”)
var resourcesURL = currentDirectoryURL.appendPathComponent(“directory”)
// zip:
do {
try fileManager.zip(item: resourcesURL, to: archive)
} catch _ {}
// or:
guard let archive = Zipper(url: archiveURL, accessMode: .create) else { return }
do {
try archive.zip(item: resourcesURL)
} catch {
=== Unzipping
var archiveURL = currentDirectoryURL.appendPathComponent(“archive.zip”)
var destinationURL = currentDirectoryURL.appendPathComponent(“directory”)
// unzip:
do {
try fileManager.createDirectory(at: destinationURL, withIntermediateDirectories: true, attributes: nil)
try fileManager.unzip(item: archiveURL, to: destinationURL)
} catch {
}
// or:
guard let archive = Zipper(url: archiveURL, accessMode: .read) else { return }
do {
try archive.unzip(to: destinationURL)
} catch {
=== Accessing individual Entries
var archiveURL = currentDirectoryURL.appendPathComponent(“archive.zip”)
guard let archive = Zipper(url: archiveURL, accessMode: .read) else { return }
guard let entry = archive[“file.txt”] else { return }
var destinationURL = currentDirectoryURL.appendPathComponent(“output.txt”)
do {
try archive.extract(entry, to: destinationURL)
} catch {
=== Adding/Removing Entries
==== Adding:
guard let archive = Zipper(url: archiveURL, accessMode: .update) else { return }
do {
try archive.addEntry(with: fileURL.lastPathComponent, relativeTo: fileURL.deletingLastPathComponent())
} catch {
==== Removing:
guard let entry = archive[“file.txt”] else { return }
do {
try archive.remove(entry)
} catch {