Dirent

Hye,

I am new to c++. I need to create a program that prints all the files directories and subdirectories. For example, if user enters Local Disk D. It prints all the files in Local Disk D. Currently, I am using netbeans and I manage to print all the files if I insert command 'find "D:\"' in the terminal. This coding is using Dirent.

My problem is, is there any way I can run this program without opening the terminal? If i run usual way, it automatically prints all the files of where I put the project. Or is there any way to call back the printed files in terminal to become output?
Please help.


1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
  /*
 * An example demonstrating recursive directory traversal.
 *
 * Compile this file with Visual Studio 2008 project vs2008.sln and run
 * the produced command in console with a directory name argument.  For
 * example, command
 *
 *     find "C:\Program Files"
 *
 * might produce a listing with thousands of entries such as
 *
 *     c:\Program Files/7-Zip/7-zip.chm
 *     c:\Program Files/7-Zip/7-zip.dll
 *     c:\Program Files/7-Zip/7z.dll
 *     c:\Program Files/Adobe/Reader 10.0/Reader/logsession.dll
 *     c:\Program Files/Adobe/Reader 10.0/Reader/LogTransport2.exe
 *     c:\Program Files/Windows NT/Accessories/wordpad.exe
 *     c:\Program Files/Windows NT/Accessories/write.wpc
 *
 * The find command provided by this file is only an example.  That is,
 * the command does not provide options to restrict the output to certain
 * files as the Linux version does.
 *
 * Copyright (C) 2006-2012 Toni Ronkko
 * This file is part of dirent.  Dirent may be freely distributed
 * under the MIT license.  For all details and documentation, see
 * https://github.com/tronkko/dirent
 */
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <dirent.h>

static int find_directory (const char *dirname);


int
main(int argc, char *argv[]) 
{
    int i;
    int ok;

    /* For each directory in command line */
    i = 1;
    while (i < argc) 
    {
        ok = find_directory (argv[i]);
        if (!ok) 
        {
            exit (EXIT_FAILURE);
        }
        i++;
    }

    /* List current working directory if no arguments on command line */
    if (argc == 1) 
    {
        find_directory (".");
    }
    return EXIT_SUCCESS;
}

/* Find files and subdirectories recursively */
static int
find_directory(const char *dirname)
{
    DIR *dir;
    char buffer[PATH_MAX + 2];
    char *p = buffer;
    const char *src;
    char *end = &buffer[PATH_MAX];
    int ok;

    /* Copy directory name to buffer */
    src = dirname;
    while (p < end  &&  *src != '\0') {
        *p++ = *src++;
    }
    *p = '\0';

    /* Open directory stream */
    dir = opendir (dirname);
    if (dir != NULL) {
        struct dirent *ent;

        /* Print all files and directories within the directory */
        while ((ent = readdir (dir)) != NULL) {
            char *q = p;
            char c;

            /* Get final character of directory name */
            if (buffer < q) 
            {
                c = q[-1];
            } else {
                c = ':';
            }

            /* Append directory separator if not already there */
            if (c != ':'  &&  c != '/'  &&  c != '\\') 
            {
                *q++ = '/';
            }

            /* Append file name */
            src = ent->d_name;
            while (q < end  &&  *src != '\0') {
                *q++ = *src++;
            }
            *q = '\0';

            /* Decide what to do with the directory entry */
            switch (ent->d_type) {
            case DT_LNK:
            case DT_REG:
                /* Output file name with directory */
                printf ("%s\n", buffer);
                break;

            case DT_DIR:
                /* Scan sub-directory recursively */
                if (strcmp (ent->d_name, ".") != 0  
                        &&  strcmp (ent->d_name, "..") != 0) {
                    find_directory (buffer);
                }
                break;

            default:
                /* Ignore device entries */
                /*NOP*/;
            }

        }

        closedir (dir);
        ok = 1;

    } else {
        /* Could not open directory */
        printf ("Cannot open directory %s\n", dirname);
        ok = 0;
    }

    return ok;
}
Last edited on
My problem is, is there any way I can run this program without opening the terminal?
What do you mean? The console? When you print it to the console (using printf(...)) the console should exists?

Or is there any way to call back the printed files in terminal to become output?
I have really no idea what that could mean.
Hello amateurcpp,

After playing with the code for awhile and understanding how it worked I did away with the while loop at line 45 because it is rare that I use command line arguments. After that I did away with the if statement at line 56 and just kept line 58. To that I added a variable for the path and a vector to hold the file names.

Line 58 in the function call parameter is where you will put the path that you want to list.

he case case DT_DIR: is a recursive call, but I see no way to break out of the recursion. A good start, but I think it needs some work.

Hope that helps.

Andy
It seems to me OP is asking how to pass command line parameters without using the console.

he case case DT_DIR: is a recursive call, but I see no way to break out of the recursion.
A directory with no subdirectories causes the control flow to never enter that switch case for that directory. Since a directory tree can contain no cycles (other than links, which are not followed here), it's not possible for this function to recurse infinitely.
@helios,

Recursion is not my best area. I stand corrected. Thank you.

Andy
Topic archived. No new replies allowed.