zstandard_ios
The iOS implementation of the zstandard Flutter plugin. Uses FFI and the native Zstandard C library.
Installation
Add the main plugin to your app; this package is included automatically via the federated plugin:
dependencies:
zstandard: ^1.3.29
No extra setup is required for normal use.
Usage
Use the main zstandard API; the iOS implementation is selected automatically on iOS:
import 'package:zstandard/zstandard.dart';
void main() async {
final zstandard = Zstandard();
final data = Uint8List.fromList([1, 2, 3, 4, 5]);
final compressed = await zstandard.compress(data, 3);
final decompressed = await zstandard.decompress(compressed ?? Uint8List(0));
}
Or use the extension methods:
final compressed = await data.compress(compressionLevel: 3);
final decompressed = await compressed?.decompress();
API
- ZstandardIOS() — Creates the iOS platform implementation.
- compress(Uint8List data, int compressionLevel) — Compresses
data(level 1–22). Returns compressed bytes ornull. - decompress(Uint8List data) — Decompresses zstd-compressed data. Returns decompressed bytes or
null. - getPlatformVersion() — Returns a platform identifier string.
Architecture
This package uses Dart FFI with the zstandard_ios framework (native zstd C library). The framework is built as part of your iOS app when you build or run from Xcode or Flutter.
Testing
From the package directory:
flutter test
Unit tests run only on iOS (skipped on other platforms). For integration tests, run the main zstandard example app on an iOS device or simulator.
Troubleshooting
- Symbol or framework not found: Ensure the iOS target is built (e.g.
flutter run -d ios) and that you are targeting a supported architecture (arm64 device, x86_64/arm64 simulator). - CocoaPods: Run
pod installin your app’sios/directory if needed.
See the documentation for more.
