⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 dir.c

📁 编译后直接运行的MP3播放器全部C语言源代码 一个包含FAT文件系统、系统引导 Boot、FLASH Driver等内容的
💻 C
字号:
/*************************************************************************** *             __________               __   ___. *   Open      \______   \ ____   ____ |  | _\_ |__   _______  ___ *   Source     |       _//  _ \_/ ___\|  |/ /| __ \ /  _ \  \/  / *   Jukebox    |    |   (  <_> )  \___|    < | \_\ (  <_> > <  < *   Firmware   |____|_  /\____/ \___  >__|_ \|___  /\____/__/\_ \ *                     \/            \/     \/    \/            \/ * $Id: dir.c,v 1.20 2004/02/11 14:37:16 linusnielsen Exp $ * * Copyright (C) 2002 by Bj鰎n Stenberg * * All files in this archive are subject to the GNU General Public License. * See the file COPYING in the source tree root for full license agreement. * * This software is distributed on an "AS IS" basis, WITHOUT WARRANTY OF ANY * KIND, either express or implied. * ****************************************************************************/#include <stdio.h>#include <errno.h>#include <string.h>#include <stdbool.h>#include "fat.h"#include "dir.h"#include "debug.h"#define MAX_OPEN_DIRS 8static DIR opendirs[MAX_OPEN_DIRS];DIR* opendir(char* name){    char namecopy[MAX_PATH];    char* part;    char* end;    struct fat_direntry entry;    int dd;    /* find a free dir descriptor */    for ( dd=0; dd<MAX_OPEN_DIRS; dd++ )        if ( !opendirs[dd].busy )            break;    if ( dd == MAX_OPEN_DIRS ) {        DEBUGF("Too many dirs open\n");        errno = EMFILE;        return NULL;    }    opendirs[dd].busy = true;    if ( name[0] != '/' ) {        DEBUGF("Only absolute paths supported right now\n");        opendirs[dd].busy = false;        return NULL;    }    if ( fat_opendir(&(opendirs[dd].fatdir), 0) < 0 ) {        DEBUGF("Failed opening root dir\n");        opendirs[dd].busy = false;        return NULL;    }    strncpy(namecopy,name,sizeof(namecopy));    namecopy[sizeof(namecopy)-1] = 0;    for ( part = strtok_r(namecopy, "/", &end); part;          part = strtok_r(NULL, "/", &end)) {        /* scan dir for name */        while (1) {            if ((fat_getnext(&(opendirs[dd].fatdir),&entry) < 0) ||                (!entry.name[0])) {                opendirs[dd].busy = false;                return NULL;            }            if ( (entry.attr & FAT_ATTR_DIRECTORY) &&                 (!strcasecmp(part, entry.name)) ) {                if ( fat_opendir(&(opendirs[dd].fatdir),                                 entry.firstcluster) < 0 ) {                    DEBUGF("Failed opening dir '%s' (%d)\n",                           part, entry.firstcluster);                    opendirs[dd].busy = false;                    return NULL;                }                break;            }        }    }    return &opendirs[dd];}int closedir(DIR* dir){    dir->busy=false;    return 0;}struct dirent* readdir(DIR* dir){    struct fat_direntry entry;    struct dirent* theent = &(dir->theent);    if (fat_getnext(&(dir->fatdir),&entry) < 0)        return NULL;    if ( !entry.name[0] )        return NULL;	    strncpy(theent->d_name, entry.name, sizeof( theent->d_name ) );    theent->attribute = entry.attr;    theent->size = entry.filesize;    theent->startcluster = entry.firstcluster;    return theent;}int mkdir(char *name, int mode){    DIR *dir;    char namecopy[MAX_PATH];    char* end;    char *basename;    char *parent;    struct dirent *entry;    struct fat_dir newdir;    int rc;    (void)mode;    if ( name[0] != '/' ) {        DEBUGF("mkdir: Only absolute paths supported right now\n");        return -1;    }    strncpy(namecopy,name,sizeof(namecopy));    namecopy[sizeof(namecopy)-1] = 0;    /* Split the base name and the path */    end = strrchr(namecopy, '/');    *end = 0;    basename = end+1;    if(namecopy == end) /* Root dir? */        parent = "/";    else        parent = namecopy;            DEBUGF("mkdir: parent: %s, name: %s\n", parent, basename);    dir = opendir(parent);        if(!dir) {        DEBUGF("mkdir: can't open parent dir\n");        return -2;    }        if(basename[0] == 0) {        DEBUGF("mkdir: Empty dir name\n");        errno = EINVAL;        return -3;    }        /* Now check if the name already exists */    while ((entry = readdir(dir))) {        if ( !strcasecmp(basename, entry->d_name) ) {            DEBUGF("mkdir error: file exists\n");            errno = EEXIST;            closedir(dir);            return - 4;        }    }    memset(&newdir, sizeof(struct fat_dir), 0);        rc = fat_create_dir(basename, &newdir, &(dir->fatdir));        closedir(dir);        return rc;}

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -