Virtual folder

From Wikipedia, the free encyclopedia
Jump to navigation Jump to search

In computing, a virtual folder generally denotes an organizing principle for files that is not dependent on location in a hierarchical directory tree. Instead, it consists of software that coalesces results from a data store, which may be a database or a custom index, and presents them visually in the format in which folder views are presented. A virtual folder can be thought of as a view that lists all files tagged with a certain tag, and thus a simulation of a folder whose dynamic contents can be assembled on the fly, when requested. It is related in concept to several other topics in computer science, with names including saved search, saved query, and filtering.

Technology[edit]

Virtual folders provide a means for making it easier for users to find files that are content-related, such as by project. The user needs to specify criteria and all files matching the criteria are dynamically aggregated into the virtual folder. Files in a virtual folder are not limited to any single physical location on the hard drive, as is the case with traditional folders, but can be in any location. In fact, files in a virtual folder do not even need to be stored as files on the hard drive. They may be on a network share or in a custom application datastore such as e-mail inbox or even a database.

Documents cannot be "stored" in a virtual folder, since physically a virtual folder is just a file storing a search query. Any attempt to store a file in a virtual folder, depending on the implementation, is redirected to some physical store.

Most implementations speed up searching by pre-indexing the hard drive, or the locations where the search has to be performed. So when searching is to be done, the index, which is a representation of the entire data suitable for fast searching, is used. Since the entire folder hierarchy is not accessed, the search is completed much faster.

Implementations[edit]

Virtual folders are a well-established construct in operating systems. BeOS included a version of virtual folders referred to as "saved queries", that has since influenced the development of virtual folder features in operating systems like Mac OS X, Windows and Linux. These virtual folders are populated dynamically by executing a search on the entire file system, or a subset of it, or by using the cached version of the search.

History[edit]

BeOS[edit]

The initial developer preview of the operating system, released in October 1995, included database-like functionality to make it easier for users to manage their files. To do this the filesystem indexes certain file attributes to allow for fast searching. By default the filesystem indexes the filename, size and last modified timestamp automatically, but could also create indexes for other attributes when told to by either an application or by the user.[1]

When a user performs a file search, a file is created in the folder "/boot/home/queries" with a name derived from the content of the query and the date and time of the search, such as "Name = Western Infirmary - Mar 21, 11:59:40 PM". The query criteria of the search is stored in an attribute of the file called "qrystr".[2] When the file is opened, the filesystem indexes were queried and a Tracker window is opened with an up-to-date list of files that match the criteria.

Additional features were added to search with subsequent releases. Release 2 introduced the ability to edit saved queries,[3] and Release 3 gave the users the chance to define their own names for saved queries.[4] Before Release 4 in 1998, all queries were stored indefinitely. However, with R4, the BeOS developers introduced a seven-day limit on all queries. If a user wanted a query to stay around longer, they could uncheck a "Temporary" flag in the Find dialog.[5]

macOS[edit]

In April 2005, Apple released Mac OS X v10.4, with their implementation of virtual folders called Smart Folders. These folders are dynamically updated by the Spotlight engine to contain content that match certain criteria. For example, this could be used to give you a folder containing all the Word documents containing the word "shpadoinkle" that have been edited within the last 7 days. Smart Folders are created by saving a Spotlight search, which records the search criteria in a Property list file with a .savedSearch extension and, by default, saves them in the "/Users/username/Library/Saved Searches" folder.

Dominic Giampaolo, One of the lead developers of the BeOS filesystem,was also involved in adding a virtual folder system in Apple Inc.'s Mac OS X operating system.[6]

There are many variants of the Smart Folder concept that can be seen in applications that use the Spotlight engine, usually identified by a gear symbol on a purple-hued icon. Examples include: Smart Mailboxes in Mail and Smart Groups in Address Book.

Before Spotlight earlier versions of macOS had a similar concept in the iApps (iTunes and iPhoto), but these did not use the system-wide Spotlight engine.

Microsoft Windows [edit]

Saved Searches[edit]

