Gets the size of all files within a directory
/*
Copyright (c) 2010 <a href="http://www.gutgames.com">James Craig</a>
Permission is hereby granted, free of charge, to any person obtaining a copy
of this software and associated documentation files (the "Software"), to deal
in the Software without restriction, including without limitation the rights
to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
copies of the Software, and to permit persons to whom the Software is
furnished to do so, subject to the following conditions:
The above copyright notice and this permission notice shall be included in
all copies or substantial portions of the Software.
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
THE SOFTWARE.*/
#region Usings
using System;
using System.Collections.Generic;
using System.IO;
using System.Net;
using System.Text;
#endregion
namespace Utilities
{
public static class FileManager
{
/// <summary>
/// Determines if a directory exists
/// </summary>
/// <param name="DirectoryPath">Path of the directory</param>
/// <returns>true if it exists, false otherwise</returns>
public static bool DirectoryExists(string DirectoryPath)
{
try
{
return Directory.Exists(DirectoryPath);
}
catch (Exception a)
{
throw a;
}
}
/// <summary>
/// Gets a list of files
/// </summary>
/// <param name="DirectoryPath">Directory to check for files</param>
/// <param name="Recursive">Determines if this is a recursive look at all directories under this one</param>
/// <returns>a list of files</returns>
public static List<FileInfo> FileList(string DirectoryPath,bool Recursive)
{
try
{
if (!Recursive)
{
return FileList(DirectoryPath);
}
List<FileInfo> Files = new List<FileInfo>();
if (DirectoryExists(DirectoryPath))
{
DirectoryInfo Directory = new DirectoryInfo(DirectoryPath);
FileInfo[] SubFiles = Directory.GetFiles();
foreach (FileInfo SubFile in SubFiles)
{
Files.Add(SubFile);
}
DirectoryInfo[] SubDirectories = Directory.GetDirectories();
foreach (DirectoryInfo SubDirectory in SubDirectories)
{
List<FileInfo> TempFiles = FileList(SubDirectory.FullName, Recursive);
foreach (FileInfo File in TempFiles)
{
Files.Add(File);
}
}
}
return Files;
}
catch (Exception a)
{
throw a;
}
}
/// <summary>
/// Gets a list of files
/// </summary>
/// <param name="DirectoryPath">Directory to check for files</param>
/// <returns>a list of files</returns>
public static List<FileInfo> FileList(string DirectoryPath)
{
try
{
List<FileInfo> Files = new List<FileInfo>();
if (DirectoryExists(DirectoryPath))
{
DirectoryInfo Directory = new DirectoryInfo(DirectoryPath);
FileInfo[] SubFiles = Directory.GetFiles();
foreach (FileInfo SubFile in SubFiles)
{
Files.Add(SubFile);
}
}
return Files;
}
catch (Exception a)
{
throw a;
}
}
/// <summary>
/// Gets the size of all files within a directory
/// </summary>
/// <param name="Directory">Directory path</param>
/// <param name="Recursive">determines if this is a recursive call or not</param>
/// <returns></returns>
public static long GetDirectorySize(string Directory, bool Recursive)
{
try
{
long Size = 0;
List<FileInfo> Files = FileManager.FileList(Directory, Recursive);
foreach (FileInfo File in Files)
{
Size += File.Length;
}
return Size;
}
catch (Exception a)
{
throw a;
}
}
}
}
Related examples in the same category
1. | Find Files That Match a Wildcard Expression | | |
2. | Get Files from a directory | | |
3. | Get Directory properties from DirectionInfo class | | |
4. | Get directory name and file information in that directory | | |
5. | Directory Counter | | |
6. | File Search | | |
7. | Get Name, Parent, Exists properties from DirectoryInfo class | | |
8. | Get Creation Time | | |
9. | Get Last Write Time | | |
10. | Get Last Access Time | | |
11. | Calculate Directory Size | | |
12. | Copy Directory | | |
13. | Check the Existance of a Directory | | |
14. | Get Current Directory | | |
15. | Set Current Directory | | |
16. | Traversing Directories | | |
17. | Directory Object | | |
18. | illustrates recursive Directory use | | |
19. | illustrates the Directory class | | |
20. | illustrates the Directory class 2 | | |
21. | Uses the DirectoryInfo class to recursively show subdirectories | | |
22. | Changes the current working directory and then lists the files in the directory | | |
23. | Directory Tree Host | | |
24. | Determine if the directory is empty, ie. no files and no sub-directories | | |
25. | Get an array of files info from a directory. | | |
26. | Removes a directory as best as it can. Errors are ignored. | | |
27. | Directory Class xxposes static methods for creating, moving, and enumerating through directories and subdirectories. | | |
28. | Calculates the size of a directory and its subdirectories, if any, and displays the total size in bytes. | | |
29. | Gets the current working directory of the application. | | |
30. | Directory Class | | |
31. | Calculate the size of a directory and its subdirectories, if any, and displays the total size in bytes. | | |
32. | Creates all directories and subdirectories in the specified path. | | |
33. | Create new nested directories | | |
34. | Deletes an empty directory from a specified path. | | |
35. | Deletes the directory any subdirectories and files in the directory. | | |
36. | Returns an enumerable collection of directory names in a specified path. | | |
37. | Returns an enumerable collection of directory names that match a search pattern in a specified path. | | |
38. | Get collection of directory names that match a search pattern, and optionally searches subdirectories. | | |
39. | Returns an enumerable collection of file names in a specified path. | | |
40. | Returns an enumerable collection of file names that match a search pattern in a specified path. | | |
41. | Get a collection of file names that match a search pattern, and optionally searches subdirectories. | | |
42. | Determines whether the given path refers to an existing directory on disk. | | |
43. | Gets a DirectorySecurity object that encapsulates the access control list (ACL) entries | | |
44. | Gets the creation date and time of a directory. | | |
45. | Gets the creation date and time, in Coordinated Universal Time (UTC) format, of a directory. | | |
46. | Gets the names of subdirectories in the specified directory. | | |
47. | Gets an array of directories matching the specified search pattern from the current directory. | | |
48. | Returns the volume information, root information, or both for the specified path. | | |
49. | Returns the names of files that match the specified search pattern | | |
50. | Returns the names of all files and subdirectories in the specified directory. | | |
51. | Returns the date and time the specified file or directory was last accessed. | | |
52. | Returns the date and time the specified file or directory was last written to. | | |
53. | Sets the date and time the specified file or directory was last accessed. | | |
54. | Sets the date and time a directory was last written to. | | |
55. | Instance methods for creating, moving, and enumerating through directories and subdirectories. | | |
56. | Copy directories with DirectoryInfo | | |
57. | DriveInfo Class Provides access to information on a drive. | | |
58. | Read and Write to a Newly Created Data File | | |
59. | Read Text from a File | | |
60. | File.OpenText returns a StreamReader | | |
61. | Write Text to a File | | |
62. | Copy,delete file and directory | | |
63. | Find all files in a directory, and all files within every nested directory. | | |
64. | Find all files in a directory, and all files within every nested directory. (2) | | |
65. | Current Dir | | |
66. | Directory Walker | | |
67. | Create Directory | | |
68. | Class, which describes folder with its subfolders. | | |