Important changes to repositories hosted on mbed.com
Mbed hosted mercurial repositories are deprecated and are due to be permanently deleted in July 2026.
To keep a copy of this software download the repository Zip archive or clone locally using Mercurial.
It is also possible to export all your personal repositories from the account settings page.
Dependents: cc3000_ping_demo_try_2
Fork of mbed by
DirHandle.h
- Committer:
- simon.ford@mbed.co.uk
- Date:
- 2009-02-03
- Revision:
- 8:00a04e5cd407
- Child:
- 11:1c1ebd0324fa
File content as of revision 8:00a04e5cd407:
/* Copyright 2008 ARM Limited. All rights reserved. */
#ifndef MBED_DIRHANDLE_H
#define MBED_DIRHANDLE_H
#ifdef __ARMCC_VERSION
# define NAME_MAX 255
typedef int mode_t;
#else
# include <sys/syslimits.h>
#endif
#include "FileHandle.h"
struct dirent {
char d_name[NAME_MAX+1];
};
namespace mbed {
/* Class DirHandle
* Represents a directory stream. Objects of this type are returned
* by a FileSystemLike's opendir method. Implementations must define
* at least closedir, readdir and rewinddir.
*
* If a FileSystemLike class defines the opendir method, then the
* directories of an object of that type can be accessed by
* DIR *d = opendir("/example/directory") (or opendir("/example")
* to open the root of the filesystem), and then using readdir(d) etc.
*
* The root directory is considered to contain all FileLike and
* FileSystemLike objects, so the DIR* returned by opendir("/") will
* reflect this.
*/
class DirHandle {
public:
/* Function closedir
* Closes the directory.
*
* Variables
* returns - 0 on success, or -1 on error.
*/
virtual int closedir()=0;
/* Function readdir
* Return the directory entry at the current position, and
* advances the position to the next entry.
*
* Variables
* returns - A pointer to a dirent structure representing the
* directory entry at the current position, or NULL on reaching
* end of directory or error.
*/
virtual struct dirent *readdir()=0;
/* Function rewinddir
* Resets the position to the beginning of the directory.
*/
virtual void rewinddir()=0;
/* Function telldir
* Returns the current position of the DirHandle.
*
* Variables
* returns - The current position, or -1 on error.
*/
virtual off_t telldir() { return -1; }
/* Function seekdir
* Sets the position of the DirHandle.
*
* Variables
* location - The location to seek to. Must be a value returned
* by telldir.
*/
virtual void seekdir(off_t location) { }
};
} /* namespace mbed */
typedef mbed::DirHandle DIR;
extern "C" {
DIR *opendir(const char*);
struct dirent *readdir(DIR *);
int closedir(DIR*);
void rewinddir(DIR*);
long telldir(DIR*);
void seekdir(DIR*, long);
int mkdir(const char *name, mode_t n);
};
#endif /* MBED_DIRHANDLE_H */
