极简文件列表

简介

单片机里搭建webserver,储存的资源需要用文件系统。如果使用fatfs之类的,体积太庞大,所以需要自己搭建一个按名访问的极简文件系统。

文件对象结构

c 复制代码
typedef struct {
    char *name;
    char *content;
}File_Item_t;
  • name:文件名
  • content:文件内容

文件存储和注册

c 复制代码
/// @brief File List
File_Item_t File_List[config_MAX_FileItem] = {0};

/// @brief register file name and file content to FileSystem
/// @param i :index
/// @param name :file name
/// @param content :file content, could be stored in flash or in ram
void SF_register(uint16_t i, char *name, char *content)
{
    if(i >= config_MAX_FileItem)
        return;
    File_List[i].name = name;
    File_List[i].content = content;
}

文件按名访问

按名访问只做到获取文件内容头指针,对文件的读写要自己建立缓冲区进行读写,文件长度限制要注意。

c 复制代码
/// @brief find file by name
/// @param file_name :file name
/// @param len :file name length, should be identical with name length in filesystem
/// @return file item pointer(File_Item_t *)
File_Item_t *SF_find(char *file_name, uint8_t len)
{
    if(len > config_MAX_Namelen)
        return 0;
    for(uint16_t i = 0; i < config_MAX_FileItem; i++)
    {
        if((strlen(file_name) == strlen(File_List[i].name)) && 
            (!memcmp(file_name, File_List[i].name, strlen(file_name))))
        {
            return &(File_List[i]);
        }
    }
    return 0;
}

测试

c 复制代码
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <errno.h>
#include <sys/types.h>
#include <sys/socket.h>
#include <netinet/in.h>
#include <unistd.h>
#include "Simple_Filesystem.h"

const char *file0_name = "boot0.bin";
const char *file0_content = "bin0bin0bin0bin0bin0bin0bin0bin0bin0";
const char *file1_name = "boot1.bin";
const char *file1_content = "bin1bin1bin1bin1bin1bin1bin1bin1bin1";

int main(int argc, char **argv)
{
    SF_register(0, (void *)file0_name, (void *)file0_content);
    SF_register(1, (void *)file1_name, (void *)file1_content);

    File_Item_t *filep = NULL;
    filep = SF_find("boot0.bin", strlen("boot0.bin"));
    if(filep)
        printf("file %s = %s\r\n",filep->name, filep->content);
    filep = SF_find("boot1.bin", strlen("boot1.bin"));
    if(filep)
        printf("file %s = %s\r\n",filep->name, filep->content);

    return 0;
}
相关推荐
xie_pin_an25 分钟前
C 语言排序算法全解析:从原理到实战,附性能对比
c语言·算法·排序算法
再睡一夏就好1 小时前
深入解析Linux页表:从虚拟地址到物理内存的映射艺术
linux·运维·服务器·c语言·c++·页表·缺页异常
LinHenrY12272 小时前
初识C语言(编译和链接)
c语言·开发语言·蓝桥杯
l1t2 小时前
利用小米mimo为精确覆盖矩形问题C程序添加打乱函数求出更大的解
c语言·开发语言·javascript·人工智能·算法
松涛和鸣2 小时前
34、 Linux IPC进程间通信:无名管道(Pipe) 和有名管道(FIFO)
linux·服务器·c语言·网络·数据结构·数据库
秦苒&2 小时前
【C语言】详解数据类型和变量(一):数据类型介绍、 signed和unsigned、数据类型的取值范围、变量、强制类型转换
c语言·开发语言·c++·c#
LinHenrY12273 小时前
初识C语言(文件操作)
c语言·windows·microsoft
智者知已应修善业3 小时前
【删除有序数组中的重复项 II之O(N)算法】2024-1-31
c语言·c++·经验分享·笔记·算法
代码游侠4 小时前
应用——管道与文件描述符
linux·服务器·c语言·学习·算法
GoWjw4 小时前
C语言高级特性
c语言·开发语言·算法