Saved Searches are recognizable by their distinctive icon and blue color; folders are yellow
Internals of a Saved Search, which display the search query stored in as a .search-ms file.

Windows Vista, released in November 2006, introduced the concept of virtual folders to the Windows platform with the introduction of Saved Searches[a], which aggregate and display items based on their properties rather than folders or hierarchical paths on disk.[8][9] Saved Searches are not folders — they do not store items — they instead are XML files that retain a query for utilization by Windows Search.[7] Saved Searches can be defined based on customizable parameters including dates, metadata, names, paths to search (called the scopes), and item types — such as attachments, communications, documents, emails, folders, programs, photos, tracks, and videos.[10] A similar approach for saving queries exists in Windows XP and the Indexing Service, as searches can be saved as .fnd files;[8][9] however, this only saves the user's search criteria and users must specify the location to search and perform the search again after opening, as results are not dynamic.[9] Query Composition in Windows Vista also allows Saved Searches to scope other Saved Searches to further refine results.[11][12]

By default, Windows Vista references the disk partition and user profile of a created Saved Search as part of its scope, which inhibits their ability to return content from different machines or partitions when transferred to other machines. Microsoft released a SearchMelt Creator utility that changes the scope of Saved Searches to reference the %USERPROFILE% environment variable, which allows them to operate on other machines or profiles; users can also edit Saved Searches manually to reference %USERPROFILE% to facilitate sharing.[13]

"We actually considered at one time not having folders. It was all going to be virtualized storage with search queries and so on. We would just completely abstract the file organization stuff from the physical folders and disk structure. But that was too much of a leap over the chasm, too confusing for users."

Greg Sullivan[14]

Saved Searches additionally allow users to create stacks of data, which are collections of items assembled by properties such as document authors. The same content can appear in more than one stack. Users can, by way of example, first navigate to a specific author stack then to a keyword stack, or to the same keyword stack and to the same author stack without creating new folders or changing the underlying location on disk, which frees users from the limitation of a hierarchical folder structure where one item can only be stored in one location[15] — this liberation from folder hierarchies was a primary benefit and differentiator of WinFS.[16]

All Documents, All Music, All Pictures and Videos and associated Saved Searches in the navigation pane of Windows Vista Beta 1

Pre-release builds of Windows Vista offered significantly different metadata and namespace functionality in contrast to the functionality of the build of Windows Vista released to manufacturing. Microsoft constructed several Saved Searches as part of its goals for a new user profile namespace, which replaced traditional user profile folders. Documents, My Music, and My Pictures on the Start menu were replaced by Saved Searches — All Documents, All Music, and All Pictures and Videos — that searched for documents, music, and photos and videos, respectively, with several other Saved Searches for specific content (e.g., authors for documents) also displayed in the navigation pane of Windows Explorer. When viewing All Music or traditional folders with music, for example, the navigation pane would include Saved Searches for all music, albums, artists, genres, favorite music, and ratings.[11][17][18] Stacks in Saved Searches in pre-release builds of Windows Vista could also be created by users, or write properties to data by drag-and-drop — in a feature known as metadata painting, dragging a document onto an author stack, for example, would assign that author to the document.[19] In later builds, Microsoft replaced these Saved Searches with a single Library Saved Search that aggregated content from all locations with subqueries for individual types (e.g., the Music Library searched Library for all music).[11] Microsoft had sought to include metadata painting and user profile namespace virtual folders since the development of WinFS;[20] the objective was for Saved Searches to become the primary way users interact with data.[14][20] Microsoft reportedly received extensive feedback that these changes were confusing — having Saved Searches in the new user profile namespace caused users to believe there were several folders with similar names.[14]

Accordingly, Microsoft removed the Library Saved Search and its associated subqueries; however, Windows Vista still includes Recent Documents, Recent E-mail, Recent Music, Recent Pictures and Videos, and Recently Changed Saved Searches, all of which use a single Indexed Locations Saved Search in accordance with the previous Library concept.[11] These Saved Searches were previously known as Last 30 Days Documents, Last 7 Days Email, Fresh Tracks, and Last 30 Days Pictures and Videos.[21]

