From 4270e994fc2722308f22a7b4d4c4bc8d9e795a9c Mon Sep 17 00:00:00 2001 From: EmergReanimator Date: Fri, 4 Mar 2022 13:47:13 +0100 Subject: [PATCH] Added path delimiter configuration option --- lfs.c | 16 ++++++++++------ lfs.h | 8 +++++++- 2 files changed, 17 insertions(+), 7 deletions(-) diff --git a/lfs.c b/lfs.c index d976389d..f9e17c6a 100644 --- a/lfs.c +++ b/lfs.c @@ -10,6 +10,10 @@ #define LFS_BLOCK_NULL ((lfs_block_t)-1) #define LFS_BLOCK_INLINE ((lfs_block_t)-2) +// create a string out of the character +static const char lsf_path_delimiter[2] = {LSF_PATH_DELIMITER, '\0'}; +#define LSF_PATH_DELIMITER_STR (&lsf_path_delimiter[0]) + /// Caching block device operations /// static inline void lfs_cache_drop(lfs_t *lfs, lfs_cache_t *rcache) { // do not zero, cheaper if cache is readonly or only going to be @@ -1102,7 +1106,7 @@ static int lfs_dir_getinfo(lfs_t *lfs, lfs_mdir_t *dir, uint16_t id, struct lfs_info *info) { if (id == 0x3ff) { // special case for root - strcpy(info->name, "/"); + strcpy(info->name, LSF_PATH_DELIMITER_STR); info->type = LFS_TYPE_DIR; return 0; } @@ -1178,8 +1182,8 @@ static lfs_stag_t lfs_dir_find(lfs_t *lfs, lfs_mdir_t *dir, while (true) { nextname: // skip slashes - name += strspn(name, "/"); - lfs_size_t namelen = strcspn(name, "/"); + name += strspn(name, LSF_PATH_DELIMITER_STR); + lfs_size_t namelen = strcspn(name, LSF_PATH_DELIMITER_STR); // skip '.' and root '..' if ((namelen == 1 && memcmp(name, ".", 1) == 0) || @@ -1193,8 +1197,8 @@ static lfs_stag_t lfs_dir_find(lfs_t *lfs, lfs_mdir_t *dir, lfs_size_t sufflen; int depth = 1; while (true) { - suffix += strspn(suffix, "/"); - sufflen = strcspn(suffix, "/"); + suffix += strspn(suffix, LSF_PATH_DELIMITER_STR); + sufflen = strcspn(suffix, LSF_PATH_DELIMITER_STR); if (sufflen == 0) { break; } @@ -1241,7 +1245,7 @@ static lfs_stag_t lfs_dir_find(lfs_t *lfs, lfs_mdir_t *dir, LFS_MKTAG(0x780, 0, 0), LFS_MKTAG(LFS_TYPE_NAME, 0, namelen), // are we last name? - (strchr(name, '/') == NULL) ? id : NULL, + (strchr(name, LSF_PATH_DELIMITER) == NULL) ? id : NULL, lfs_dir_find_match, &(struct lfs_dir_find_match){ lfs, name, namelen}); if (tag < 0) { diff --git a/lfs.h b/lfs.h index ad491627..4e97c427 100644 --- a/lfs.h +++ b/lfs.h @@ -22,7 +22,7 @@ extern "C" // Software library version // Major (top-nibble), incremented on backwards incompatible changes // Minor (bottom-nibble), incremented on feature additions -#define LFS_VERSION 0x00020004 +#define LFS_VERSION 0x00020005 #define LFS_VERSION_MAJOR (0xffff & (LFS_VERSION >> 16)) #define LFS_VERSION_MINOR (0xffff & (LFS_VERSION >> 0)) @@ -67,6 +67,12 @@ typedef uint32_t lfs_block_t; #define LFS_ATTR_MAX 1022 #endif +// Path delimiter used to separate path tokens +// Default : POSIX like slash +#ifndef LSF_PATH_DELIMITER +#define LSF_PATH_DELIMITER '/' +#endif + // Possible error codes, these are negative to allow // valid positive return values enum lfs_error {