blob: cf596f06db99bce382628a99656fa1af30ca0768 [file] [log] [blame] [view]
> [!NOTE]
> The source-of-truth for this package has moved to https://github.com/dart-lang/tools.
## package:file
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:
```dart
import 'package:file/file.dart';
class FooBarFileSystem implements FileSystem { ... }
```
Use the in-memory file system:
```dart
import 'package:file/memory.dart';
var fs = MemoryFileSystem();
```
Use the local file system (requires dart:io access):
```dart
import 'package:file/local.dart';
var fs = const LocalFileSystem();
```