Libraries[edit]

Windows 7 introduces Libraries to display and organize content. Similar to Saved Searches, a Library is an XML file with a unique extension — .library-ms extension — and it is a collection of files organized by specified locations. Unlike Saved Searches, however, users must specify folder locations, and Libraries can display content that does not match the type of the Library (e.g., the Pictures Library may display a document if any subfolders include documents). Libraries have a shell namespace extension in Explorer and their XML files can be reused across Windows installations or the network.

GNOME[edit]

A saved search in GNOME 2.14

In GNOME 2.14, a saved search is a virtual folder whose contents are the result of a Nautilus search, which has multiple backends. The contents of these folders are determined dynamically when the folder is opened, and updated automatically when files are created or modified.

Other implementations[edit]

Email clients[edit]

Virtual folders are also a well-established construct in email clients. In early 1991, the Emacs-based mail reader VM provided a virtual folder facility in its version 5.09.[22][23] VM allows the users to define virtual folders using rules, taking their mail content from one or more physical folders and based on selection criteria dealing with dates, authors, recipient, subject, message body etc. Virtual folders can also be created interactively and take content from previously defined virtual folders, thereby cascading the selection criteria. The Evolution email client created by Helix Code in 2000, also incorporated virtual folders. Folders can be created that automatically list e-mails matching user-defined rules, for example all e-mail from a particular address or all e-mail that includes a specific keyword.[24][25] The Opera web browser released a new mail client (beta in November 2002, final version in Jan 2003), M2 in which virtual folders (called access points) were used for all email management. Virtual folders were automatically made for active contacts, for attachments and for assigned labels. Virtual folders were also automatically generated whenever a search was performed, and manual virtual folders could use multiple logical mail header rules for their construction (including using regular expressions). Microsoft Outlook 2003 added a similar feature called Search Folders. Gmail, first released in 2004, bases all of its mail management on virtual folders accessed via labels. Mozilla Thunderbird also has the ability to create search folders and from version 1.5 allowed the search to be done over more than one email account.[26]

Music clients[edit]

In July 2002, Apple announced version 3 of iTunes which includes Smart Playlists which can be considered a variant of a virtual folder.[clarification needed] The only difference is that the search executed on accessing them is not on the file system's folder hierarchy, but on their internal data-store.[27] Microsoft also added a similar feature to version 9 of Windows Media Player in Windows XP called Auto Playlists in 2003.[28]

See also[edit]

Notes[edit]

  1. ^ Saved Searches are also referred to as Search Folders[7]

