-
Notifications
You must be signed in to change notification settings - Fork 0
/
FindAllFiles.cs
45 lines (37 loc) · 1.82 KB
/
FindAllFiles.cs
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
namespace BackupHash;
static class FindAllFiles {
public static List<string> Find(string BaseDirectory) {
return Find(new DirectoryInfo(BaseDirectory));
}
public static List<string> Find(DirectoryInfo BaseDirectory) {
ConfigInfo ci = ConfigInfo.FromDirectory(BaseDirectory);
List<string> result = [];
_GetSubs(BaseDirectory, ci, BaseDirectory, result);
return result;
}
public static List<string> Find(DirectoryInfo WorkingDirectory, ConfigInfo UpperInfo, DirectoryInfo Directory) {
List<string> result = [];
Find(WorkingDirectory, UpperInfo, Directory, result);
return result;
}
public static void Find(DirectoryInfo WorkingDirectory, ConfigInfo UpperInfo, DirectoryInfo Directory, List<string> FileList) {
ConfigInfo ci = ConfigInfo.UpdateFromDirectory(UpperInfo, Directory);
if (ci != UpperInfo)
WorkingDirectory = Directory;
_GetSubs(WorkingDirectory, ci, Directory, FileList);
}
private static void _GetSubs(DirectoryInfo WorkingDirectory, ConfigInfo CurrentInfo, DirectoryInfo Directory, List<string> FileList) {
FileInfo[] files = Directory.GetFiles();
DirectoryInfo[] directories = Directory.GetDirectories();
foreach (FileInfo file in files) {
string relativePath = Path.GetRelativePath(WorkingDirectory.FullName, file.FullName);
if (file.Name != Shared.ConfigFilename && CurrentInfo.IncludedFile(relativePath))
FileList.Add(file.FullName);
}
foreach (DirectoryInfo dir in directories) {
string relativePath = Path.GetRelativePath(WorkingDirectory.FullName, dir.FullName);
if (CurrentInfo.IncludedDirectory(relativePath))
Find(WorkingDirectory, CurrentInfo, dir, FileList);
}
}
}