Modern data processing systems, such as general purpose computer systems, allow the users of such systems to create a variety of different types of data files. For example, a typical user of a data processing system may create text files with a word processing program such as Microsoft Word or may create an image file with an image processing program such as Adobe's PhotoShop. Numerous other types of files are capable of being created or modified, edited, and otherwise used by one or more users for a typical data processing system. The large number of the different types of files that can be created or modified can present a challenge to a typical user who is seeking to find a particular file which has been created.
Modern data processing systems often include a file management system which allows a user to place files in various directories or subdirectories (e.g. folders) and allows a user to give the file a name. Further, these file management systems often allow a user to find a file by searching for the file's name, or the date of creation, or the date of modification, or the type of file. An example of such a file management system is the Finder program which operates on Macintosh computers from Apple Computer, Inc. of Cupertino, Calif. Another example of a file management system program is the Windows Explorer program which operates on the Windows operating system from Microsoft Corporation of Redmond, Wash. Both the Finder program and the Windows Explorer program include a find command which allows a user to search for files by various criteria including a file name or a date of creation or a date of modification or the type of file. However, this search capability searches through information which is the same for each file, regardless of the type of file. Thus, for example, the searchable data for a Microsoft Word file is the same as the searchable data for an Adobe PhotoShop file, and this data typically includes the file name, the type of file, the date of creation, the date of last modification, the size of the file and certain other parameters which may be maintained for the file by the file management system.
Certain presently existing application programs allow a user to maintain data about a particular file. This data about a particular file may be considered metadata because it is data about other data. This metadata for a particular file may include information about the author of a file, a summary of the document, and various other types of information. A program such as Microsoft Word may automatically create some of this data when a user creates a file and the user may add additional data or edit the data by selecting the “property sheet” from a menu selection in Microsoft Word. The property sheets in Microsoft Word allow a user to create metadata for a particular file or document. However, in existing systems, a user is not able to search for metadata across a variety of different applications using one search request from the user. Furthermore, existing systems can perform one search for data files, but this search does not also include searching through metadata for those files.
Methods for managing data in a data processing system and systems for managing data are described herein.
According to one aspect described herein, an exemplary embodiment includes a hierarchy of saved search folders, which may be referred to as “smart” folders. A first folder represents a first search query, and a second folder represents a second search query. The second folder may be nested graphically within the first folder or otherwise portrayed in a predetermined hierarchical relationship between the two folders. Opening the first folder reveals the search results of a first search query and opening the second folder displays the search results of the second search query. The predetermined relationship between the folders may be defined by user metadata. This embodiment allows the use of relationships of metadata to build a view of user files and to allow the user to browse the files within a system using that view. In one particular embodiment, the second folder may be portrayed in a graphical user interface system as a subfolder of the first folder. The view of files provided by the user metadata and the saved search folders may be different than a view provided by a file management system (e.g. Windows Explorer or the Finder on a Macintosh) which provides a graphical view based on the relative location in a file directory.
In another aspect of this description, an exemplary method of processing a result of a search operation includes receiving an input of a search operation and performing the search operation, and displaying a list of results from the search operation, where the list presents N items which is less than M items found from the search operation. In one embodiment, the N items are the N most relevant hits in the results. The list is typically grouped by categories and the number of items within each category is also limited to less than N. Typically the list is a non-scrollable list which is sorted by recency and relevance and includes a command to show all items since less than all items are shown in the list.
In another aspect of the disclosure, an exemplary embodiment of a method for handling data includes storing on a volume an index created from files and metadata for the files with an operating system and making the volume available for distribution to licensees or customers. Typically, the index is created for all user related files beyond merely help files, such as all files normally accessible to a user through the standard use of word processing programs, spreadsheet programs, presentation programs, graphics programs or other types of software. This index is stored with the user related files and with an operating system on a volume, which is made available for distribution to licensees or customers. These volumes may, for example, be CD ROMs or DVD ROMs or a bootable magnetic hard drive which is shipped with a newly manufactured computer system.
In another aspect of the disclosure, an exemplary embodiment of a method for processing data includes displaying an open file window, displaying a search input field to allow entry of a search query to find a file within the open file window, receiving a search query and performing a search, and displaying a result of a search within the open file window. Typically, the open file window is invoked by using a “open” command or an “open file” command from an application program such as a word processing program (e.g. Microsoft Word) or a spreadsheet program (e.g. Excel), or a presentation program (e.g. Keynote or PowerPoint), or a graphics program (e.g. PhotoShop), etc. The open file window typically provides an interface allowing the user to select the folder within which files may exist. The user can select the file which is displayed within a particular folder and then activate an “open” button to cause the file to be opened within the application from which the open file window was invoked.
According to another aspect of the present description, an exemplary embodiment of a method for processing data includes displaying text within a text processing application, receiving a selection of at least some of the text, receiving a selection of a command to search a plurality of files using the selection, and displaying results of a search of the plurality of files. The selection may be through a pop-up menu which appears associated with the selected text within the text processing application, such as a word processing application or an email application.
In another aspect of the present disclosure, an exemplary method for processing data includes displaying a search input parameter and interface which displays an expandable plurality of metadata search attributes, and receiving a selection of a particular metadata search attribute from the display of the expandable plurality of metadata attributes. The selection of a particular metadata search attribute is typically used in forming a search query.
In another aspect of the present description, an exemplary embodiment of a method for processing data includes receiving a command to perform a search for content and/or metadata of content, displaying search results and a search window, creating or receiving new documents, some of which may match or satisfy the search query while the search window is open, and updating the search results in the search window dynamically as the new documents are created or received. New documents which match the search query, as they are created or received, appear within the search window without having to open or close the search window or without having to select a command to refresh the search window. Thus, it appears as if the search window is updated live as new documents are created or received in the system.
A method of managing data in one exemplary embodiment includes capturing metadata from a plurality of files having different file types (and having different metadata content for the different file types) or created by a plurality of different software applications which execute on a data processing system. The type of information in the metadata for the files of a first software application differs from the type of information in metadata for files of a second software application. This captured metadata may be searched. In one embodiment, this search may occur concurrently for all of the metadata from the different files created by or used by the different software applications. In one implementation of this method, a single search interface may be provided to search all of the metadata for all of the different files created by the different software applications, thereby allowing a single search to search through all of the metadata for all of the files created by the different software applications. Further, the single search may also search through non-metadata such as the indexed (or non-indexed) content of the actual data files.
According to another aspect of the invention, an exemplary method includes capturing metadata from a plurality of different files created by a plurality of different software applications and storing the metadata on a storage medium in a flat file format. Another aspect relates to a flat file format for the metadata on the storage medium.
Another aspect of the present invention relates to various user interfaces which may be provided by a system to allow a user to search through the metadata. In one exemplary embodiment of such a user interface, the method includes capturing metadata from a plurality of files created by a plurality of different software applications and displaying a search input interface for searching through the metadata, wherein the type of information in metadata for files of a first software application differs from the type of information in metadata for files of a second software application. Various implementations of user interfaces are discussed for search input and also for the presentation (e.g. display) of search results. For example, the search results may be displayed in multiple different formats (e.g. list view, icon view, column view) and they may be displayed with headers or titles which separate the groups of matches in a search results list. Further, the displayed results may be limited to a predetermined number (or a dynamically generated number) for each category so that a limited viewing can still display multiple categories within a search result window. Further, a search query can be saved as a folder which appears within a user configurable portion of the search results window, and a selection of the folder causes another search to be performed using the saved search query (sometimes also referred to as search criteria). A display of the search results from the saved search query can then be sorted or further searched to limit the results to a subset of the original matches from the saved search query. Numerous other user interface implementations are shown and described. Another user interface feature includes the ability to provide both a list view and another view (e.g. icon view) for different portions (e.g. different categories) of a search results window.
Another aspect of the present invention relates to a software architecture for managing metadata. One exemplary embodiment of this architecture includes a first plurality of application programs which are capable of creating a plurality of different data files and a metadata management program which is coupled through programming interfaces with the first plurality of application programs and which is coupled to a file system storage of metadata which is captured from files created by the first plurality of application programs. Normally, the type of information in metadata for files of a first application program differs from the type of information in metadata for files of a second application program. The metadata management program is also coupled to other (non-metadata) sources of information about the data files such as an indexed database of the full text content of the data files and software which is capable of searching this indexed database. Search queries which are directed to the metadata may also be concurrently directed to the non-metadata sources so that the search results include matches from both the metadata and the non-metadata sources, and these searches, through both metadata and non-metadata sources, may be in response to a single search query or a single search request or command and these searches may be performed concurrently.
Another aspect of the inventions described herein relates to one or more importers which interact with new or modified files created by different application programs. These one or more importers may be invoked (e.g. called) by the application programs or by an operating system component (e.g. a metadata processing software) which responds to a call from the application programs or from an operating system kernel. In one particular example, an importer is called by a metadata processing software in response to a notification from an OS kernel that a new file has been created or an existing file has been modified; in this case, the particular importer called by the metadata processing system will typically depend upon the type of file (e.g. text file or image file or MP3 file, etc.), although one, single importer for all file types on a system may be used regardless of the type of file. An importer will typically specify a file path name for the extracted metadata and specify selected data to be extracted and written into the file path name of the file containing the extracted metadata.
Another aspect of the inventions described herein relates to performing a search through a system while receiving input from a user, where the search is through a plurality of data files created by different software applications on a data processing system. In an exemplary method of this aspect, the data processing system begins a search through the plurality of data files as the user enters input and before the user completes the entry of the search query. Thus, a user may enter a search (“quick brown fox”) and before the user has entered “fox,” the data processing system has searched through, or begins to search through, the plurality of data files created by different software applications and has displayed the list of matches to the partial search query “quick brown” (or at least begins to display a partial list of matches to the partial search query “quick brown”). This search may be performed through the plurality of data files as well as the metadata for the plurality of data files, wherein the type of information in metadata for files of a first software application differs from the type of information in metadata for files of a second software application. The search results may be sorted by relevancy, and the system may display first only a partial list of matches and then, in response to a user request, display all the matches. The search results may be organized by categories (e.g. see
Another aspect of the inventions relates to a method of selecting a group of items, such as a group of individual data files. In an exemplary method of this aspect, a data processing system receives a selection of a plurality of items such as data files, folders (e.g. graphical user interface representations of subdirectories), application programs or a combination of one or more of these items. This selection may be performed by one of the many conventional ways to select a plurality of items such as (a) pointing a cursor at each item individually (e.g. through movement of a mouse) and indicating a selection individually by, for example, pressing and releasing a button such as a mouse's button; (b) pointing a cursor at a first item in a list and indicating a selection of the first item and pointing the cursor at a last item in a list of items and indicating a selection of all items from the first item to the last item in the list; (c) drawing a selection rectangle by a dragging operation of the cursor, etc. After the selection of the plurality of items has been received, the data processing system receives a command to create a new folder and add or move, e.g. in one operation, the selected plurality of items into the new folder. The add operation creates the new folder (optionally with a name specified by the user as a result of a prompt or request by the system) and copies the selected files into the new folder, which represents a new subdirectory. This add operation is in response to the single command which requests that a new folder be created and that copies of the selected items be created and stored with a path name reflecting storage within the new folder. The move operation also creates a new folder (optionally with a name specified by the user as a result of a prompt or request by the system) and may merely change the path names associated with each of the selected items, which changed path names reflect the new file system location (within the subdirectory of the new folder) of the selected items.
Other aspects of the present invention include various data processing systems which perform these methods and machine readable media which perform various methods described herein.
The present invention is illustrated by way of example and not limitation in the figures of the accompanying drawings in which like references indicate similar elements.
The subject invention will be described with reference to numerous details set forth below, and the accompanying drawings will illustrate the invention. The following description and drawings are illustrative of the invention and are not to be construed as limiting the invention. Numerous specific details are described to provide a thorough understanding of the present invention. However, in certain instances, well known or conventional details are not described in order to not unnecessarily obscure the present invention in detail.
The present description includes material protected by copyrights, such as illustrations of graphical user interface images. The owners of the copyrights, including the assignee of the present invention, hereby reserve their rights, including copyright, in these materials. The copyright owner has no objection to the facsimile reproduction by anyone of the patent document or the patent disclosure, as it appears in the Patent and Trademark Office file or records, but otherwise reserves all copyrights whatsoever. Copyright Apple Computer, Inc. 2005.
As shown in
It will be apparent from this description that aspects of the present invention may be embodied, at least in part, in software. That is, the techniques may be carried out in a computer system or other data processing system in response to its processor, such as a microprocessor, executing sequences of instructions contained in a memory, such as ROM 107, RAM 105, mass storage 106 or a remote storage device. In various embodiments, hardwired circuitry may be used in combination with software instructions to implement the present invention. Thus, the techniques are not limited to any specific combination of hardware circuitry and software nor to any particular source for the instructions executed by the data processing system. In addition, throughout this description, various functions and operations are described as being performed by or caused by software code to simplify description. However, those skilled in the art will recognize what is meant by such expressions is that the functions result from execution of the code by a processor, such as the microprocessor 103.
Capturing and Use of Metadata Across a Variety of Application Programs
The method of
The method of
One particular field which may be useful in the various metadata formats would be a field which includes an identifier of a plug in or other software element which may be used to capture metadata from a data file and/or export metadata back to the creator application.
Various different software architectures may be used to implement the functions and operations described herein. The following discussion provides one example of such an architecture, but it will be understood that alternative architectures may also be employed to achieve the same or similar results. The software architecture shown in
The software architecture 400 also includes a file system directory 417 for the metadata. This file system directory keeps track of the relationship between the data files and their metadata and keeps track of the location of the metadata object (e.g. a metadata file which corresponds to the data file from which it was extracted) created by each importer. In one exemplary embodiment, the metadata database is maintained as a flat file format as described below, and the file system directory 417 maintains this flat file format. One advantage of a flat file format is that the data is laid out on a storage device as a string of data without references between fields from one metadata file (corresponding to a particular data file) to another metadata file (corresponding to another data file). This arrangement of data will often result in faster retrieval of information from the metadata database 415.
The software architecture 400 of
The method of
It will be appreciated that the notification, if done through the OS kernel, is a global, system wide notification process such that changes to any file will cause a notification to be sent to the metadata processing software. It will also be appreciated that in alternative embodiments, each application program may itself generate the necessary metadata and provide the metadata directly to a metadata database without the requirement of a notification from an operating system kernel or from the intervention of importers, such as the importers 413. Alternatively, rather than using OS kernel notifications, an embodiment may use software calls from each application to a metadata processing software which receives these calls and then imports the metadata from each file in response to the call.
As noted above, the metadata database 415 may be stored in a flat file format in order to improve the speed of retrieval of information in most circumstances. The flat file format may be considered to be a non-B tree, non-hash tree format in which data is not attempted to be organized but is rather stored as a stream of data. Each metadata object or metadata file will itself contain fields, such as the fields shown in the examples of
A flexible query language may be used to search the metadata database in the same way that such query languages are used to search other databases. The data within each metadata file may be packed or even compressed if desirable. As noted above, each metadata file, in certain embodiments, will include a persistent identifier which uniquely identifies its corresponding data file. This identifier remains the same even if the name of the file is changed or the file is modified. This allows for the persistent association between the particular data file and its metadata.
User Interface Aspects
Various different examples of user interfaces for inputting search parameters and for displaying search results are provided herein. It will be understood that some features from certain embodiments may be mixed with other embodiments such that hybrid embodiments may result from these combinations. It will be appreciated that certain features may be removed from each of these embodiments and still provide adequate functionality in many instances.
The combination of text entry region 709 and the search parameter menu bar allow a user to specify a search query or search parameters. Each of the configurable pull down menus presents a user with a list of options to select from when the user activates the pull down menu. As shown in
It will also be appreciated that the various options in the pull down menus may depend upon the fields within a particular type of metadata file. For example, the selection of “images” to be searched may cause the various fields present in the metadata for an image type file to appear in one or more pull down menus, allowing the user to search within one or more of those fields for that particular type of file. Other fields which do not apply to “images” types of files may not appear in these menus in order reduce the complexity of the menus and to prevent user confusion.
Another feature of the present invention is shown in
The window 1001 includes an additional feature which may be very useful while analyzing a search result. A user may select individual files from within the display region 1005 and associate them together as one collection. Each file may be individually marked using a specific command (e.g. pressing the right button on a mouse and selecting a command from a menu which appears on the screen, which command may be “add selection to current group”) or similar such commands. By individually selecting such files or by selecting a group of files at once, the user may associate this group of files into a selected group or a “marked” group and this association may be used to perform a common action on all of the files in the group (e.g. print each file or view each file in a viewer window or move each file to a new or existing folder, etc.). A representation of this marked group appears as a folder in the user-configurable portion 1003A. An example of such a folder is the folder 1020 shown in the user-configurable portion 1003A. By selecting this folder (e.g. by positioning a cursor over the folder 1020 and pressing and releasing a mouse button or by pressing another button) the user, as a result of this selection, will cause the display within the display region 1005 of the files which have been grouped together or marked. Alternatively, a separate window may appear showing only the items which have been marked or grouped. This association or grouping may be merely temporary or it may be made permanent by retaining a list of all the files which have been grouped and by keeping a folder 1020 or other representations of the grouping within the user-configurable side bar, such as the side bar 1003A. Certain embodiments may allow multiple, different groupings to exist at the same time, and each of these groupings or associations may be merely temporary (e.g. they exist only while the search results window is displayed), or they may be made permanent by retaining a list of all the files which have been grouped within each separate group. It will be appreciated that the files within each group may have been created from different applications. As noted above, one of the groupings may be selected and then a user may select a command which performs a common action (e.g. print or view or move or delete) on all of the files within the selected group.
The window 1201 shown in
A column 1211 of window 1201 allows a user to select various search parameters by selecting one of the options which in turn causes the display of a submenu that corresponds to the selected option. In the case of
The window 1301 shown in
A saved search folder may also be created before doing a search rather than after a search has been performed. An exemplary method for creating a saved search folder before a search is performed is shown in
One attribute of windows which display search results, according to at least certain embodiments of the present invention, is the ability for live updating, wherein the results in the search results window are dynamically updated as new documents are created or received by the system which is executing the search.
The user interface provided by a hierarchy of saved search folders provides a powerful mechanism to browse user files on a data processing system. In the example shown in
The search results user interface shown in
It will be appreciated that this method may employ various alternatives. For example, a window may appear after the command option 2232 or 2233 has been selected, and this window asks for a name for the new folder. This window may display a default name (e.g. “new folder”) in case the user does not enter a new name. Alternatively, the system may merely give the new folder or new storage facility a default path name. Also, the system may merely create the new folder and move or copy the items into the new folder without showing the new window as shown in
Another aspect of certain embodiments of aspects described herein relate to the presentation of a limited number of items found from a search query rather than displaying a full list of items found from the search query. In a particular implementation, shown in
When a volume has not been previously indexed, the user may still cause the volume to be indexed. This may happen automatically as a consequence of attaching the volume (e.g. attaching a hard drive which is portable and which includes a USB interface to a computer system through a USB port, etc.) or as a result of the user instructing the system to do so through a command on a graphical user interface. In either case, it may take some time to index the volume, and a progress bar, such as the progress bars 4607 or 4707 may be displayed while this indexing is being performed. In one implementation (e.g. the example shown in
In certain embodiments, it may be desirable to provide the user with the ability to set preferences for the searching functions provided by the various embodiments described herein.
The window 5701a is displayed in response to activating the results window 5705. This window includes a list 5800, which is a list of the various categories which appear in the search result windows, such as the window of
There are many different types of files which presently exist (e.g. word processing files, spreadsheet files, presentation files, email files, html files, PDF files, various types of image files, etc.). As a result, there are many different types of data which can exist as metadata for any one type of file. This can be seen from the large table shown herein which gives an example of metadata for certain types of files. Furthermore, through changes in file types, the creation of new types of software applications, and the creation of importers to input data from a file into a metadata database, it is apparent that the types of metadata can expand in the future. Thus, a list of metadata attributes should be expandable, and in certain embodiments of the present invention, it is expandable. It may be made expandable through the use of an interface which allows for the selection of “other” metadata or search attributes.
An optional privacy feature may be included with one or more of the various embodiments described herein. This privacy feature, if enabled, causes the system to determine that a user has stopped inputting search queries after a period of time (e.g. after N minutes which may be 5 minutes, etc.), and if the user has stopped, the system stops updating (e.g. as in
At least certain embodiments of the various inventions allow for the searching of system preference or system setting or system configuration files or data structures through the use of a searching utility. For example, a system wide searching utility may be used to search for a system preference or system setting or system configuration file or data structure by entering the name or a synonym of the system preference or system setting or system configuration file or data structure. Metadata and/or content of the system preference or system setting or system configuration file or data structure may be searched by the searching utility and cause the system preference or system setting or system configuration file or data structure to be retrieved as one of the search results and then opened from the list of search results. In this exemplary manner, the search utility can open a particular system preference or system setting or system configuration file or data structure through a search process.
At least certain embodiments of the various embodiments provide intelligent mail boxes in email software. In one exemplary embodiment, the email software includes “in boxes” or folders which contain new or received email and these folders or “in boxes” (or mail boxes) may be configured to act as smart folders to automatically search through incoming email and segregate the email based on the saved search queries associated with each of the email in boxes which act in a manner which is similar to the way smart folders act. Also see U.S. Pat. No. 6,243,724 in connection with this type of email box. The email software may be configured to allow multiple folders, each of which or at least one of which may be defined as having a saved search query which is automatically used to search through newly received emails and, if any of the emails match the search query, the email is moved to the folder or “in box” (or the email is copied and the copy is moved to the folder). Thus, these folders automatically move emails from a general in box to folders or specific “in boxes” which are specified by a search query.
In the foregoing specification, the invention has been described with reference to specific exemplary embodiments thereof. It will be evident that various modifications may be made thereto without departing from the broader spirit and scope of the invention as set forth in the following claims. The specification and drawings are, accordingly, to be regarded in an illustrative sense rather than a restrictive sense.
This application is a divisional of U.S. patent application Ser. No. 11/351,249 filed on Feb. 8, 2006, now issued as U.S. Pat. No. 9,063,942, which is a divisional of U.S. patent application Ser. No. 11/112,350, filed on Apr. 22, 2005, now issued as U.S. Pat. No. 7,437,358, which is a continuation-in-part of co-pending U.S. patent application Ser. No. 10/877,584, filed on Jun. 25, 2004, now issued as U.S. Pat. No. 7,730,012, which also claims priority to U.S. Provisional Patent Application No. 60/643,087 filed on Jan. 7, 2005, which provisional application is incorporated herein by reference in its entirety; this application claims the benefit of the provisional's filing date under 35 U.S.C. §119(e). This present application hereby claims the benefit of these earlier filing dates under 35 U.S.C. §120.
Number | Name | Date | Kind |
---|---|---|---|
4270182 | Asija | May 1981 | A |
4704703 | Fenwick | Nov 1987 | A |
4736308 | Heckel | Apr 1988 | A |
4939507 | Beard et al. | Jul 1990 | A |
4985863 | Fujisawa et al. | Jan 1991 | A |
5008853 | Bly et al. | Apr 1991 | A |
5072412 | Henderson, Jr. et al. | Dec 1991 | A |
5161223 | Abraham | Nov 1992 | A |
5228123 | Heckel | Jul 1993 | A |
5231578 | Levin et al. | Jul 1993 | A |
5241671 | Reed et al. | Aug 1993 | A |
5319745 | Vinsonneau et al. | Jun 1994 | A |
5355497 | Cohen-Levy | Oct 1994 | A |
5392428 | Robins | Feb 1995 | A |
5437029 | Sinha | Jul 1995 | A |
5497484 | Potter et al. | Mar 1996 | A |
5504852 | Thompson-Rohrlich | Apr 1996 | A |
5544360 | Lewak et al. | Aug 1996 | A |
5557793 | Koerber | Sep 1996 | A |
5592608 | Weber et al. | Jan 1997 | A |
5623681 | Rivette et al. | Apr 1997 | A |
5659735 | Parrish et al. | Aug 1997 | A |
5668966 | Ono et al. | Sep 1997 | A |
5689665 | Mitsui et al. | Nov 1997 | A |
5710844 | Capps et al. | Jan 1998 | A |
5761655 | Hoffman | Jun 1998 | A |
5761678 | Bendert et al. | Jun 1998 | A |
5828376 | Solimene et al. | Oct 1998 | A |
5832500 | Burrows | Nov 1998 | A |
5844554 | Geller | Dec 1998 | A |
5845301 | Rivette et al. | Dec 1998 | A |
5890147 | Peltonen et al. | Mar 1999 | A |
5913215 | Rubinstein et al. | Jun 1999 | A |
5950190 | Yeager et al. | Sep 1999 | A |
5966710 | Burrows | Oct 1999 | A |
5983248 | DeRose et al. | Nov 1999 | A |
6003034 | Tull | Dec 1999 | A |
6012053 | Pant et al. | Jan 2000 | A |
6026404 | Adunuthula et al. | Feb 2000 | A |
6055543 | Christensen et al. | Apr 2000 | A |
6061692 | Thomas et al. | May 2000 | A |
6067541 | Raju et al. | May 2000 | A |
6078924 | Ainsbury et al. | Jun 2000 | A |
6115717 | Mehrotra et al. | Sep 2000 | A |
6119118 | Kain, III et al. | Sep 2000 | A |
6185574 | Howard et al. | Feb 2001 | B1 |
6195662 | Ellis et al. | Feb 2001 | B1 |
6208345 | Sheard et al. | Mar 2001 | B1 |
6212518 | Yoshida et al. | Apr 2001 | B1 |
6239802 | Lahey et al. | May 2001 | B1 |
6243724 | Mander et al. | Jun 2001 | B1 |
6246410 | Bergeron et al. | Jun 2001 | B1 |
6272489 | Rauch et al. | Aug 2001 | B1 |
6300948 | Geller | Oct 2001 | B1 |
6301586 | Yang et al. | Oct 2001 | B1 |
6353823 | Kumar | Mar 2002 | B1 |
6363386 | Soderberg et al. | Mar 2002 | B1 |
6370562 | Page et al. | Apr 2002 | B2 |
6374260 | Hoffert et al. | Apr 2002 | B1 |
6385600 | McGuinness et al. | May 2002 | B1 |
6389412 | Light | May 2002 | B1 |
6401097 | McCotter et al. | Jun 2002 | B1 |
6408301 | Patton et al. | Jun 2002 | B1 |
6434548 | Emens et al. | Aug 2002 | B1 |
6449627 | Baer et al. | Sep 2002 | B1 |
6457017 | Watkins et al. | Sep 2002 | B2 |
6466237 | Miyao et al. | Oct 2002 | B1 |
6473794 | Guheen et al. | Oct 2002 | B1 |
6480835 | Light | Nov 2002 | B1 |
6486897 | Arrouye et al. | Nov 2002 | B1 |
6490575 | Berstis | Dec 2002 | B1 |
6549916 | Sedlar | Apr 2003 | B1 |
6564225 | Brogliatti et al. | May 2003 | B1 |
6567805 | Johnson et al. | May 2003 | B1 |
6613101 | Mander et al. | Sep 2003 | B2 |
6633864 | Christensen et al. | Oct 2003 | B1 |
6633867 | Kraft et al. | Oct 2003 | B1 |
6636856 | Pasquali | Oct 2003 | B2 |
6647383 | August | Nov 2003 | B1 |
6665657 | Dibachi | Dec 2003 | B1 |
6681227 | Kojima et al. | Jan 2004 | B1 |
6681229 | Carson et al. | Jan 2004 | B1 |
6687712 | Mito et al. | Feb 2004 | B2 |
6691125 | Engle et al. | Feb 2004 | B1 |
6704739 | Craft et al. | Mar 2004 | B2 |
6721747 | Lipkin | Apr 2004 | B2 |
6732088 | Glance | May 2004 | B1 |
6741996 | Brechner et al. | May 2004 | B1 |
6757673 | Makus | Jun 2004 | B2 |
6760721 | Chasen et al. | Jul 2004 | B1 |
6760731 | Huff | Jul 2004 | B2 |
6772167 | Snavely et al. | Aug 2004 | B1 |
6785683 | Zodik et al. | Aug 2004 | B1 |
6785688 | Abajian et al. | Aug 2004 | B2 |
6804674 | Hsiao et al. | Oct 2004 | B2 |
6847959 | Arrouye et al. | Jan 2005 | B1 |
6847982 | Parker et al. | Jan 2005 | B2 |
6850257 | Colleran et al. | Feb 2005 | B1 |
6862713 | Kraft et al. | Mar 2005 | B1 |
6895430 | Schneider | May 2005 | B1 |
6944620 | Cleraux et al. | Sep 2005 | B2 |
6947959 | Gill | Sep 2005 | B1 |
6952695 | Trinks et al. | Oct 2005 | B1 |
6961731 | Holbrook | Nov 2005 | B2 |
6980949 | Ford | Dec 2005 | B2 |
7039635 | Morgan et al. | May 2006 | B1 |
7039637 | Murray et al. | May 2006 | B2 |
7054870 | Holbrook | May 2006 | B2 |
7137099 | Knight et al. | Nov 2006 | B2 |
7155504 | Fujieda | Dec 2006 | B1 |
7162466 | Kaasten et al. | Jan 2007 | B2 |
7162473 | Dumais et al. | Jan 2007 | B2 |
7188100 | De Bellis et al. | Mar 2007 | B2 |
7188317 | Hazel | Mar 2007 | B1 |
7209915 | Taboada et al. | Apr 2007 | B1 |
7266546 | Son | Sep 2007 | B2 |
7269604 | Moore et al. | Sep 2007 | B2 |
7275063 | Horn | Sep 2007 | B2 |
7334195 | Gemmell | Feb 2008 | B2 |
7337448 | Dalia et al. | Feb 2008 | B1 |
7340472 | Makus | Mar 2008 | B2 |
7437358 | Arrouye et al. | Oct 2008 | B2 |
7493315 | Holbrook | Feb 2009 | B2 |
7613689 | Arrouye et al. | Nov 2009 | B2 |
7617225 | Arrouye et al. | Nov 2009 | B2 |
7630971 | Arrouye et al. | Dec 2009 | B2 |
7631318 | Cottrille et al. | Dec 2009 | B2 |
7640232 | Fish | Dec 2009 | B2 |
7650397 | Price et al. | Jan 2010 | B2 |
7698255 | Goodwin et al. | Apr 2010 | B2 |
7730012 | Arrouye et al. | Jun 2010 | B2 |
7734690 | Moromisato et al. | Jun 2010 | B2 |
7769752 | Turner | Aug 2010 | B1 |
7769794 | Moore | Aug 2010 | B2 |
7774326 | Arrouye et al. | Aug 2010 | B2 |
7814134 | Leonardos | Oct 2010 | B2 |
7831552 | Borthakur et al. | Nov 2010 | B2 |
7873684 | Souder et al. | Jan 2011 | B2 |
7925661 | Broussard et al. | Apr 2011 | B2 |
7970799 | Arrouye et al. | Jun 2011 | B2 |
8095506 | Arrouye et al. | Jan 2012 | B2 |
8135727 | Arrouye et al. | Mar 2012 | B2 |
8150826 | Arrouye et al. | Apr 2012 | B2 |
8156104 | Arrouye et al. | Apr 2012 | B2 |
8156123 | Tribble et al. | Apr 2012 | B2 |
8166065 | Arrouye et al. | Apr 2012 | B2 |
8229889 | Arrouye et al. | Jul 2012 | B2 |
8229913 | Arrouye et al. | Jul 2012 | B2 |
8234245 | Arrouye et al. | Jul 2012 | B2 |
8352513 | Arrouye et al. | Jan 2013 | B2 |
8738670 | Arrouye et al. | May 2014 | B2 |
20010037332 | Miller et al. | Nov 2001 | A1 |
20010054042 | Watkins et al. | Dec 2001 | A1 |
20020002453 | Lazaridis et al. | Jan 2002 | A1 |
20020004709 | Peter et al. | Jan 2002 | A1 |
20020038348 | Malone et al. | Mar 2002 | A1 |
20020040442 | Ishidera | Apr 2002 | A1 |
20020049738 | Epstein | Apr 2002 | A1 |
20020049749 | Helgeson et al. | Apr 2002 | A1 |
20020059210 | Makus | May 2002 | A1 |
20020059288 | Yagi et al. | May 2002 | A1 |
20020069218 | Sull et al. | Jun 2002 | A1 |
20020075312 | Amadio et al. | Jun 2002 | A1 |
20020122077 | Doney | Sep 2002 | A1 |
20020135612 | Royer et al. | Sep 2002 | A1 |
20020152267 | Lennon | Oct 2002 | A1 |
20020167538 | Bhetanabhotla | Nov 2002 | A1 |
20020169771 | Melmon et al. | Nov 2002 | A1 |
20020184195 | Qian | Dec 2002 | A1 |
20020184196 | Lehmeier et al. | Dec 2002 | A1 |
20020188603 | Baird et al. | Dec 2002 | A1 |
20020188616 | Chinnici et al. | Dec 2002 | A1 |
20020188620 | Doss et al. | Dec 2002 | A1 |
20020194164 | Morrow | Dec 2002 | A1 |
20020196295 | Haley et al. | Dec 2002 | A1 |
20030005464 | Gropper et al. | Jan 2003 | A1 |
20030009484 | Hamanaka et al. | Jan 2003 | A1 |
20030018622 | Chau | Jan 2003 | A1 |
20030028545 | Wang et al. | Feb 2003 | A1 |
20030033296 | Rothmuller et al. | Feb 2003 | A1 |
20030046292 | Subramanian et al. | Mar 2003 | A1 |
20030069880 | Harrison et al. | Apr 2003 | A1 |
20030069902 | Narang et al. | Apr 2003 | A1 |
20030084087 | Berry | May 2003 | A1 |
20030088567 | Rosenfelt et al. | May 2003 | A1 |
20030088573 | Stickler | May 2003 | A1 |
20030097361 | Huang | May 2003 | A1 |
20030098893 | Makinen | May 2003 | A1 |
20030100999 | Markowitz | May 2003 | A1 |
20030117907 | Kang | Jun 2003 | A1 |
20030122873 | Dieberger et al. | Jul 2003 | A1 |
20030122874 | Dieberger et al. | Jul 2003 | A1 |
20030135828 | Dockter et al. | Jul 2003 | A1 |
20030135840 | Szabo et al. | Jul 2003 | A1 |
20030140035 | Burrows | Jul 2003 | A1 |
20030140051 | Fujiwara et al. | Jul 2003 | A1 |
20030142953 | Terada et al. | Jul 2003 | A1 |
20030144990 | Benelisha et al. | Jul 2003 | A1 |
20030158855 | Farnham et al. | Aug 2003 | A1 |
20030164855 | Grant et al. | Sep 2003 | A1 |
20030164856 | Prager et al. | Sep 2003 | A1 |
20030172082 | Benoit et al. | Sep 2003 | A1 |
20030187950 | Rising | Oct 2003 | A1 |
20030195877 | Ford et al. | Oct 2003 | A1 |
20030196094 | Hillis et al. | Oct 2003 | A1 |
20030200218 | Tijare et al. | Oct 2003 | A1 |
20030200234 | Koppich et al. | Oct 2003 | A1 |
20030220853 | Back | Nov 2003 | A1 |
20030236842 | Natarajan et al. | Dec 2003 | A1 |
20040003011 | Broussard | Jan 2004 | A1 |
20040015521 | Hudicka | Jan 2004 | A1 |
20040078224 | Schramm-Apple | Apr 2004 | A1 |
20040078358 | Hughes et al. | Apr 2004 | A1 |
20040078382 | Mercer et al. | Apr 2004 | A1 |
20040088316 | Cleraux et al. | May 2004 | A1 |
20040107175 | Hung et al. | Jun 2004 | A1 |
20040111728 | Schwalm | Jun 2004 | A1 |
20040117374 | Hung et al. | Jun 2004 | A1 |
20040122741 | Sidman | Jun 2004 | A1 |
20040126038 | Aublant et al. | Jul 2004 | A1 |
20040133544 | Kiessig et al. | Jul 2004 | A1 |
20040143569 | Gross | Jul 2004 | A1 |
20040158584 | Necsoiu et al. | Aug 2004 | A1 |
20040163020 | Sidman | Aug 2004 | A1 |
20040174396 | Jobs et al. | Sep 2004 | A1 |
20040177057 | Fairchild et al. | Sep 2004 | A1 |
20040177319 | Horn | Sep 2004 | A1 |
20040186860 | Lee et al. | Sep 2004 | A1 |
20040199491 | Bhatt | Oct 2004 | A1 |
20040199507 | Tawa, Jr. | Oct 2004 | A1 |
20040199867 | Bradenborg | Oct 2004 | A1 |
20040199921 | Snader et al. | Oct 2004 | A1 |
20040205076 | Huang et al. | Oct 2004 | A1 |
20040205473 | Fisher et al. | Oct 2004 | A1 |
20040205514 | Sommerer | Oct 2004 | A1 |
20040215611 | Jawa et al. | Oct 2004 | A1 |
20040215643 | Brechner et al. | Oct 2004 | A1 |
20040230571 | Robertson | Nov 2004 | A1 |
20040243567 | Levy | Dec 2004 | A1 |
20040254923 | Piersol | Dec 2004 | A1 |
20040267811 | Nelson et al. | Dec 2004 | A1 |
20050015389 | Novak et al. | Jan 2005 | A1 |
20050020043 | Lai | Jan 2005 | A1 |
20050021659 | Pilu | Jan 2005 | A1 |
20050027750 | Martin et al. | Feb 2005 | A1 |
20050038831 | Souder et al. | Feb 2005 | A1 |
20050050301 | Whittle et al. | Mar 2005 | A1 |
20050055351 | Barton et al. | Mar 2005 | A1 |
20050055372 | Springer et al. | Mar 2005 | A1 |
20050060337 | Chou et al. | Mar 2005 | A1 |
20050075544 | Shapiro et al. | Apr 2005 | A1 |
20050080770 | Lueder | Apr 2005 | A1 |
20050154695 | Gonzalez et al. | Jul 2005 | A1 |
20050154716 | Watson | Jul 2005 | A1 |
20050165777 | Hurst-Hiller | Jul 2005 | A1 |
20050203918 | Holbrook | Sep 2005 | A1 |
20050210507 | Hawkins et al. | Sep 2005 | A1 |
20050216489 | Young et al. | Sep 2005 | A1 |
20050234984 | Rogerson et al. | Oct 2005 | A1 |
20050240640 | Kaler et al. | Oct 2005 | A1 |
20050246311 | Whelan et al. | Nov 2005 | A1 |
20050246324 | Paalasmaa et al. | Nov 2005 | A1 |
20050246645 | Beam et al. | Nov 2005 | A1 |
20050251753 | Sawyer | Nov 2005 | A1 |
20050283468 | Kamvar et al. | Dec 2005 | A1 |
20060004787 | Borthakur et al. | Jan 2006 | A1 |
20060031214 | Solaro et al. | Feb 2006 | A1 |
20060161535 | Holbrook | Jul 2006 | A1 |
20100198815 | Poston et al. | Aug 2010 | A1 |
20110161174 | Simms et al. | Jun 2011 | A1 |
Number | Date | Country |
---|---|---|
WO 0146870 | Jun 2001 | WO |
WO 03060774 | Jul 2003 | WO |
WO 03090056 | Oct 2003 | WO |
Entry |
---|
PCT Invitation to Pay Additional Fees for PCT International Appln. No. PCT/US2005/022535, mailed Nov. 14, 2005 (6 pages). |
PCT Invitation to Pay Additional Fees for PCT International Appln. No. PCT/US2005/022537, mailed Nov. 14, 2005 (4 pages). |
PCT Invitation to Pay Additional Fees for PCT International Appln No. PCT/US2005/022536, mailed Nov. 16, 2005 (5 pages). |
PCT International Search Report and Written Opinion for PCT International Appln No. PCT/US2005/022748 mailed Jan. 5, 2006. (33 pages). |
PCT International Search Report and Written Opinion for PCT International Appln No. PCT/US2005/022537 mailed Jan. 12, 2006. (16 pages). |
U.S. Appl. No. 10/461,642, filed Jun. 13, 2003, title “Domain Specific Search Engine,” by Inventor Nikhil Bhatt, 72 pages (specification and drawings). |
U.S. Appl. No. 10/407,853, filed Apr. 4, 2003, titled “Method and Apparatus for Tagging and Locating Audio Data,” by Inventor Nikhil Bhatt, 51 pages (specification and drawings). |
U.S. Appl. No. 10/873,681, filed Jun. 21, 2004, titled “Methods and Apparatuses for Operating a Data Processing System,” by Inventors Bas Ording and Donald Lindsay, 91 pages (specification and drawings). |
Baeza-Yates R.A. et al. “New Approaches to Information Management: Attribute-Centric Data Systems”, String Processing and Information Retrieval, 2000. Spire 2000, Proceedings. Seventh International Symposium on Sep. 27-29, 2000, Piscataway, NJ, USA, IEEE, Sep. 27, 2000, (Sep. 27, 2000), pp. 17-27, XP0105017584. |
Bowman, C.M. “A File for Information Management”, Proceedings of the ISMM International Conference. Intelligent Information Management Systems. Proceedings of ISMM Symposium, Jun. 1, 1994 (Jun. 1, 1994), pp. 66-71, XP002224131. |
Caban, Pipo, et al., “Improved Downloading Capabilities for Internet Browsers and File Management Capabilities for Windows Explorer to Minimize User Intervention” Research Disclosure, Mason Publications, Hampshire, GB, vol. 473, No. 23, Sep. 2003, (Sep. 2003), XP007132837(3 pages). |
Giampaolo, Dominic, “Practical File System Design with the Be File System,” 1999 Cover Page and Table of Contents (pp. 1-7), Chapters 4 & 5 (pp. 45-98) and Index (pp. 225-247). Morgan Kaufmann Publishers, San Francisco, CA. |
Grimes, Richard “Revolutionary File Storage System lets users Search and Manage Files based on Content”, MSDN Magazine, Jan. 2004. (6 pages). |
Welch, Kevin P. “Find Files Under Presentation Manager and Windows with a Handy Utility”, Microsoft Systems Journal, vol. 4, No. 5, Sep. 1989, pp. 61-68. XP002035114. |
PCT Chapter I International Preliminary Report on Patentability (IPER) for PCT Application No. PCT/US2005/022748 mailed Dec. 28, 2006. |
U.S. Appl. No. 10/873,661, filed Jun. 21, 2004, titled “Methods and Apparatuses for Operating a Data Processing System,” by Inventors Bas Ording and Donald Lindsay, 91 pages (specification and drawings). |
U.S. Appl. No. 10/951,915, filed Apr. 22, 2005, titled “Live Content Resizing”, by Inventors Steven P. Jobs, Stephen O. Lemay, Jessica Kahn, Sarah Wilkin, David Hyatt, Jens Alfke and Wayne Loffbourrow, 38 pages (specification and drawings). |
PCT International Search Report and Written Opinion for PCT International Appln No. PCT/US2005/022535 mailed Feb. 27, 2006. (22 pages). |
Floyd Richard A. , et al.,“Directory Reference Patterns in Hierarchical File Systems”, Knowledge and Data Engineering, IEEE Transactions on vol. 1, Issue 2, Jun. 1989, pp. 238-247, Digital Object Identifier 10.1109/69.87963. |
Davis, Marc., “Active Capture: Integrating Human-Computer Interaction and Computer Vision/Audition to Automate Media Capture”, Multimedia and Expo, 2003. ICME 2003. Proceedings, 2003 International Conference on, vol. 2, Jul. 6-9, 2003 pp. II-185-II-188 vol. 2. |
Baeza-Yates R.A., et al.,“Modern Information Retrieval”, Jan. 1, 1999 (Jan. 1, 1999), Modern Information Retrieval, ACM Press, New Yorks, pp. 257-339, XP002210866 OSBN: 978-0-201-39829-8. |
Halfhill, T.R., “GUIS Get a Facelift”, Byte, McGraw-Hill Inc. St. Peterborough, US, bol. 21, No. 7, Jul. 1, 1996 (Jul. 1, 1996), XP000592154, ISSN: 0360-5280. |
Number | Date | Country | |
---|---|---|---|
20150347419 A1 | Dec 2015 | US |
Number | Date | Country | |
---|---|---|---|
60643087 | Jan 2005 | US |
Number | Date | Country | |
---|---|---|---|
Parent | 11351249 | Feb 2006 | US |
Child | 14716752 | US | |
Parent | 11112350 | Apr 2005 | US |
Child | 11351249 | US |
Number | Date | Country | |
---|---|---|---|
Parent | 10877584 | Jun 2004 | US |
Child | 11112350 | US |