References[edit]

  1. ^ Scot Hacker (1999). The BeOS Bible. Peachpit Press. ISBN 0-201-35377-6.
  2. ^ Chris Herborth. "Show formula query strings in Tracker". The BeOS Tip Server. Retrieved 2007-03-22.
  3. ^ Be Inc. (October 7, 1997). "Be Ships BeOS Preview Release 2". Be Inc. Archived from the original on May 20, 1998. Retrieved 2006-12-24.
  4. ^ Be Inc. "Searching on the BeOS". The BeOS Tip of the Week. Be Inc. Archived from the original on 2002-07-24. Retrieved 2006-12-24.
  5. ^ Scot Hacker. "Self-destructing queries". The BeOS Tip Server. Retrieved 2007-03-22.
  6. ^ Dominic Giampaolo. "Personal homepage". Retrieved 2006-09-10.
  7. ^ a b Microsoft. "Saved Search File Format". MSDN. Retrieved November 11, 2015.
  8. ^ a b Price, John. "Windows Vista Virtual Folders and Search". MSDN. Microsoft. Retrieved October 23, 2015.
  9. ^ a b c Shultz, Greg (October 12, 2005). "An in-depth look at Windows Vista's Virtual Folders technology". TechRepublic. CBS Interactive. Retrieved November 15, 2015.
  10. ^ Kaelin, Mark (July 17, 2007). "How do I... Save and refine desktop searches in Microsoft Windows Vista?". TechRepublic. CBS Interactive. Retrieved November 11, 2015.
  11. ^ a b c d Bentz, Ben (October 31, 2006). "Query Composition: Building a search upon another search". Shell: Revealed Blog. Microsoft. Archived from the original on December 15, 2006. Retrieved October 20, 2015.
  12. ^ Shultz, Greg (December 11, 2007). "Narrow a saved search with Vista's Query Composition feature". TechRepublic. CBS Interactive. Retrieved November 11, 2015.
  13. ^ White, Nick (May 14, 2007). "Searcing, part III: Do you know what a SearchMelt is?". Windows Vista Team Blog. Microsoft. Archived from the original on May 16, 2007. Retrieved October 20, 2015.
  14. ^ a b c Thurrott, Paul (December 21, 2005). "Windows Vista December 2005 CTP (Build 5270) Review Part 1: Setup and User Interface". SuperSite for Windows. Penton. Archived from the original on December 23, 2005. Retrieved October 13, 2015.CS1 maint: unfit URL (link)
  15. ^ "Windows Vista Product Guide". Microsoft. 2006. pp. 44–51. Archived from the original (DOCX) on July 1, 2011. Retrieved March 1, 2018.
  16. ^ "Remarks by Bill Gates, Chairman and Chief Software Architect, Microsoft CorporationMicrosoft Professional Developers Conference 2003". Microsoft. October 27, 2003. Archived from the original on February 3, 2004. Retrieved April 27, 2021. HILLEL COOPERMAN: "All right, one more thing. You might say, 'Well, I understand that these [stack] views [in WinFS] are generated dynamically. I understand this is all based on this structured metadata that Bill [Gates] was talking about, but I could kind of approximate this with folders today. I could make a bunch of folders for authors, and then in them have project folders.' I'll tell you something you couldn't do. You couldn't do it, have that exist, and do the reverse; for example, be able to navigate first author, then project or first project then author.
  17. ^ Thurrott, Paul (October 6, 2010). "Working with Display Drivers in Windows Vista Beta 1". SuperSite for Windows. Penton. Retrieved November 11, 2015.
  18. ^ Lee, Wei-Meng (August 2, 2005). "An In-Depth Look at Vista, Part 2". O'Reilly Media. Retrieved November 11, 2015.
  19. ^ "Windows Vista First Hands-On Walkthrough of Microsoft's New 'Longhorn'". PCMag. Ziff Davis Media. September 6, 2005. p. 108. Retrieved October 25, 2015. When you create a stack based on a keyword, files added to that stack receive the keyword automatically.
  20. ^ a b "WinFS: The Windows File System (Microsoft Access 2002 Technical Articles)". MSDN. Microsoft. October 2003. Archived from the original on 2003-12-21. Retrieved February 1, 2018.
  21. ^ Shinder, Deb (July 12, 2006). "More than just a pretty interface: File management with Vista Explorer". TechRepublic. CBS Interactive. Retrieved November 22, 2016.
  22. ^ Kyle Jones. "VM User's Manual - Virtual Folders". Wonderworks. Retrieved 2010-01-26.
  23. ^ Phil Sung. "VM Configuration and Workflow". Retrieved 2010-03-13.
  24. ^ Michael Hall (June 30, 2000). "You Say You Want an Evolution". Linux Planet. Retrieved 2006-12-24.
  25. ^ Dave Whitinger (July 8, 1999). "Dave Whitinger and Miguel de Icaza at the ZD Open Source Forum". Linux Today. Retrieved 2006-12-24.
  26. ^ "Saved Search - MozillaZine Knowledge Base". Retrieved 2010-01-22.
  27. ^ Apple (July 17, 2002). "Apple Announces iTunes 3". Apple. Archived from the original on July 26, 2006. Retrieved December 25, 2006.
  28. ^ Microsoft (January 3, 2003). "Microsoft Announces Digital Media Upgrade for Windows XP With Final Release of Windows Media Player 9 Series and Windows Movie Maker 2". Microsoft. Retrieved 2006-12-25.