File Stream C#

#region License and Copyright
/* -------------------------------------------------------------------------
 * Dotnet Commons IO
 *
 *
 * This library is free software; you can redistribute it and/or modify it 
 * under the terms of the GNU Lesser General Public License as published by 
 * the Free Software Foundation; either version 2.1 of the License, or 
 * (at your option) any later version.
 *
 * This library is distributed in the hope that it will be useful, but 
 * WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY 
 * or FITNESS FOR A PARTICULAR PURPOSE. See the GNU Lesser General Public License 
 * for more details. 
 *
 * You should have received a copy of the GNU Lesser General Public License 
 * along with this library; if not, write to the 
 * 
 * Free Software Foundation, Inc., 
 * 59 Temple Place, 
 * Suite 330, 
 * Boston, 
 * MA 02111-1307 
 * USA 
 * 
 * -------------------------------------------------------------------------
 */
#endregion
using System;
using System.Collections;
using System.Globalization;
using System.IO;
namespace Dotnet.Commons.IO
{
    ///  
    ///   
    /// This class provides basic facilities for manipulating files and file paths.
    /// 
    /// 

File-related methods


    /// There are methods to 
    /// 
    ///     copy a file to another file,
    ///     compare the content of 2 files,
    ///     delete files using the wildcard character,
    ///     etc
    /// 
    /// 

    ///     
    public sealed class FileUtils
    {
        private static bool hasWildCards(string file)
        {
            return file.IndexOf("*") > -1;
        }
        /// ---------------------------------------------------------------
        /// 
        /// Get all the files that matches a wildcard pattern, eg. (*.tmp)
        /// 

        /// Wildcard pattern to search, eg. (Profile*.doc)
        /// an array of FileInfo objects that results from the wildcard pattern file search
        /// ---------------------------------------------------------------
        public static FileInfo[] GetFilesMatchWildCard(string pathPattern)
        {
            FileInfo[] files = new FileInfo[0];
            if (hasWildCards(pathPattern))
            {
                string dir = Path.GetDirectoryName(pathPattern);
                DirectoryInfo info = new DirectoryInfo(dir);
                string pattern = Path.GetFileName(pathPattern);
                if (info.Exists)
                    files = info.GetFiles(pattern);
            }
            else
            {
                files = new FileInfo[] { new FileInfo(pathPattern.Trim()) };
            }
            return files;
        }
        /// ---------------------------------------------------------------
        /// 
        /// Remove a file or similar files if wildcard is included.
        /// 

        /// path of the file(s) to delete
        /// ---------------------------------------------------------------
        public static void Remove(string path)
        {
            bool hasWildCard = FileUtils.hasWildCards(path);
            if (hasWildCard)
            {
                FileInfo[] filesToRemove = GetFilesMatchWildCard(path);
                foreach (FileInfo file in filesToRemove)
                {
                    // delete each file
                    file.Delete();
                }
                return;
            }
            FileInfo fi = new FileInfo(path);
            if (fi.Exists) fi.Delete();
        }
        /// ---------------------------------------------------------------
        /// 
        /// Remove a file or Directory recursively
        /// 

        /// 
        /// ---------------------------------------------------------------
        public static void RemoveAll(string path)
        {
            if (IsDirectory(path))
            {
                Directory.Delete(path, true);
            }
            else
            {
                if (FileUtils.hasWildCards(path))
                    Remove(path);
                else
                    File.Delete(path);
            }
        }
        /// ---------------------------------------------------------------
        /// 
        /// Determine if a path is the path of a directory.
        /// 

        /// 
        /// true if path is a valid directory, false otherwise
        /// ---------------------------------------------------------------
        public static bool IsDirectory(string path)
        {
            return Directory.Exists(path);
        }
    }
}