Click here to Skip to main content
65,938 articles
CodeProject is changing. Read more.
Articles
(untagged)

C#: Application to Watch a File or Directory using FileSystem Watcher

0.00/5 (No votes)
30 May 2008 2  
This article describesthe usage of the FileSystemWatcher object to watch changes to a file or a directory in C#

FileChangeNotifierV2.JPG

Introduction

In this article I describe the usage of the FileSystemWatcher object provided by VS 2008 (note: This object is same as the one in VS 2005), using C#. The application created here can be used to monitor any file or directory on your system. The generated change list contains notifications for creation, deletion, update or renaming of the file/directory content.

Background

The FileSystemWatcher object provided by .Net is a useful way to monitor a file system. Its definition is contained in the System.IO namespace. This object contains fields to mark which file or directory is to be monitored. Additionally the FileSystemWatcher object allows you to monitor a certain type of files in a directory using wildcards (eg. *.txt).

Using the code

A FileSystemWatcher instance can be created as follows using the new keyword:
m_Watcher = new System.IO.FileSystemWatcher(); 

Then we need to assign it a path and a filter to tell the object where to keep looking.

The line below tells the watcher that it has to keep looking at the path entered in the txtFile textBox. The '\\' characters at the end are to make sure that the path has a directory name. Orelse there will be a problem in case the user enters something like "C:" in the text box.

m_Watcher.Path = txtFile.Text + "\\"; 

Next we need to tell the watcher what all to look at.

The line below tells the watcher what files it is supposed to watch.
m_Watcher.Filter = strFilter;  

The value formats of strFilter and their meanings are as follows:

*.* - Watch all files in the Path
*.ext - Watch files with the extension ext
name.ext - Watch a particular file name.ext

Note that the file name.ext may not exist when the watcher begins watching. But as the file is created/moved to the Path directory, the watcher starts watching the file thereon.

Next we need to tell the watcher what to look for.

The following line does exactly that using various flags, each one describing a certain type of attribute of the file system.

m_Watcher.NotifyFilter = NotifyFilters.LastAccess | 
                         NotifyFilters.LastWrite | 
                         NotifyFilters.FileName | 
                         NotifyFilters.DirectoryName;

We can also tell the watcher to watch for changes to the sub-folders of the directory we specify in the Path by doing the following.

m_Watcher.IncludeSubdirectories = true; 

Next we need to describe what needs to be done when one of these attributes gets altered.

This is done by assigning different event handlers to different activities. In the present application we have used the same event handler for creation, change and deletion. This is done because we just need to log these changes the same way, and the change name is fetched from the argument in the event handler.

m_Watcher.Changed += new FileSystemEventHandler(OnChanged);
m_Watcher.Created += new FileSystemEventHandler(OnChanged);
m_Watcher.Deleted += new FileSystemEventHandler(OnChanged);
m_Watcher.Renamed += new RenamedEventHandler(OnRenamed);

Note that Renamed activity has a different handler. This is because it has a different signature for its event handler. The signatures of both the handlers are as follows.

void OnChanged(object sender, FileSystemEventArgs e)
void OnRenamed(object sender, RenamedEventArgs e)

The change type in both cases can be fetched from the e argument as e.ChangeType

Lastly, we need to tell the watcher to do its job - Watch It!!!

This is done by enabling the watcher to raise events. This is done by the following line.

m_Watcher.EnableRaisingEvents = true;

Once this is done, the watcher keeps watching the assigned file/files or folders and appropriate events will be raised for their respective activities.

Points of Interest

Once the FileSystemWatcher is set to watch a file or folder, it will keep monitoring it till the end of the application. Setting the m_Watcher value to null will not stop it from monitoring. To stop the watcher while the application is still running, we need to stop it from raising events. This is done as follows.

m_Watcher.EnableRaisingEvents = false;

The current version of this application does not work for networked drives or folders shared over the network. I will post the code with this functionality in due time.

History

Version 1.0.0.0 uploaded on 05/31/2008
Version 1.0.0.1 uploaded on 06/01/2008

License

This article has no explicit license attached to it but may contain usage terms in the article text or the download files themselves. If in doubt please contact the author via the discussion board below.

A list of licenses authors might use can be found here