Filesystem library

This newly added feature lets us interact with the directories and files on our system.

The new filesystem library is based on boost::filesystem. Some of its components are optional. This means not all functionality of std::filesystem is available on each implementation of the filesystem library. For example, FAT-32 does not support symbolic links.

ℹ️ Using cppreference.com
At the time of the writing this book (October 2017), I had no C+±compiler at my disposal that supports the new filesystem library; therefore, I executed the programs in this chapter with the newest GCC-compiler on cppreference.com: filesystem that supports the new filesystem library.

To use the new filesystem library you may have to include and apply the experimental namespace.

#include <experimental/filesystem>
namespace fs = std::experimental::filesystem;

All examples in this chapter are written without the experimental namespace.

The library is based on the three concepts: file, file name, and path.

  • A file is an object that holds data such that you can write to it or read from it. A file has a name and a file type. A file type can be a directory, hard link, symbolic link or a regular file.

    • A directory is a container for holding other files. The current directory is represented by a dot "."; the parent directory is represented by two dots "..".

    • A hard link associates a name with an existing file.

    • A symbolic link associates a name with a path that may exist.

    • A regular file is a directory entry which is neither a directory, a hard link, nor a symbolic link.

  • A file name is a string that represents a file. It is implementation-defined which characters are allowed, how long the name could be or if the name is case sensitive.

  • A path is a sequence of entries that identify the location for a file. It has an optional root-name such a “C:” on Windows, followed by a root-directory such a “/” on Unix. Additional parts can be directories, hard links, symbolic links, or regular files. A path can be absolute, canonical, or relative.

    • An absolute path is a path that identifies a file.

    • A canonical path is a path that includes neither a symbolic link nor the relative paths "." (current directory) or ".."(parent directory).

    • A relative path specifies a path relative to a location in the file system. Paths such as "." (current directory), ".."(parent directory) or "home/rainer" are relative paths. On Unix, they do not start at the root-directory "/".

Here is an introductory example of the filesystem.

Get hands-on with 1300+ tech skills courses.