File System
Principle
The FS Foundation Library defines a low-level File System framework for embedded devices. It allows you to manage abstract files and directories without worrying about the native underlying File System kind.
Functional Description
The MicroEJ Application manages File System elements using File/Directory abstraction. The FS implementation made for each MicroEJ Platform is responsible for surfacing the native File System specific behavior.
Dependencies
LLFS_impl.h
andLLFS_File_impl.h
implementations (see LLFS: File System).
Installation
FS is an additional module. To enable it, the FS Pack module must be installed in your VEE Port:
microejPack("com.microej.pack:fs:6.0.4")
<dependency org="com.microej.pack" name="fs" rev="6.0.4"/>
Then, using the VEE Port Editor (see :ref:`platform_module_configuration`), enable the `FS` library.
When installed, the FS Pack module must be configured.
The FS module defines two pre-configured File System types: Unix
and FatFS
.
Some characteristics don’t need to be specified for these File System types, but they can be overridden if needed.
For example, specifying a Unix
File System type will automatically set the file separator to /
.
If none of the pre-configured File System types correspond to the File System used in the C project, the Custom
type can be used. When this type is selected, all the File System characteristics must be specified in the properties file.
- In SDK 6, the configuration is done in the properties file
configuration.properties
of the VEE Port project. All the properties names listed below must be prefixed by
com.microej.runtime.fs.
. For example thefs
properties is defined by thecom.microej.runtime.fs.fs
property.
In SDK 5, the configuration is done in the properties file fs/fs.properties
.
This properties file specifies the characteristics of the File System used in the C project (case sensitivity, root
directory, file separator, etc.).
The list below describes the properties that can be defined in the configuration file:
fs
: Defines the type of File System used in the C project (optional, the default value isUnix
). This property can have one of the following values:Unix
: select this configuration when using a Unix-like File System(case-sensitive, file separator is
/
).
FatFS
: select this configuration when using FatFS File System(case-insensitive, file separator is
/
).
Custom
: select this configuration when using another type of File System.
root.dir
: Defines the File System root volume. This property is optional forUnix
andFatFS
(/
by default for both).user.dir
: Defines the File System user directory. This property is optional forFatFS
(/usr/
by default).java.io.tmpdir
: Defines the File System temporary directory. This property is optional forUnix
andFatFS
(/tmp/
by default for both).file.separator
: Defines the File System file separator. This property is optional forUnix
andFatFS
(/
by default for both).path.separator
: Defines the File System path separator. This property is optional forUnix
andFatFS
(:
by default for both).case.sensitivity
: Defines the case sensitivity of the File System. This property is optional forUnix
(caseSensitive
by default) andFatFS
(caseInsensitive
by default). This property can have one of the following values:caseSensitive
: the File System is case-sensitive.caseInsensitive
: the File System is case-insensitive.
Properties File Template
The following snippet can be used as a template for fs.properties
file:
# Defines the type of File System used in the C project.
# Possible values are:
# - FatFs
# - Unix
# - Custom
# @optional, default value is "Unix"
#com.microej.runtime.fs=
# Defines the File System root volume.
# @optional for the following File System types:
# - FatFs (default value is "/")
# - Unix (default value is "/")
# @mandatory for the following File System type:
# - Custom
#com.microej.runtime.root.dir=
# Defines the File System user directory.
# @optional for the following File System type:
# - FatFs (default value is "/usr")
# @mandatory for the following File System types:
# - Unix
# - Custom
#com.microej.runtime.user.dir=
# Defines the File System temporary directory.
# @optional for the following File System types:
# - FatFs (default value is "/tmp")
# - Unix (default value is "/tmp")
# @mandatory for the following File System type:
# - Custom
#com.microej.runtime.java.io.tmpdir=
# Defines the File System file separator.
# @optional for the following File System types:
# - FatFs (default value is "/")
# - Unix (default value is "/")
# @mandatory for the following File System type:
# - Custom
#com.microej.runtime.file.separator=
# Defines the File System path separator.
# @optional for the following File System types:
# - FatFs (default value is ":")
# - Unix (default value is ":")
# @mandatory for the following File System type:
# - Custom
#com.microej.runtime.path.separator=
# Defines the case sensitivity of the File System.
# Valid values are "caseInsensitive" and "caseSensitive".
# @optional for the following File System types:
# - FatFs (default value is "caseInsensitive")
# - Unix (default value is "caseSensitive")
# @mandatory for the following File System type:
# - Custom
#com.microej.runtime.case.sensitivity=
# Defines the type of File System used in the C project.
# Possible values are:
# - FatFs
# - Unix
# - Custom
# @optional, default value is "Unix"
#fs=
# Defines the File System root volume.
# @optional for the following File System types:
# - FatFs (default value is "/")
# - Unix (default value is "/")
# @mandatory for the following File System type:
# - Custom
#root.dir=
# Defines the File System user directory.
# @optional for the following File System type:
# - FatFs (default value is "/usr")
# @mandatory for the following File System types:
# - Unix
# - Custom
#user.dir=
# Defines the File System temporary directory.
# @optional for the following File System types:
# - FatFs (default value is "/tmp")
# - Unix (default value is "/tmp")
# @mandatory for the following File System type:
# - Custom
#java.io.tmpdir=
# Defines the File System file separator.
# @optional for the following File System types:
# - FatFs (default value is "/")
# - Unix (default value is "/")
# @mandatory for the following File System type:
# - Custom
#file.separator=
# Defines the File System path separator.
# @optional for the following File System types:
# - FatFs (default value is ":")
# - Unix (default value is ":")
# @mandatory for the following File System type:
# - Custom
#path.separator=
# Defines the case sensitivity of the File System.
# Valid values are "caseInsensitive" and "caseSensitive".
# @optional for the following File System types:
# - FatFs (default value is "caseInsensitive")
# - Unix (default value is "caseSensitive")
# @mandatory for the following File System type:
# - Custom
#case.sensitivity=
Use
The FS API Module must be added to the project build file to use the FS library:
implementation("ej.api:fs:2.1.1")
<dependency org="ej.api" name="fs" rev="2.1.1"/>