mirror of
https://github.com/esp8266/Arduino.git
synced 2025-04-21 10:26:06 +03:00
* Add fileCreation/getCreation create-time accessors For SDFS and LittleFS, enable a creation time accessor for files and Dir iterators, similar to the existing fileTime/getLastWrite calls. Remove spurious Dir::getLastWrite method (the proper and only documented way is really Dir::fileTime). Update json to point to new mklittlefs which copies the creation date of files to the image. Fixes #6992 * Remove malloc(), use stack vars for temp names LFS filenames are limited in size and generally very small. Use a stack variable instead of a dynamic allocation when performing full-path computations. * Replace "Creation" w/"CreationTime" in FS accessor Per review, `getCreation` -> `getCreationTime`, `fileCreation` -> `fileCreationTime`. The names `fileTime()` and `getLastWrite()` are inherited from ESP32 implementation and unchanged. * Add creation time to listfiles SD example * Enable SdFat's sateTime callback for timestamping SdFat requries the dateTimeCallback call (global for everything) to update dates and times on created files. Because the callback signature doesn't have space for us to provide any parameters, we cannot get the the File, Dir, or FS object's dateTimeCB member. Instead, just go with `time(null)` as the callback function which is right in all but the most esoteric cases. * Correct DOS year/month offset in dateTime callback * Fix docs to match new xxxCreationTime() API names Co-authored-by: Develo <deveyes@gmail.com>
130 lines
5.0 KiB
C++
130 lines
5.0 KiB
C++
/*
|
|
FSImpl.h - base file system interface
|
|
Copyright (c) 2015 Ivan Grokhotkov. All rights reserved.
|
|
This file is part of the esp8266 core for Arduino environment.
|
|
|
|
This library is free software; you can redistribute it and/or
|
|
modify it under the terms of the GNU Lesser General Public
|
|
License as published by the Free Software Foundation; either
|
|
version 2.1 of the License, or (at your option) any later version.
|
|
|
|
This library is distributed in the hope that it will be useful,
|
|
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
|
Lesser General Public License for more details.
|
|
|
|
You should have received a copy of the GNU Lesser General Public
|
|
License along with this library; if not, write to the Free Software
|
|
Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
|
|
*/
|
|
#ifndef FSIMPL_H
|
|
#define FSIMPL_H
|
|
|
|
#include <stddef.h>
|
|
#include <stdint.h>
|
|
#include <FS.h>
|
|
|
|
namespace fs {
|
|
|
|
class FileImpl {
|
|
public:
|
|
virtual ~FileImpl() { }
|
|
virtual size_t write(const uint8_t *buf, size_t size) = 0;
|
|
virtual size_t read(uint8_t* buf, size_t size) = 0;
|
|
virtual void flush() = 0;
|
|
virtual bool seek(uint32_t pos, SeekMode mode) = 0;
|
|
virtual size_t position() const = 0;
|
|
virtual size_t size() const = 0;
|
|
virtual bool truncate(uint32_t size) = 0;
|
|
virtual void close() = 0;
|
|
virtual const char* name() const = 0;
|
|
virtual const char* fullName() const = 0;
|
|
virtual bool isFile() const = 0;
|
|
virtual bool isDirectory() const = 0;
|
|
|
|
// Filesystems *may* support a timestamp per-file, so allow the user to override with
|
|
// their own callback for *this specific* file (as opposed to the FSImpl call of the
|
|
// same name. The default implementation simply returns time(&null)
|
|
virtual void setTimeCallback(time_t (*cb)(void)) { timeCallback = cb; }
|
|
|
|
// Return the last written time for a file. Undefined when called on a writable file
|
|
// as the FS is allowed to return either the time of the last write() operation or the
|
|
// time present in the filesystem metadata (often the last time the file was closed)
|
|
virtual time_t getLastWrite() { return 0; } // Default is to not support timestamps
|
|
// Same for creation time.
|
|
virtual time_t getCreationTime() { return 0; } // Default is to not support timestamps
|
|
|
|
protected:
|
|
time_t (*timeCallback)(void) = nullptr;
|
|
};
|
|
|
|
enum OpenMode {
|
|
OM_DEFAULT = 0,
|
|
OM_CREATE = 1,
|
|
OM_APPEND = 2,
|
|
OM_TRUNCATE = 4
|
|
};
|
|
|
|
enum AccessMode {
|
|
AM_READ = 1,
|
|
AM_WRITE = 2,
|
|
AM_RW = AM_READ | AM_WRITE
|
|
};
|
|
|
|
class DirImpl {
|
|
public:
|
|
virtual ~DirImpl() { }
|
|
virtual FileImplPtr openFile(OpenMode openMode, AccessMode accessMode) = 0;
|
|
virtual const char* fileName() = 0;
|
|
virtual size_t fileSize() = 0;
|
|
// Return the last written time for a file. Undefined when called on a writable file
|
|
// as the FS is allowed to return either the time of the last write() operation or the
|
|
// time present in the filesystem metadata (often the last time the file was closed)
|
|
virtual time_t fileTime() { return 0; } // By default, FS doesn't report file times
|
|
virtual time_t fileCreationTime() { return 0; } // By default, FS doesn't report file times
|
|
virtual bool isFile() const = 0;
|
|
virtual bool isDirectory() const = 0;
|
|
virtual bool next() = 0;
|
|
virtual bool rewind() = 0;
|
|
|
|
// Filesystems *may* support a timestamp per-file, so allow the user to override with
|
|
// their own callback for *this specific* file (as opposed to the FSImpl call of the
|
|
// same name. The default implementation simply returns time(&null)
|
|
virtual void setTimeCallback(time_t (*cb)(void)) { timeCallback = cb; }
|
|
|
|
protected:
|
|
time_t (*timeCallback)(void) = nullptr;
|
|
};
|
|
|
|
class FSImpl {
|
|
public:
|
|
virtual ~FSImpl () { }
|
|
virtual bool setConfig(const FSConfig &cfg) = 0;
|
|
virtual bool begin() = 0;
|
|
virtual void end() = 0;
|
|
virtual bool format() = 0;
|
|
virtual bool info(FSInfo& info) = 0;
|
|
virtual bool info64(FSInfo64& info) = 0;
|
|
virtual FileImplPtr open(const char* path, OpenMode openMode, AccessMode accessMode) = 0;
|
|
virtual bool exists(const char* path) = 0;
|
|
virtual DirImplPtr openDir(const char* path) = 0;
|
|
virtual bool rename(const char* pathFrom, const char* pathTo) = 0;
|
|
virtual bool remove(const char* path) = 0;
|
|
virtual bool mkdir(const char* path) = 0;
|
|
virtual bool rmdir(const char* path) = 0;
|
|
virtual bool gc() { return true; } // May not be implemented in all file systems.
|
|
virtual bool check() { return true; } // May not be implemented in all file systems.
|
|
|
|
// Filesystems *may* support a timestamp per-file, so allow the user to override with
|
|
// their own callback for all files on this FS. The default implementation simply
|
|
// returns the present time as reported by time(&null)
|
|
virtual void setTimeCallback(time_t (*cb)(void)) { timeCallback = cb; }
|
|
|
|
protected:
|
|
time_t (*timeCallback)(void) = nullptr;
|
|
};
|
|
|
|
} // namespace fs
|
|
|
|
#endif //FSIMPL_H
|