Fast File Finder Fast File Finder
home Student Projects no local find frame, full screen Google search web for topic jump to footer translate with Babelfish by Roedy Green ©1996-2008 Canadian Mind Products
This essay is about a suggested student project in Java programming. This essay gives a rough overview of how it might work. It does not describe an actual complete program. I have no source, object, specifications, file layouts or anything else useful to implementing this project. Everything I have to say to help you with this project is written below. I am not prepared to help you implement it; I have too many other projects of my own.

I do contract work for a living, which could include writing a program such as this. However, I don’t do people’s homework for them. That just robs them of an education.

You have my full permission to implement this project any way you please.

The File Find that comes with Windows a is inept. It is very slow because uses a brute force search of the entire disk. When it shows you the results it won’t let you copy/paste them. Why else were you looking?

Your task is to write a platform independent Fast File Find. I suggest you tackle it like this:

  1. Create a SQL database of all the filenames in the system.
  2. Ask SQL to build three indexes, by directory name, by filename, and by extension.
  3. When you get a request, analyse the wild card and convert it into a SQL query on those three fields. SQL will be clever and use its indexes or brute force if necessary. In any case it will always be faster than the Windows File Find since its database is contiguous. The directory that Windows searches can be scattered higgledy piggledy all over the disk.
  4. If you don’t want to use SQL, you will need some sort of treemap/btree indexed file manager. Btrieve will let you package their product free with your apps, but that only covers Windows.
  5. Allow copy to the clipboard of any result with a single click, as well as the traditional ways.
  6. Allow launch of any of the result files with a double click, ideally support everything in the Windows right click menu for that file type.
  7. Now for the hard part. How do you keep your SQL database up to date?
  8. Now you can get a little clever. You can do lazy updates of deleted files, procrastinating discovering and telling your SQL database about them. Don’t bother checking if the files exist until they show up in a result list of someone’s SQL query. Then at the last second check if the files still exist, and update the SQL database accordingly. You can also discover them with a low priority background process.
  9. Of course you want something that at 3 AM refreshes the database and ensures it is not corrupt in any way and is 100% up-to-date.
  10. For bonus points, in your displays, mark files that are in-use, or open-for-write. You can use File.canWrite or some platform specific code to find files that are being read too.
  11. Consider a more elaborate user interface that looks something like this:

    If the above FileFinder Java Applet does not work…

    1. This Java Applet needs Java 1.1 or later, ideally version 1.6.0_06 and a recent browser.
    2. You should see an Applet above looking much like the screenshot. If you don’t, the following should help you get it working:
    3. If you are using Microsoft Internet Explorer, try another browser. Seriously. Microsoft has taken great pains, over and over, to screw up Java and every other mult-platform standardisation.
    4. If you are using Internet Explorer 7, you must allow blocked content permission for Active X to run. This also gives permission to Java to run. Click the Information bar, and then click Allow blocked content. Unfortunately, this also allows dangerous ActiveX code to run. However, you must do this in order to get access to perfectly-safe Java Applets running in a sandbox. This is part of Microsoft’s war on Java. Don’t put up with it! Use a different browser.
    5. To ensure your Java is up to date, check with Wassup.
    6. If the above Java Applet does not work, check the Java console for error messages.
    7. If the above Applet does not work, you might have better luck with the downloadable version.
    8. If you still can’t get the program working click HELP for more detail.
    9. If you can’t get the program working after trying the advice above and from the HELP button below, have bugs to report or ideas to improve the program or its documentation, please send me an email atemail Roedy Green.
    Java powered   Get New Java  Get New Browser   Help

Why JNI?

You could do this by polling directories in a platform-independent way. Why would You want to take the clean, system-independent Java solution and replace it with a half-dozen native implementations?

The reasons I originally wanted to write a file find to replace Microsoft’s are:

  1. I wanted it much faster.
  2. I wanted it low overhead.
  3. I wanted it up-to-date. I most often search for a file that I recently saved under the wrong name.
Given that a Java method for a global hook in a platform-independent way to monitor changes is not available, and polling is both slow and a huge drain on resources, I see no alternative but JNI or other native hook for an efficient implementation. Think of it as doing Sun’s work for them, providing the hook to everyone (who has sufficient priviledge).

One nice thing about native classes is you can add more implementations later without disturbing existing code. JAWS selects the right library for you.

FindCat

I experimented with Robert Swanson’s beta implementation of a fast file finder called FindCat32. It sooo fast! I find myself using it far more frequently than I ever used the Windows equivalent. It is even faster to use it to find a file than to click to it with the Windows Explorer, even when you know exactly where it is. FindCat32 also lets you push the filename to the clipboard which saves retyping. FindCat does not let you use wildcards, or regexes, and it does not monitor file changes, but those features may be in the pipe. It uses a fairly simple flat file structure with various indexes.

Desktop Google has provided a fast search, but by content, not by name.

Copernic
file monitor
Google Desktop
JNotify

CMP_homejump to top
CMP logo
feedback Please email your feedback for publication, errors, omissions, broken/redirected link reports
and suggestions to improve this page to Roedy Green : feedback email
made with CSS
HTML Checked!
ICRA ratings logo
mindprod.com IP:[65.110.21.43]
Your face IP:[38.103.63.18] Spread the Net
You are visitor number 6,983.
You can get a fresh copy of this page from: or possibly from your local J: drive (Java virtual drive/Mindprod website mirror)
http://mindprod.com/project/filefinder.html J:\mindprod\project\filefinder.html