Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/tronkko/dirent
C/C++ library for retrieving information on files and directories
https://github.com/tronkko/dirent
Last synced: 2 months ago
JSON representation
C/C++ library for retrieving information on files and directories
- Host: GitHub
- URL: https://github.com/tronkko/dirent
- Owner: tronkko
- License: mit
- Created: 2015-09-24T19:10:20.000Z (over 9 years ago)
- Default Branch: master
- Last Pushed: 2024-06-14T12:23:12.000Z (7 months ago)
- Last Synced: 2024-08-02T15:31:02.956Z (6 months ago)
- Language: C
- Size: 198 KB
- Stars: 1,037
- Watchers: 41
- Forks: 511
- Open Issues: 1
-
Metadata Files:
- Readme: README.md
- Changelog: ChangeLog
- Contributing: CONTRIBUTING.md
- License: LICENSE
Awesome Lists containing this project
- AwesomeCppGameDev - dirent
README
# Dirent
Dirent is a programming interface for retrieving information about files and
directories in C and C++ languages. This project provides a Dirent interface
for Microsoft Visual Studio.# Installation
Download the latest Dirent installation package from
[GitHub](https://github.com/tronkko/dirent/releases) and
unpack the installation file with 7-zip, for example. The installation
package contains ``include/dirent.h`` file as well as a few example and test
programs.To make Dirent available to all C/C++ projects in your machine, simply copy
``include/dirent.h`` file to the system include directory, e.g.
``C:\Program Files\Microsoft Visual Studio 9.0\VC\include``. Everything you
need is included in the single ``dirent.h`` file, and you can start using
Dirent immediately -- there is no need to add files to your Visual Studio
project.Alternatively, if you wish to distribute ``dirent.h`` alongside with your own
project, then copy ``include/dirent.h`` file to a new sub-directory within
your project and add that directory to include path on Windows while omitting
the directory under Linux/UNIX. This allows your project to be compiled
against native ``dirent.h`` on Linux/UNIX while substituting the functionality
on Microsoft Windows.# Example Programs
The installation package contains example programs:
Program | Purpose
-------- | -----------------------------------------------------------------
ls | List files in a directory, e.g. ls "c:\Program Files"
find | Find files in subdirectories, e.g. find "c:\Program Files\CMake"
updatedb | Build database of files in a drive, e.g. updatedb c:\
locate | Locate a file from database, e.g. locate notepad
scandir | Printed sorted list of file names in a directory, e.g. scandir .
du | Compute disk usage, e.g. du "C:\Program Files"
cat | Print a text file to screen, e.g. cat include/dirent.hIn order to build the example programs, first install
[CMake](https://cmake.org/) to your machine. Then, open command prompt and
create a temporary directory ``c:\temp\dirent`` for the build files as```
c:\
mkdir temp
mkdir temp\dirent
cd temp\dirent
```Generate build files as
```
cmake d:\dirent
```where ``d:\dirent`` is the root directory of the Dirent package containing
this README.md file.Once CMake is finished, open Visual Studio, load the generated ``dirent.sln``
file from the build directory and build the whole solution.Once the build completes, open command prompt and cd to the Debug directory to
run the example programs. For example:```
cd c:\temp\dirent\Debug
.\ls .
```Visual Studio project also contains a solution named ``check`` which can be
used to verify that Dirent API works as expected. Just build the solution
from Visual Studio to run the test programs.# UTF-8 Support
By default, file and directory names in the Dirent API are expressed in the
currently selected windows codepage. If you wish to use UTF-8 character
encoding, then replace the main function with \_main function and convert
wide-character arguments to UTF-8 strings as demonstrated in the snippet
below.```
/* This is your true main function */
static int
_main(int argc, char *argv[])
{
/* ... */
}/* Convert arguments to UTF-8 */
#ifdef _MSC_VER
int
wmain(int argc, wchar_t *argv[])
{
/* Select UTF-8 locale */
setlocale(LC_ALL, ".utf8");
SetConsoleCP(CP_UTF8);
SetConsoleOutputCP(CP_UTF8);/* Allocate memory for multi-byte argv table */
char **mbargv;
mbargv = (char**) malloc(argc * sizeof(char*));
if (!mbargv) {
puts("Out of memory");
exit(3);
}/* Convert each argument in argv to UTF-8 */
for (int i = 0; i < argc; i++) {
size_t n;
wcstombs_s(&n, NULL, 0, argv[i], 0);/* Allocate room for ith argument */
mbargv[i] = (char*) malloc(n);
if (!mbargv[i]) {
puts("Out of memory");
exit(3);
}/* Convert ith argument to utf-8 */
wcstombs_s(NULL, mbargv[i], n, argv[i], n);
}/* Pass UTF-8 converted arguments to the main program */
int errorcode = _main(argc, mbargv);/* Release UTF-8 arguments */
for (int i = 0; i < argc; i++) {
free(mbargv[i]);
}/* Release the argument table */
free(mbargv);
return errorcode;
}
#else
int
main(int argc, char *argv[])
{
return _main(argc, argv);
}
#endif
```For more information on UTF-8 support, please see setlocale in Visual Studio
[C runtime library reference](https://docs.microsoft.com/en-us/cpp/c-runtime-library/reference/setlocale-wsetlocale?view=msvc-160#utf-8-support).# Contributing
We love to receive contributions from you. See the
[CONTRIBUTING](CONTRIBUTING.md) file for details.# Copying
Dirent may be freely distributed under the MIT license. See the
[LICENSE](LICENSE) file for details.# Alternatives to Dirent
I ported Dirent to Microsoft Windows in 1998 when only a few alternatives
were available. However, the situation has changed since then and nowadays
both [Cygwin](http://www.cygwin.com) and [MingW](http://www.mingw.org)
allow you to compile a great number of UNIX programs in Microsoft Windows.
They both provide a full Dirent API as well as many other UNIX APIs. MingW
can even be used for commercial applications!