A generic file system abstraction for Dart.
Features
Like dart:io, package:file supplies a rich Dart-idiomatic API for accessing
a file system.
Unlike dart:io, package:file:
- Can be used to implement custom file systems.
- Comes with an in-memory implementation out-of-the-box, making it super-easy to test code that works with the file system.
- Allows using multiple file systems simultaneously. A file system is a first-class object. Instantiate however many you want and use them all.
Usage
Implement your own custom file system:
import 'package:file/file.dart';
class FooBarFileSystem implements FileSystem { ... }
Use the in-memory file system:
import 'package:file/memory.dart';
var fs = MemoryFileSystem();
Use the local file system (requires dart:io access):
import 'package:file/local.dart';
var fs = const LocalFileSystem();
Libraries
- chroot
- A file system that provides a view into another
FileSystemvia a path. - file
- Core interfaces containing the abstract
FileSysteminterface definition and all associated types used byFileSystem. - local
- A local file system implementation. This relies on the use of
dart:ioand is thus not suitable for use in the browser. - memory
- An implementation of
FileSystemthat exists entirely in memory with an internal representation loosely based on the Filesystem Hierarchy Standard.