dart:io
FileSystemEntity class
The common super class for File, Directory, and Link objects.
FileSystemEntity objects are returned from directory listing operations. To determine if a FileSystemEntity is a File, a Directory, or a Link perform a type check:
if (entity is File) (entity as File).readAsStringSync();
You can also use the type or typeSync methods to determine the type of a file system object.
Most methods in this class occur in synchronous and asynchronous pairs, for example, exists and existsSync. Unless you have a specific reason for using the synchronous version of a method, prefer the asynchronous version to avoid blocking your program.
Here's the exists method in action:
entity.exists().then((isThere) {
isThere ? print('exists') : print('non-existent');
});
Other resources
-
Dart by Example provides additional task-oriented code samples that show how to use various API from the Directory class and the File class, both subclasses of FileSystemEntity.
-
I/O for Command-Line Apps, a section from A Tour of the Dart Libraries covers files and directories.
-
Write Command-Line Apps, a tutorial about writing command-line apps, includes information about files and directories.
- Implemented by
Constructors
- FileSystemEntity()
Properties
- absolute → FileSystemEntity
read-only
- Returns a FileSystemEntity whose path is the absolute path to this. [...]
- isAbsolute → bool
read-only
- Returns a bool indicating whether this object's path is absolute. [...]
- parent → Directory
read-only
- The directory containing this.
- path → String
read-only
- uri → Uri
read-only
- Returns a Uri representing the file system entity's location. [...]
- hashCode → int
read-only, inherited
- The hash code for this object. [...]
- runtimeType → Type
read-only, inherited
- A representation of the runtime type of the object.
Methods
- delete({bool recursive: false }) → Future<FileSystemEntity>
- Deletes this FileSystemEntity. [...]
- deleteSync({bool recursive: false }) → void
- Synchronously deletes this FileSystemEntity. [...]
- exists() → Future<bool>
- Checks whether the file system entity with this path exists. Returns a
Future<bool>
that completes with the result. [...] - existsSync() → bool
- Synchronously checks whether the file system entity with this path exists. [...]
- rename(String newPath) → Future<FileSystemEntity>
- Renames this file system entity. [...]
- renameSync(String newPath) → FileSystemEntity
- Synchronously renames this file system entity. [...]
- resolveSymbolicLinks() → Future<String>
- Resolves the path of a file system object relative to the current working directory. [...]
- resolveSymbolicLinksSync() → String
- Resolves the path of a file system object relative to the current working directory. [...]
- stat() → Future<FileStat>
- Calls the operating system's stat() function on the path of this FileSystemEntity. [...]
- statSync() → FileStat
- Synchronously calls the operating system's stat() function on the path of this FileSystemEntity. [...]
- watch({int events: FileSystemEvent.all, bool recursive: false }) → Stream<FileSystemEvent>
- Start watching the FileSystemEntity for changes. [...]
- noSuchMethod(Invocation invocation) → dynamic
inherited
- Invoked when a non-existent method or property is accessed. [...]
- toString() → String
inherited
- Returns a string representation of this object.
Operators
- operator ==(dynamic other) → bool
inherited
- The equality operator. [...]
Static Properties
- isWatchSupported → bool
read-only
- Test if watch is supported on the current system. [...]
Static Methods
- identical(String path1, String path2) → Future<bool>
- Checks whether two paths refer to the same object in the file system. [...]
- identicalSync(String path1, String path2) → bool
- Synchronously checks whether two paths refer to the same object in the file system. [...]
- isDirectory(String path) → Future<bool>
- Checks if type(path) returns FileSystemEntityType.directory.
- isDirectorySync(String path) → bool
- Synchronously checks if typeSync(path) returns FileSystemEntityType.directory.
- isFile(String path) → Future<bool>
- Checks if type(path) returns FileSystemEntityType.file.
- isFileSync(String path) → bool
- Synchronously checks if typeSync(path) returns FileSystemEntityType.file.
- isLink(String path) → Future<bool>
- Checks if type(path, followLinks: false) returns FileSystemEntityType.link.
- isLinkSync(String path) → bool
- Synchronously checks if typeSync(path, followLinks: false) returns FileSystemEntityType.link.
- parentOf(String path) → String
- Removes the final path component of a path, using the platform's path separator to split the path. [...]
- type(String path, { bool followLinks: true }) → Future<FileSystemEntityType>
- Finds the type of file system object that a path points to. [...]
- typeSync(String path, { bool followLinks: true }) → FileSystemEntityType
- Synchronously finds the type of file system object that a path points to. [...]