The disclosed implementations relate generally to storing and restoring digital data.
Modern graphical user interfaces allow a large number of graphical objects or items to be displayed on a display screen at the same time. Operating systems, such as Apple Mac OS®, provide user interfaces in which a number of windows can be displayed, overlapped, resized, moved, configured, and reformatted according to the needs of a user or a particular application. Taskbars, menus, virtual buttons and other user interface elements provide mechanisms for accessing and activating windows even when they are hidden behind other windows.
With the sophisticated tools available, users are encouraged not only to create and save a multitude of items in their computers, but also to revise or otherwise improve on them over time. For example, a user can work with a certain file and thereafter save its current version on a storage device. The next day, however, the user could have had second thoughts about the revisions, or could have come up with new ideas, and therefore opens the file again.
The revision process is usually straightforward if the user wants to add more material to the file or make changes to what is there. However, it is typically more difficult for a user to revert a file back to an earlier state if the user has changed his/her mind about modifications that were previously made. Application programs for word processing typically let the user “undo” previous edits of a text, at least up to a predefined number of past revisions. The undo feature also usually is configured so that the previously made revisions must be undone in reverse chronological order; that is, the user must first undo the most recently made edit, then the second-most recent one, and so on. If the user saves and closes the document and thereafter opens it again, it may not be possible to undo automatically any previous edits.
Systems and methods are provided for storing and restoring digital data. In general, in one aspect, a method is provided. The method includes receiving, while a current view is displayed in a user interface, a first user input requesting that a backup interface be displayed, displaying the backup interface, the backup interface including a display area for presenting at least a first visual representation of an earlier version of the current view and a visual representation of the current view, the earlier version including a first element, receiving, while the backup interface is displayed, a second user input requesting that the current view be modified according to the earlier version, at least with regard to the first element, animating the modification of the first element as moving from the visual representation of the earlier version to the visual representation of the current view, and modifying, in response to the second user input, the current view according to the earlier version, at least with regard to the first element. Other embodiments of this aspect include corresponding systems, apparatus, computer program products, and computer readable media.
Implementations of the aspect can include one or more of the following features. Animating the modification can further includes lifting a copy of the first element from the visual representation of the earlier version, maintaining the position of the copy of the first element while animating the visual representations such that the visual representation of the earlier version falls away and the visual representation of the current view is presented, and adding the copy of the first element to the visual representation of the current view. The aspect can further include displaying the current view in the user interface, where the current view includes the modification of the first element.
In general, in one aspect, a method is provided. The method includes receiving, while a current view is displayed in a user interface, a first user input requesting that a backup interface be displayed and displaying the backup interface, the backup interface including a display area for presenting at least a first visual representation of an earlier version of the current view and a visual representation of the current view, the backup interface further including a timeline, where the timeline represents a plurality of visual representations of earlier versions of the current view. Other embodiments of this aspect include corresponding systems, apparatus, computer program products, and computer readable media.
Implementations of the aspect can include one or more of the following features. Displaying the backup interface can include displaying a timeline including a vertical column of tick marks. The timeline can be a condensed timeline that includes a plurality of condensed tick marks, where each condensed tick mark represents multiple individual tick marks. The timeline can animate in response to a user input. The animation can be based on a cursor position.
The animation can further include determining an identified tick mark, the identified tick mark having a shortest distance from a cursor position and expanding the timeline to display individual tick marks relative to the identified tick mark. Displaying the individual tick marks can include magnifying the identified tick mark. A date can be displayed corresponding to the earlier version of the current view represented by the identified tick mark.
The aspect can further include determining that the cursor position has moved, determining a next identified tick mark relative to the cursor position, and magnifying the next identified tick mark. The aspect can further include receiving an input selecting the identified tick mark, displaying the visual representation of an earlier version of the current view corresponding to the identified tick mark, and compressing the timeline to the condensed timeline.
In general, in one aspect, a method is provided. The method includes displaying a backup interface in a user interface, the backup interface including a display area for presenting a plurality of visual representations of an earlier version of the current view and a visual representation of the current view, and displaying a timeline, the timeline including a series of steps and including one or more compressed portions and an expanded portion where each step in a compressed portion is associated with one or more earlier versions of the current view, and each step in an expanded portion is associated with only a single earlier version of the current view or the current view. Other embodiments of this aspect include corresponding systems, apparatus, computer program products, and computer readable media.
Implementations of the aspect can include one or more of the following features. Each step can have a visible representation in the timeline and includes a tick mark. A tick mark associated with a compressed portion of the time line can be larger than a tick mark associated with an expanded portion of the timeline.
Particular embodiments of the subject matter described in this specification can be implemented to realize one or more of the following advantages. Users can focus in and identify particular snapshots from a timeline of tick marks representing one or more snapshots. A restoration animation provides users with visual cues to the restoration of an item from a history view.
The details of the various aspects of the subject matter described in this specification are set forth in the accompanying drawings and the description below. Other features, aspects, and advantages of the invention will become apparent from the description, the drawings, and the claims.
The system 100 includes a personal computer 102 communicatively coupled to a remote server 107 via a network interface 116 and a network 108 (e.g., local area network, wireless network, Internet, intranet, etc.). The computer 102 generally includes a processor 103, memory 105, one or more input devices 114 (e.g., keyboard, mouse, etc.), and one or more output devices 115 (e.g., a display device). A user interacts with the system 100 via the input and output devices 114, 115. The system 100 includes various hardware elements. The system 100 can include hardware, software, and combinations of the two.
The computer 102 also includes a local storage device 106 and a graphics module 113 (e.g., a graphics card) for storing information and generating graphical objects, respectively. The local storage device 106 can be a computer-readable medium. The term “computer-readable medium” refers to any medium that includes data and/or participates in providing instructions to a processor for execution, including without limitation, a machine-readable storage device such as non-volatile media (e.g., optical or magnetic disks) and volatile media (e.g., memory). The computer-readable medium also includes transmission media. Transmission media includes, without limitation, coaxial cables, copper wire, fiber optics, and computer buses. Transmission media can also take the form of acoustic, light or radio frequency waves.
While modifications of a user interface view are described herein with respect to a personal computer 102, it should be apparent that the disclosed implementations can be incorporated in, or integrated with, any electronic device that has a user interface, including without limitation, portable and desktop computers, servers, electronics, media players, game devices, mobile phones, email devices, personal digital assistants (PDAs), embedded devices, televisions, other consumer electronic devices, etc.
Systems and methods are provided for searching stored contents that correspond to earlier versions of system information, application information, or system, application, or user interface state. The systems and methods can be stand-alone or otherwise integrated into a more comprehensive application. In the materials presented below, integrated systems and methods are provided for viewing and modifying an interface view (e.g., a user interface view).
Though discussion is made with reference to modifying a user interface view, those of ordinary skill will recognize that such a view can be based on various data structures, files, processes, and other aspects of information management. It follows that modification to file structures, data and the like is also contemplated in order to achieve the modification to the user interface view. In other words, while the restoration of the user interface view from one state to another can be the most apparent change from the user's perspective, this is accomplished through the corresponding changes in the underlying system content.
One of ordinary skill in the art will recognize that the engines, methods, processes and the like that are described can themselves be an individual process or application, part of an operating system, a plug-in, an application, or the like. In one implementation, the system and methods can be implemented as one or more plug-ins that are installed and run on the personal computer 102. The plug-ins are configured to interact with an operating system (e.g., MAC OS® X, WINDOWS XP, LINUX, etc.) and to perform the various functions, as described below.
A system and method for modifying a user interface view can also be implemented as one or more software applications running on the computer 102. Such a system and method can be characterized as a framework or model that can be implemented on various platforms and/or networks (e.g., client/server networks, wireless networks, stand-alone computers, portable electronic devices, mobile phones, etc.), and/or embedded or bundled with one or more software applications (e.g., email, media player, browser, etc.).
The computer 102 includes the backup component 117 that allows for the storage of versions of the computer's files or other items (e.g., restoring a view including past state of a file, application, application data, parameters, settings, and the like), for example within the local storage 106 or in an external storage repository. In one implementation, the backup component 117 also allows a user to select any of the stored versions and use it to initiate a restoration of backup data corresponding to that version in the computer 102.
In some implementations, the computer 102 can include a search component 118 that allows for searches of the computer's files or other items, for example within the local storage 106 or an external storage repository. In one implementation, the search component 118 can interact with the backup component 117 to perform searches of stored versions of the computer's files and other items. Particularly, in one implementation, the search component 118 provides that a user can select search results identified in an earlier version and use them to initiate a restoration of that version in the computer 102. This means that when a user searches for a file but the file is not found, the user can invoke the backup component 117 (or a portion thereof) to show one or more previous states of, for example, the C: drive or some other system resource. For example, if the user is looking for content of the C: drive (that does not currently hold the sought file), the user (or the computer) can launch a backup component to look at previous states of the C: drive to see if the file has been archived. This operation can be facilitated by the search environment forwarding information (e.g., an identity of the sought file) to the backup environment for showing the correct archive(s).
In this example, the backup component 117 includes a local storage device 204 and an external storage device 232. Backup data can be stored on either. Any number of local and/or external storage devices can be used by the backup component 117 for storing backup data corresponding to the versions. In one implementation, no local storage is provided. In one implementation, the backup component 117 stores the backup data in a format corresponding to a file system structure.
In one implementation, one copy of original data (e.g., folders, files, items, information portions, directories, images, system parameters, playlists, address books, e-mails, e-mail folders, application states, preferences, and the like) is stored in the system as backup data (e.g., an original version of the data). When one or more subsequent sets of backup data, or versions, of the data are generated through subsequent backup operations, the backup data can contain only the differences between a current data version and the prior backup data, thereby saving storage space. In some implementations, the storage devices 204 and 232 can be used to store the original backup data as well as links pointing to the original backup data. The links can be hard links which reference, or point to, physical data, or as another example can be symbolic links that reference another file on the storage device (e.g., by name or location).
In one implementation, the backup component 117 runs as a background task on an operating system 230, where the task is generally not visible to the user. The backup component 117 can be configured to run across multiple user accounts. In another implementation, the backup component 117 runs within an application 228 in the user space.
The backup component 117 includes an activity monitoring engine 212. In one implementation, the activity monitoring engine 212 monitors for changes within an application view (e.g., application files or state) that are targeted for inclusion in backup operations. A change can also include the addition of new files or data (e.g., files or other data structures) or deletion of the same.
In one implementation, the activity monitoring engine 212 is capable of discerning between a substantive change (e.g. the text within a document has been modified) and a non-substantive change (e.g. the play count within an iTunes playlist has been updated, or several changes cancel each other out) through its interaction with the applications 228. The activity monitoring engine 212 can create, for example, a list of modified elements (e.g., files) to be used when a backup operation is eventually triggered. In one implementation, the activity monitoring engine 212 can monitor the system for periods of inactivity. The activity monitoring engine 212 can then trigger a backup operation during a period of time in which the backup operation will not cause a system slowdown for an active user.
A preference management engine 214 specifies some operating parameters of the backup component 117. In one implementation, preference management engine 214 contains user-specified and/or system default application parameters for the backup component 117. These can include settings for the details of capturing and storing the views. For example, the preference management engine 214 can determine the frequency of the backup operations, the storage location for the backup data, the types of elements (e.g. files or other items) that are eligible for inclusion in backup operations, and the events which trigger a backup operation (periodic or event-driven, etc.).
In one implementation, the preference management engine 214 can detect when a new storage device is being added to the system and prompt the user to specify whether it should be included as a backup repository. Files and other items can be scheduled for a backup operation based on location (e.g. everything on lettered drives such as C: drive and within D:/photos, or named drives such as “MyBigDisk” drive or within named directories such as within “/ExtraStorage/Photos”, thus reference in this specification to drives is not limited to lettered drives or paths), a correlation with specific applications (e.g. all pictures, music, e-mail in an inbox, an address book and system settings), or a combination of strategies. Different types of items can be scheduled to be stored on different devices or on different segments of a storage device during a backup operation.
A backup management engine 216 coordinates the collection, storage, and retrieval of views performed by the backup component 117. For example, the backup management engine 216 can trigger the activity monitoring engine 212 to watch for activities that satisfy a requirement specified in the preference management engine 214 for initiating a backup operation.
A change identifying engine 218 locates specific elements (e.g., monitored files or other items within) the system 200 to determine if they have changed. The change identifying engine 218 can be capable of discerning a substantive change from a non-substantive change, similar to the example described above for the activity monitoring engine 212. In one implementation, the change identifying engine 218 traverses a target set of elements (e.g., files, data, or other items), comparing a previous version to the current version to determine whether or not a modification has occurred.
A backup capture engine 220 locates views (e.g., elements, files, data, or other items) that are to be included in a backup. The backup capture engine 220 can invoke the activity monitoring engine 212 and/or the change identifying engine 218, for example, to generate a capture list identifying data to be included in a next backup operation. The backup capture engine 220 can then store copies of the listed data in one or more targeted storage repositories. The backup capture engine 220 can track multiple versions of the data included in the backup repository.
The backup component 117 includes a backup restoration engine 222 to restore previous versions of views (e.g., files, data, or other items). In one implementation, the backup restoration engine 222 provides a user interface (e.g., a graphical user interface) where a user can select the item(s) to be restored.
The backup component 117 includes an animation management engine 234. The animation management engine 234 performs or otherwise manages animations occurring within a user interface generated by the backup component 117. For example, the animation management engine 234 can animate a timeline of captured earlier versions stored by the backup component 117. Such animation can give an overview of the archive data that is available and can help a user in choosing a particular backup version to restore.
The search component 118 can search directly within the one or more applications 228 for a current state or version of the files or other items. In addition, the search component 118 can search earlier versions of the files and other items using the backup component 117. For example, the search component 118 can provide a search interface within a backup user interface that allows searches of earlier versions of the files or other items. In addition, the search component 118 can provide a search interface within a user interface (e.g., a desktop user interface) that allows searches of the current version of the files or other items.
For example, the search component 118 can be used to initiate a search to find a particular item or element, such as an image file. If this search finds the sought item, and if the item meets the user's expectations, there may be no need to do any further searching at that time. However, if the search does not find the sought item, or if the item that is found does not meet the user's expectations, the user can choose to perform a search of historical views. The user can activate the backup user interface to search the historical views.
In some implementations, the desktop user interface includes one or more windows. The windows can provide, for example, a current view of an open application (e.g., a user interface of the current application state) or a current view of a navigation interface (e.g., for navigating a file system, for example, of local storage 106). The user can initiate the backup interface within an active window of the user interface, e.g., from a particular application or navigation interface.
A backup interface icon or menu option can allow a user to enter the backup interface with respect to the active window. For example, a user can enter the backup interface from a navigation interface providing a particular view of the file system in order to search for a missing or earlier version of an item (e.g., a file or folder).
The system displays (304) the backup interface. The backup interface can include multiple history views with respect to the current view. The history views can be visual representations of the backup data presented in the history view. In some implementations, the history views are presented as snapshots. A snapshot, as used herein, can refer to a backup element stored in an archive that includes a backup of selected items or content as specified by the backup component 117. A snapshot can also represent the current view in the backup interface. In some implementations, the snapshots are arranged in a cascading stack, where each next snapshot moving through the stack corresponds to a point in time further in the past relative to the current view (e.g., presented at the top of the stack).
For example, if the user activated the backup interface from an interface of a particular application, each snapshot can provide a visual representation of the application's user interface corresponding to the state when the corresponding backup occurred. Similarly, if the user activated the backup interface from a particular point in the file system using the navigation interface, the snapshots can provide representations of the navigation interface at particular points in time. As a result, the user can visually identify items in snapshots for restoration or restore an entire state (e.g., of an application) represented by the snapshot.
The system receives (306) an input to display a particular snapshot. The user can navigate between snapshots in the backup interface. For example, the user can use navigation buttons (e.g., arrow buttons) to move forward or backward though the snapshots. Alternatively, the user can select a particular snapshot directly in the stack using, for example, an input device (e.g., a mouse) to move a cursor to a particular snapshot and then select the snapshot. In other implementations, the snapshots can be represented in other ways, for example, as a timeline of tick marks within the backup interface. The user can select a particular tick mark to select a specific snapshot (as described in greater detail below). When the user selects a particular snapshot, the selected snapshot is presented as a current snapshot at the top of the stack of snapshots.
The system receives (308) an input to restore an item in the particular displayed snapshot. For example, a user can enter the backup interface from a navigation interface in order to restore an earlier version of a particular file. Once the user identifies the particular earlier version of the file in a selected snapshot (e.g., corresponding to an earlier time prior to some edits to the file that the user wishes to undo), the user can select the file for restoration. Similarly, the user can select other aspects in the snapshot, for example, presented application data (e.g., mail messages in snapshots of an e-mail application interface, songs from a music management application) as well as state information for a collection of data represented by the snapshot (e.g., a state of an application).
The user can select the file, for example, by selecting the file in the snapshot with an input device. The selected item can be identified, for example, by highlighting the item in the snapshot. The user can then select a restore control to activate a restoration process for the selected file.
In some implementations, the system animates (310) a restoration of the selected item to the current view. For example, the system can animate the item by lifting a copy of the item off of the selected snapshot and transporting the item forward in time to the snapshot representing the current state. One example animation is described with respect to
The system restores (312) the item to a current view and exits the backup interface. For example, if the restored item exists in the current view (e.g., when restoring an earlier version of the item), the restored item can replace the existing item in the current view (e.g., the exiting item is deleted and replaced with the restored item). Alternatively, the restored item can be separately saved (e.g., under a different filename). Alternatively, if the item does not exist in the current view (e.g., restoring an item that was deleted from the current view), then the copy of the restored item can simply be copied, e.g., to a location corresponding to the current view.
With the navigation interface 400 as the active window, the user can launch the backup user interface by, for example, selecting a backup option from a menu 404 of the user interface 400 or using an icon or menu item associated with the navigation interface 402.
The “cancel” control 510 can allow the user to cancel the restoration of one or more files or items. In some implementations, canceling a restoration will also lead to exiting the backup interface and returning, for example, to the user interface 400 of
In some implementations, the “restore” control 514 can be used to restore the entire contents of the selected snapshot e.g., restore the current file system state with all the files or items in a currently selected snapshot. The “only show changes” control 512 can allow a user to select whether or not snapshots without changed items will be presented in the backup interface. In some implementations, the “only show changes” control 512 can be toggled to display a “show all” control.
In
During the animation, snapshots between the current snapshot and selected snapshot can appear to move forward and dissolve in sequence. Thus, as shown in
The system displays (1304) the backup interface. The backup interface can include multiple history views with respect to the current view. The history views can be visual representations of the backup data presented in the history view. In some implementations, the history views are presented in the form of snapshots. The snapshot can also represent the current view in the backup interface. In some implementations, the snapshots are arranged in a cascading stack, where each next snapshot moving through the stack corresponds to a point in time further in the past relative to the current view (e.g., presented at the top of the stack), as described above.
For example, if the user activated the backup interface from an interface of a particular application, each snapshot can provide a visual representation of the application's user interface corresponding to the state when the corresponding backup occurred. Similarly, if the user activated the backup interface from a particular point in the file system using the navigation interface, the snapshots can provide representations of the navigation interface at particular points in time. As a result, the user can visually identify items in snapshots for restoration or restore an entire state (e.g., of an application) represented by the snapshot.
The backup component can represent snapshots in the backup interface in other ways, for example, as a timeline of markers (e.g., tick marks) within the backup interface. The user can select a particular tick mark to select a specific snapshot. When a user selects a particular snapshot, the selected snapshot is presented as a current snapshot at the top of the stack of snapshots.
The system determines (1306) a cursor position relative to the timeline. For example, the position of a cursor can be determined as it changes position within the backup interface (e.g., corresponding to a user movement of a mouse device). The position can be determined, for example, according to a pixel location of the cursor relative to the pixels forming the timeline in the backup interface. Additionally, the movements of the cursor within the backup interface can be tracked by the backup component.
The system animates (1308) the timeline based on the determined cursor position. For example, the backup component can provide a dynamic animation of the timeline that is responsive to cursor position. For example, the timeline can expand as the cursor approaches a particular region of the timeline. The expansion can include enlarging the timeline as well as increasing the number of tick marks to enhance resolution. For example, a condensed tick mark in the timeline, before expansion, can represent multiple tick marks where each of the condensed tick marks corresponds to a particular history view. That single tick mark can expand to the multiple tick marks as the cursor approaches in order to display the underlying tick marks. Each of the underlying tick marks can correspond to a particular history view. In some implementations, a date can be displayed for the history view corresponding to a closest proximity tick mark (with reference to the cursor).
In some implementations, the system automatically scrolls the timeline toward the center if the cursor position is near either end of the timeline. For example, if the system determines a cursor position at a top edge of the timeline, the animation can scroll the timeline and cursor downward by some amount. The cursor is scrolled with the timeline to maintain the positional relationship between a particular tick mark and the cursor. In some implementations, the scroll is only enough to allow nearby tick marks to expand fully during the animation. In other implementations, the scroll brings the cursor, and corresponding point in the timeline to the vertical center of the interface.
The system receives (1310) input selecting a tick mark in the timeline. For example, once the user has identified a specific tick mark, the tick mark can be selected using the input device. For example, the user can identify the particular tick mark for selection according to the displayed date information associated with the tick mark. The user can then select the tick mark in order to view the associated history view (e.g., as a snapshot).
The system displays (1312) a history view corresponding to the selected tick mark. For example, when the user selects a tick mark corresponding to a particular history view, the history view can be presented in the backup interface as the current snapshot (e.g., a topmost snapshot) in the backup interface. The user can then view or select, or otherwise navigate the items in the snapshot. In some implementations, the user can restore one or more selected items or the entire view to the current view. Alternatively, the user can select a new snapshot to view, e.g., using the timeline.
The “cancel” control 1410 can allow the user to cancel the restoration of one or more files or items. In some implementations, canceling a restoration will also lead to exiting the backup interface and returning, for example, to a desktop user interface (e.g., user interface 400 of
In some implementations, the “restore” control 1414 can be used to restore the entire contents of the selected snapshot e.g., restore the current file system state with all the files or items in a currently selected snapshot. The “only show changes” control 1412 can allow a user to select whether or not snapshots without changed items will be presented in the backup interface. In some implementations, the “only show changes” control 1412 can be toggled to display a “show all” control.
In
One or more tick marks can include data labels at various positions in the timeline 1402. For example, the timeline 1402 labels the current view in
In some implementations, there is a limit to the number of tick marks that can be presented in the timeline 1402. For example, if each tick mark is represented by a horizontal line having a height of two pixels and each tick mark is separated by a space having a height of 10 pixels, 100 tick marks would require 1190 vertical pixels. Consequently, timeline 1402, in an compressed state, can include compressed tick marks that are associated with multiple snapshots. In some implementations, the spacing between tick marks in the timeline 1402 is variable. For example, as snapshots are added during backup operations, the corresponding tick marks are added to the timeline 1402. As the number increases, the spacing between each tick mark can be reduced, e.g., incrementally until a minimum pixel spacing is reached.
The backup component can determine a compression for the timeline when there are more individual tick marks than vertical space in the backup interface. Those individual tick marks can be compressed according to specified criteria. In one implementation, the compression initially calculates two timelines. The first represents the maximum number of tick marks that can fit in the available space using the minimal spacing between tick marks. The first timeline will be the final timeline. The backup component calculates the second timeline by reducing the spacing until all of the tick marks fit within the total available space.
The backup component then calculates a span of each tick mark in the first timeline. The backup component calculates the span, for example, including determining two points based on the center point of the tick mark. In one implementation, the points define a distance plus or minus one-half the minimum spacing amount from the center point. Each tick mark in the first timeline spans either one or multiple tick marks in the second timeline. If a tick mark in the timeline spans only one tick mark, than the backup component replaces the tick mark with only that tick mark. However, if a tick mark in the first timeline spans multiple tick marks in the second timeline, than the backup component replaces the tick mark with a condensed tick mark that contains/references all of the spanned tick marks.
In some implementations, the backup component can delay the animation such that the cursor can reach a particular point in the timeline 1402 before animation occurs. Similarly, if all the snapshots are visible in the compressed timeline 1402 (e.g., each tick mark represents a single snapshot), then no animation need occur. Alternatively, the animation can begin when the cursor position is within a threshold distance relative to the timeline 1402.
As shown in
In some implementations, the enlargement includes horizontal and vertical thickening of the identified tick mark 1902. In other implementations, the magnification also enlarges the tick marks adjacent to the identified tick mark 1902, though to a lesser extent (e.g., forming a bell curve shape with the selected tick mark 1902 in the center). The user can select the identified tick mark 1902 in order to display the corresponding snapshot in the backup interface.
When the user moves the cursor away from the timeline, for example, after selecting a particular snapshot for display or to navigate to a different portion of the timeline, the timeline returns to the condensed state.
In the above description, for purposes of explanation, numerous specific details are set forth in order to provide a thorough understanding. It will be apparent, however, to one skilled in the art that implementations can be practiced without these specific details. In other instances, structures and devices are shown in block diagram form in order to avoid obscuring the disclosure.
In particular, one skilled in the art will recognize that other architectures and graphics environments can be used, and that the examples can be implemented using graphics tools and products other than those described above. In particular, the client/server approach is merely one example of an architecture for providing the functionality described herein; one skilled in the art will recognize that other, non-client/server approaches can also be used. Some portions of the detailed description are presented in terms of algorithms and symbolic representations of operations on data bits within a computer memory. These algorithmic descriptions and representations are the means used by those skilled in the data processing arts to convey most effectively the substance of their work to others skilled in the art. An algorithm is conceived here, and generally, to be a self-consistent sequence of steps leading to a desired result. The steps are those requiring physical manipulations of physical quantities. Usually, though not necessarily, these quantities take the form of electrical or magnetic signals capable of being stored, transferred, combined, compared, and otherwise manipulated. It has proven convenient at times, principally for reasons of common usage, to refer to these signals as bits, values, elements, symbols, characters, terms, numbers, or the like.
It should be borne in mind, however, that all of these and similar terms are to be associated with the appropriate physical quantities and are merely convenient labels applied to these quantities. Unless specifically stated otherwise as apparent from the discussion, it is appreciated that throughout the description, discussions utilizing terms such as “processing” or “computing” or “calculating” or “determining” or “displaying” or the like, refer to the action and processes of a computer system, or similar electronic computing device, that manipulates and transforms data represented as physical (electronic) quantities within the computer system's registers and memories into other data similarly represented as physical quantities within the computer system memories or registers or other such information storage, transmission or display devices.
An apparatus for performing the operations herein can be specially constructed for the required purposes, or it can comprise a general-purpose computer selectively activated or reconfigured by a computer program stored in the computer. Such a computer program can be stored in a computer readable storage medium, such as, but is not limited to, any type of disk including floppy disks, optical disks, CD-ROMs, and magnetic-optical disks, read-only memories (ROMs), random access memories (RAMs), EPROMs, EEPROMs, magnetic or optical cards, or any type of media suitable for storing electronic instructions, and each coupled to a computer system bus.
The algorithms and modules presented herein are not inherently related to any particular computer or other apparatus. Various general-purpose systems can be used with programs in accordance with the teachings herein, or it can prove convenient to construct more specialized apparatuses to perform the method steps. The required structure for a variety of these systems will appear from the description. In addition, the present examples are not described with reference to any particular programming language. It will be appreciated that a variety of programming languages can be used to implement the teachings as described herein. Furthermore, as will be apparent to one of ordinary skill in the relevant art, the modules, features, attributes, methodologies, and other aspects can be implemented as software, hardware, firmware or any combination of the three. Of course, wherever a component is implemented as software, the component can be implemented as a standalone program, as part of a larger program, as a plurality of separate programs, as a statically or dynamically linked library, as a kernel loadable module, as a device driver, and/or in every and any other way known now or in the future to those of skill in the art of computer programming. Additionally, the present description is in no way limited to implementation in any specific operating system or environment.
It will be understood by those skilled in the relevant art that the above-described implementations are merely exemplary, and many changes can be made without departing from the true spirit and scope of the present invention. Therefore, it is intended by the appended claims to cover all such changes and modifications that come within the true spirit and scope of this invention.
This application is a continuation application of and claims priority to U.S. application Ser. No. 11/760,708, filed on Jun. 8, 2007. The disclosure of the foregoing application is incorporated herein by reference.
Number | Name | Date | Kind |
---|---|---|---|
5150407 | Chan | Sep 1992 | A |
5150473 | Zulch | Sep 1992 | A |
5163148 | Walls | Nov 1992 | A |
5276867 | Kenley et al. | Jan 1994 | A |
5349658 | O'Rourke et al. | Sep 1994 | A |
5369570 | Parad | Nov 1994 | A |
5574846 | Yoshimura et al. | Nov 1996 | A |
5659614 | Bailey | Aug 1997 | A |
5664186 | Bennett et al. | Sep 1997 | A |
5680562 | Conrad et al. | Oct 1997 | A |
5736974 | Selker | Apr 1998 | A |
5745669 | Hugard et al. | Apr 1998 | A |
5754178 | Johnston et al. | May 1998 | A |
5758359 | Saxon | May 1998 | A |
5790120 | Lozares et al. | Aug 1998 | A |
5802175 | Kara | Sep 1998 | A |
5818936 | Mashayekhi | Oct 1998 | A |
5819032 | De Vries et al. | Oct 1998 | A |
5819292 | Hitz et al. | Oct 1998 | A |
5831617 | Bhukhanwala | Nov 1998 | A |
5832526 | Schuyler | Nov 1998 | A |
5961605 | Deng et al. | Oct 1999 | A |
5987566 | Vishlitzky et al. | Nov 1999 | A |
6006227 | Freeman et al. | Dec 1999 | A |
6023506 | Ote et al. | Feb 2000 | A |
6054989 | Robertson et al. | Apr 2000 | A |
6097313 | Takahashi et al. | Aug 2000 | A |
6112318 | Jouppi et al. | Aug 2000 | A |
6121969 | Jain et al. | Sep 2000 | A |
6134660 | Boneh et al. | Oct 2000 | A |
6167532 | Wisecup | Dec 2000 | A |
6188405 | Czerwinski et al. | Feb 2001 | B1 |
6269381 | St. Pierre et al. | Jul 2001 | B1 |
6366988 | Skiba et al. | Apr 2002 | B1 |
6396500 | Qureshi et al. | May 2002 | B1 |
6397308 | Ofek et al. | May 2002 | B1 |
6424626 | Kidambi et al. | Jul 2002 | B1 |
6460055 | Midgley et al. | Oct 2002 | B1 |
6493745 | Cherian | Dec 2002 | B1 |
6553392 | Mosher, Jr. et al. | Apr 2003 | B1 |
6574733 | Langford | Jun 2003 | B1 |
6600501 | Israel et al. | Jul 2003 | B1 |
6604118 | Kleiman et al. | Aug 2003 | B2 |
6625704 | Winokur | Sep 2003 | B2 |
6629129 | Bookspan et al. | Sep 2003 | B1 |
6636937 | Peter | Oct 2003 | B2 |
6638313 | Freeman et al. | Oct 2003 | B1 |
6701454 | Fischer et al. | Mar 2004 | B1 |
6711572 | Zakharov et al. | Mar 2004 | B2 |
6714201 | Grinstein et al. | Mar 2004 | B1 |
6714952 | Dunham et al. | Mar 2004 | B2 |
6724918 | Yen et al. | Apr 2004 | B1 |
6725427 | Freeman et al. | Apr 2004 | B2 |
6728735 | Fong | Apr 2004 | B1 |
6750890 | Sugimoto | Jun 2004 | B1 |
6760723 | Oshinsky et al. | Jul 2004 | B2 |
6768999 | Prager et al. | Jul 2004 | B2 |
6785751 | Connor | Aug 2004 | B1 |
6785786 | Gold et al. | Aug 2004 | B1 |
6801229 | Tinkler | Oct 2004 | B1 |
6836657 | Ji et al. | Dec 2004 | B2 |
6857001 | Hitz et al. | Feb 2005 | B2 |
6892211 | Hitz et al. | May 2005 | B2 |
6901493 | Maffezzoni | May 2005 | B1 |
6918124 | Novik et al. | Jul 2005 | B1 |
6947556 | Matyas et al. | Sep 2005 | B1 |
6948039 | Biessener et al. | Sep 2005 | B2 |
6959368 | St. Pierre et al. | Oct 2005 | B1 |
6993710 | Coad et al. | Jan 2006 | B1 |
7069402 | Coulter et al. | Jun 2006 | B2 |
7072916 | Lewis et al. | Jul 2006 | B1 |
7099900 | Bromley et al. | Aug 2006 | B1 |
7103740 | Colgrove et al. | Sep 2006 | B1 |
7107527 | Takahashi et al. | Sep 2006 | B2 |
7111136 | Yamagami | Sep 2006 | B2 |
7133902 | Saha et al. | Nov 2006 | B2 |
7134026 | Horiuchi et al. | Nov 2006 | B2 |
7155486 | Aoshima et al. | Dec 2006 | B2 |
7174352 | Kleiman et al. | Feb 2007 | B2 |
7185028 | Lechner | Feb 2007 | B2 |
7200617 | Kibuse | Apr 2007 | B2 |
7213040 | Stokes et al. | May 2007 | B1 |
7222194 | Kano et al. | May 2007 | B2 |
7243310 | Crain et al. | Jul 2007 | B2 |
7257717 | Huang | Aug 2007 | B2 |
7275075 | Cannon | Sep 2007 | B2 |
7284190 | Chellis et al. | Oct 2007 | B2 |
7289973 | Kiessig et al. | Oct 2007 | B2 |
7318134 | Oliveira et al. | Jan 2008 | B1 |
7320076 | Caronni | Jan 2008 | B2 |
7386801 | Horvitz et al. | Jun 2008 | B1 |
7401194 | Jewell | Jul 2008 | B2 |
7418619 | Uhlmann et al. | Aug 2008 | B1 |
7421449 | Williams et al. | Sep 2008 | B2 |
7434164 | Salesin et al. | Oct 2008 | B2 |
7434177 | Ording et al. | Oct 2008 | B1 |
7440125 | Maekawa et al. | Oct 2008 | B2 |
7483693 | Lueng et al. | Jan 2009 | B2 |
7505762 | Onyon et al. | Mar 2009 | B2 |
7518611 | Boyd et al. | Apr 2009 | B2 |
7558930 | Kitamura et al. | Jul 2009 | B2 |
7559016 | Rakowski et al. | Jul 2009 | B1 |
7574459 | Sen et al. | Aug 2009 | B2 |
7590668 | Kathuria et al. | Sep 2009 | B2 |
7596586 | Gokhale et al. | Sep 2009 | B2 |
7600133 | Long et al. | Oct 2009 | B2 |
7620670 | Tokuda et al. | Nov 2009 | B2 |
7624133 | Ojalvo | Nov 2009 | B1 |
7630021 | Matsuzaka et al. | Dec 2009 | B2 |
7657450 | Amit et al. | Feb 2010 | B2 |
7660817 | Smith et al. | Feb 2010 | B2 |
7669141 | Pegg | Feb 2010 | B1 |
7676689 | Shioyama et al. | Mar 2010 | B1 |
7703044 | Graham | Apr 2010 | B2 |
7711771 | Kirnos | May 2010 | B2 |
7716171 | Kryger | May 2010 | B2 |
7734594 | Wang | Jun 2010 | B2 |
7735018 | Bakhash | Jun 2010 | B2 |
7739464 | Coulter et al. | Jun 2010 | B1 |
7739622 | DeLine et al. | Jun 2010 | B2 |
7743347 | Graham et al. | Jun 2010 | B2 |
7747655 | Hull et al. | Jun 2010 | B2 |
7752573 | Shiba et al. | Jul 2010 | B2 |
7761456 | Cram et al. | Jul 2010 | B1 |
7774718 | Finke-Anlauff et al. | Aug 2010 | B2 |
7788080 | Graham et al. | Aug 2010 | B2 |
7788592 | Williams et al. | Aug 2010 | B2 |
7800615 | MacPherson | Sep 2010 | B2 |
7809687 | Cisler et al. | Oct 2010 | B2 |
7809688 | Cisler et al. | Oct 2010 | B2 |
7836311 | Kuriya et al. | Nov 2010 | B2 |
7853566 | Cisler et al. | Dec 2010 | B2 |
7853567 | Cisler et al. | Dec 2010 | B2 |
7856424 | Cisler et al. | Dec 2010 | B2 |
7860839 | Cisler et al. | Dec 2010 | B2 |
7882072 | Axe et al. | Feb 2011 | B1 |
7890527 | Nene et al. | Feb 2011 | B1 |
7899829 | Malla | Mar 2011 | B1 |
7934064 | Per et al. | Apr 2011 | B1 |
7953730 | Bleckner | May 2011 | B1 |
7999810 | Boice et al. | Aug 2011 | B1 |
8010900 | Hart et al. | Aug 2011 | B2 |
8024292 | Thompson et al. | Sep 2011 | B2 |
8055911 | Feng et al. | Nov 2011 | B2 |
8099392 | Paterson et al. | Jan 2012 | B2 |
8161410 | Bray | Apr 2012 | B2 |
8166415 | Cisler et al. | Apr 2012 | B2 |
8209308 | Rueben et al. | Jun 2012 | B2 |
8219995 | Flemming et al. | Jul 2012 | B2 |
8229897 | Cannon et al. | Jul 2012 | B2 |
8234591 | Dhawan et al. | Jul 2012 | B1 |
8245078 | Chatterjee et al. | Aug 2012 | B1 |
8260770 | Bell et al. | Sep 2012 | B2 |
8375318 | Masuda et al. | Feb 2013 | B2 |
8484569 | Carlson et al. | Jul 2013 | B2 |
8490019 | Jarrett et al. | Jul 2013 | B2 |
8495024 | Cisler et al. | Jul 2013 | B2 |
8533593 | Grossman et al. | Sep 2013 | B2 |
8627195 | Hayden | Jan 2014 | B1 |
8775378 | Cisler et al. | Jul 2014 | B2 |
8839087 | Hayden | Sep 2014 | B1 |
9009115 | Cisler et al. | Apr 2015 | B2 |
9134879 | Kumamoto | Sep 2015 | B2 |
20010047368 | Oshinsky et al. | Nov 2001 | A1 |
20010055317 | Kajizaki et al. | Dec 2001 | A1 |
20020016912 | Johnson | Feb 2002 | A1 |
20020023198 | Kokubun et al. | Feb 2002 | A1 |
20020046220 | Freeman et al. | Apr 2002 | A1 |
20020049883 | Schneider et al. | Apr 2002 | A1 |
20020054158 | Asami | May 2002 | A1 |
20020063737 | Feig et al. | May 2002 | A1 |
20020065999 | Kikuchi et al. | May 2002 | A1 |
20020075322 | Rosenzweig et al. | Jun 2002 | A1 |
20020080180 | Mander et al. | Jun 2002 | A1 |
20020107886 | Gentner et al. | Aug 2002 | A1 |
20020112237 | Kelts | Aug 2002 | A1 |
20020120648 | Ball et al. | Aug 2002 | A1 |
20020156921 | Dutta et al. | Oct 2002 | A1 |
20020160760 | Aoyama | Oct 2002 | A1 |
20020174283 | Lin | Nov 2002 | A1 |
20030016248 | Hayes Ubillos | Jan 2003 | A1 |
20030018878 | Dorward et al. | Jan 2003 | A1 |
20030038831 | Engelfriet | Feb 2003 | A1 |
20030050940 | Robinson | Mar 2003 | A1 |
20030063128 | Salmimaa et al. | Apr 2003 | A1 |
20030065687 | Momiji et al. | Apr 2003 | A1 |
20030097640 | Abrams et al. | May 2003 | A1 |
20030122874 | Dieberger et al. | Jul 2003 | A1 |
20030126247 | Strasser et al. | Jul 2003 | A1 |
20030131007 | Schirmer et al. | Jul 2003 | A1 |
20030135650 | Kano et al. | Jul 2003 | A1 |
20030137540 | Klevenz et al. | Jul 2003 | A1 |
20030167380 | Green et al. | Sep 2003 | A1 |
20030172937 | Faries et al. | Sep 2003 | A1 |
20030177149 | Coombs | Sep 2003 | A1 |
20030182332 | McBrearty et al. | Sep 2003 | A1 |
20030195903 | Manley et al. | Oct 2003 | A1 |
20030220949 | Witt et al. | Nov 2003 | A1 |
20040003351 | Sommerer et al. | Jan 2004 | A1 |
20040044707 | Richard | Mar 2004 | A1 |
20040066414 | Czerwinski et al. | Apr 2004 | A1 |
20040073560 | Edwards | Apr 2004 | A1 |
20040078641 | Fleischmann | Apr 2004 | A1 |
20040088331 | Therrien et al. | May 2004 | A1 |
20040117459 | Fry | Jun 2004 | A1 |
20040125137 | Stata et al. | Jul 2004 | A1 |
20040125150 | Adcock et al. | Jul 2004 | A1 |
20040133575 | Farmer et al. | Jul 2004 | A1 |
20040139396 | Gelernter et al. | Jul 2004 | A1 |
20040143652 | Grannan et al. | Jul 2004 | A1 |
20040153973 | Horwitz | Aug 2004 | A1 |
20040163009 | Goldstein et al. | Aug 2004 | A1 |
20040167942 | Oshinsky et al. | Aug 2004 | A1 |
20040175000 | Caronni | Sep 2004 | A1 |
20040193953 | Callahan et al. | Sep 2004 | A1 |
20040199779 | Huang | Oct 2004 | A1 |
20040199826 | Bertram et al. | Oct 2004 | A1 |
20040210608 | Lee et al. | Oct 2004 | A1 |
20040220965 | Harville et al. | Nov 2004 | A1 |
20040220980 | Forster | Nov 2004 | A1 |
20040222992 | Calkins et al. | Nov 2004 | A1 |
20040228493 | Ma | Nov 2004 | A1 |
20040230892 | Horton | Nov 2004 | A1 |
20040235523 | Schrire et al. | Nov 2004 | A1 |
20040236769 | Smith et al. | Nov 2004 | A1 |
20040236916 | Berkowitz et al. | Nov 2004 | A1 |
20040236958 | Teicher et al. | Nov 2004 | A1 |
20040267700 | Dumais et al. | Dec 2004 | A1 |
20050010955 | Elia et al. | Jan 2005 | A1 |
20050047295 | Kim et al. | Mar 2005 | A1 |
20050071390 | Midgley et al. | Mar 2005 | A1 |
20050086613 | McKnight et al. | Apr 2005 | A1 |
20050091596 | Anthony et al. | Apr 2005 | A1 |
20050097475 | Makioka et al. | May 2005 | A1 |
20050102329 | Jiang et al. | May 2005 | A1 |
20050102695 | Musser | May 2005 | A1 |
20050108253 | Metsatahti et al. | May 2005 | A1 |
20050138013 | Walker et al. | Jun 2005 | A1 |
20050138066 | Finke-Anlauff et al. | Jun 2005 | A1 |
20050138081 | Alshab et al. | Jun 2005 | A1 |
20050144135 | Juarez et al. | Jun 2005 | A1 |
20050149577 | Okada et al. | Jul 2005 | A1 |
20050165867 | Barton et al. | Jul 2005 | A1 |
20050187992 | Prahlad et al. | Aug 2005 | A1 |
20050204186 | Rothman et al. | Sep 2005 | A1 |
20050216520 | He et al. | Sep 2005 | A1 |
20050216527 | Erlingsson | Sep 2005 | A1 |
20050246398 | Barzilai et al. | Nov 2005 | A1 |
20050262168 | Helliker et al. | Nov 2005 | A1 |
20050262377 | Sim-Tang | Nov 2005 | A1 |
20060026218 | Urmston | Feb 2006 | A1 |
20060036568 | Moore et al. | Feb 2006 | A1 |
20060041603 | Paterson et al. | Feb 2006 | A1 |
20060041823 | Wolfgang et al. | Feb 2006 | A1 |
20060053332 | Uhlmann et al. | Mar 2006 | A1 |
20060064444 | Van Ingen et al. | Mar 2006 | A1 |
20060064634 | Dettinger et al. | Mar 2006 | A1 |
20060080521 | Barr et al. | Apr 2006 | A1 |
20060085792 | Traut | Apr 2006 | A1 |
20060085817 | Kim et al. | Apr 2006 | A1 |
20060088167 | Bade et al. | Apr 2006 | A1 |
20060101384 | Sim-Tang et al. | May 2006 | A1 |
20060106893 | Daniels et al. | May 2006 | A1 |
20060117022 | Lucas | Jun 2006 | A1 |
20060117309 | Singhal et al. | Jun 2006 | A1 |
20060129496 | Chow et al. | Jun 2006 | A1 |
20060137010 | Kramer et al. | Jun 2006 | A1 |
20060143250 | Peterson et al. | Jun 2006 | A1 |
20060150107 | Leung et al. | Jul 2006 | A1 |
20060156246 | Williams et al. | Jul 2006 | A1 |
20060156259 | Wagner et al. | Jul 2006 | A1 |
20060161861 | Holecek et al. | Jul 2006 | A1 |
20060173848 | Peterson et al. | Aug 2006 | A1 |
20060200754 | Kablesh et al. | Sep 2006 | A1 |
20060206460 | Gadkari | Sep 2006 | A1 |
20060218363 | Palapudi | Sep 2006 | A1 |
20060224956 | Storisteanu et al. | Oct 2006 | A1 |
20060235907 | Kathuria et al. | Oct 2006 | A1 |
20060236406 | Johnson | Oct 2006 | A1 |
20060248294 | Nedved et al. | Nov 2006 | A1 |
20060253470 | Friedman et al. | Nov 2006 | A1 |
20060288205 | Linares | Dec 2006 | A1 |
20070015118 | Nickell et al. | Jan 2007 | A1 |
20070027935 | Haselton et al. | Feb 2007 | A1 |
20070030528 | Quaeler et al. | Feb 2007 | A1 |
20070038884 | Campbell et al. | Feb 2007 | A1 |
20070043715 | Kaushik et al. | Feb 2007 | A1 |
20070043790 | Kryger | Feb 2007 | A1 |
20070070066 | Bakhash | Mar 2007 | A1 |
20070078910 | Bopardikar | Apr 2007 | A1 |
20070088702 | Fridella et al. | Apr 2007 | A1 |
20070094312 | Sim-Tang | Apr 2007 | A1 |
20070106978 | Felts | May 2007 | A1 |
20070117459 | Chen | May 2007 | A1 |
20070130232 | Therrien et al. | Jun 2007 | A1 |
20070136381 | Cannon et al. | Jun 2007 | A1 |
20070136389 | Bergant et al. | Jun 2007 | A1 |
20070136423 | Gilmore et al. | Jun 2007 | A1 |
20070143425 | Kieselbach et al. | Jun 2007 | A1 |
20070150326 | Nakao et al. | Jun 2007 | A1 |
20070156772 | Lechner | Jul 2007 | A1 |
20070168497 | Locker et al. | Jul 2007 | A1 |
20070174580 | Shulga | Jul 2007 | A1 |
20070180268 | Filimon et al. | Aug 2007 | A1 |
20070185879 | Roublev et al. | Aug 2007 | A1 |
20070185922 | Kapoor et al. | Aug 2007 | A1 |
20070186127 | Desai et al. | Aug 2007 | A1 |
20070192386 | Fries et al. | Aug 2007 | A1 |
20070245238 | Fugitt et al. | Oct 2007 | A1 |
20070266007 | Arrouye et al. | Nov 2007 | A1 |
20070271263 | Merrild | Nov 2007 | A1 |
20070271303 | Menendez et al. | Nov 2007 | A1 |
20070282854 | Bhogal et al. | Dec 2007 | A1 |
20070288536 | Sen et al. | Dec 2007 | A1 |
20080016576 | Ueda et al. | Jan 2008 | A1 |
20080022393 | Waltermann et al. | Jan 2008 | A1 |
20080028007 | Ishii et al. | Jan 2008 | A1 |
20080033922 | Cisler et al. | Feb 2008 | A1 |
20080033969 | Koo et al. | Feb 2008 | A1 |
20080034004 | Cisler et al. | Feb 2008 | A1 |
20080034011 | Cisler et al. | Feb 2008 | A1 |
20080034013 | Cisler et al. | Feb 2008 | A1 |
20080034016 | Cisler et al. | Feb 2008 | A1 |
20080034017 | Giampaolo et al. | Feb 2008 | A1 |
20080034018 | Cisler et al. | Feb 2008 | A1 |
20080034019 | Cisler et al. | Feb 2008 | A1 |
20080034039 | Cisler et al. | Feb 2008 | A1 |
20080046557 | Cheng | Feb 2008 | A1 |
20080059894 | Cisler et al. | Mar 2008 | A1 |
20080065663 | Farlee et al. | Mar 2008 | A1 |
20080070496 | Jackson | Mar 2008 | A1 |
20080071796 | Ghuneim | Mar 2008 | A1 |
20080077808 | Teicher et al. | Mar 2008 | A1 |
20080082578 | Hogue et al. | Apr 2008 | A1 |
20080091655 | Gokhale et al. | Apr 2008 | A1 |
20080126441 | Cisler et al. | May 2008 | A1 |
20080126442 | Cisler et al. | May 2008 | A1 |
20080133487 | Gross | Jun 2008 | A1 |
20080141029 | Culver | Jun 2008 | A1 |
20080162999 | Schlueter et al. | Jul 2008 | A1 |
20080168184 | Freedman et al. | Jul 2008 | A1 |
20080168245 | De Atley et al. | Jul 2008 | A1 |
20080168391 | Robbin et al. | Jul 2008 | A1 |
20080172607 | Baer | Jul 2008 | A1 |
20080177961 | McSharry et al. | Jul 2008 | A1 |
20080208630 | Fors et al. | Aug 2008 | A1 |
20080214163 | Onyon et al. | Sep 2008 | A1 |
20080216011 | Gould | Sep 2008 | A1 |
20080222512 | Albornoz et al. | Sep 2008 | A1 |
20080229037 | Bunte et al. | Sep 2008 | A1 |
20080250314 | Larsen | Oct 2008 | A1 |
20080250342 | Clark et al. | Oct 2008 | A1 |
20080250400 | Vertes | Oct 2008 | A1 |
20080256138 | Sim-Tang | Oct 2008 | A1 |
20080285754 | Kezmann | Nov 2008 | A1 |
20080307000 | Paterson et al. | Dec 2008 | A1 |
20080307017 | Lyons et al. | Dec 2008 | A1 |
20080307018 | Ulrich et al. | Dec 2008 | A1 |
20080307019 | Weiss et al. | Dec 2008 | A1 |
20080307020 | Ko et al. | Dec 2008 | A1 |
20080307175 | Hart et al. | Dec 2008 | A1 |
20080307333 | McInerney et al. | Dec 2008 | A1 |
20080307347 | Cisler et al. | Dec 2008 | A1 |
20080310628 | Fujioka et al. | Dec 2008 | A1 |
20080310633 | Brown et al. | Dec 2008 | A1 |
20080313243 | Poston et al. | Dec 2008 | A1 |
20090019291 | Murray | Jan 2009 | A1 |
20090031401 | Cudich et al. | Jan 2009 | A1 |
20090052669 | Ma | Feb 2009 | A1 |
20090254591 | Weiss et al. | Oct 2009 | A1 |
20090307333 | Welingkar et al. | Dec 2009 | A1 |
20100017855 | Johnson et al. | Jan 2010 | A1 |
20100063960 | Lehto | Mar 2010 | A1 |
20100217929 | Kirshenbaum et al. | Aug 2010 | A1 |
20100306171 | Antos et al. | Dec 2010 | A1 |
20100312754 | Bear et al. | Dec 2010 | A1 |
20110016089 | Freedman et al. | Jan 2011 | A1 |
20110083088 | Cisler et al. | Apr 2011 | A1 |
20110083098 | Cisler et al. | Apr 2011 | A1 |
20110087976 | Cisler et al. | Apr 2011 | A1 |
20110202763 | Martin et al. | Aug 2011 | A1 |
20120124507 | Paterson et al. | May 2012 | A1 |
20120185438 | Giampaolo et al. | Jul 2012 | A1 |
20120185762 | Ozer et al. | Jul 2012 | A1 |
20120198383 | Cisler et al. | Aug 2012 | A1 |
20130066836 | Weiss et al. | Mar 2013 | A1 |
20130212599 | Giampaolo et al. | Aug 2013 | A1 |
Number | Date | Country |
---|---|---|
0629950 | Dec 1994 | EP |
1152352 | Nov 2001 | EP |
1582982 | Oct 2005 | EP |
0106356 | Jan 2001 | WO |
02101540 | Dec 2002 | WO |
2005045756 | May 2005 | WO |
2008019237 | Feb 2008 | WO |
2008019259 | Feb 2008 | WO |
Entry |
---|
Chen et al., “Data Redundancy and Compression Methods for a Disk-based Network Backup System”, 2004, IEEE, pp. 1-8. |
Wang et al., “A Secure and Efficient Desktop Backup and Recovery System”, 2007, IEEE, pp. 304-309. |
“Apple Previews Mac OS X Leopard,” Aug. 7, 2006, [Online] [Retrieved on Nov. 26, 2007] Retrieved from the Internet: URL:http://www.apple.com/pr/library/2006/aug/07leopard.html, pp. 1-2. |
“Aulaclic: Unit 6. The Recycle Bin,” Nov. 2005, [Online] [Retrieved on Nov. 26, 2007] Retrieved from the Internet: URL:http://www.teacherclick.com/winxp/t—6—1.htm, pp. 1-2. |
Bonwick, “ZFS The Last Word in File Systems,” [Online] [Retrieved on Jan. 22, 2008] Retrieved from the Internet: URL:http://opensolaris.org/os/community/zfs/docs/zfs.pdf, 34 pages. |
Bonwick et al., “The Zettabyte File System,” [Online] [Retrieved on Jan. 22, 2008] Retrieved from the Internet: URL:http://partneradvantage.sun.com/protected/solaris10/adoptionkit/tech/zfs/zfs—overview.pdf, 13 pages. |
Bott, “Windows XP Backup Made Easy,” [Online] [Retrieved on Jul. 7, 2009]; Retrieved from the Internet URL: http://www.microsoft.com/windowsxp/using/setup/learnmore/bott—03july14.mspx, 4 pages. |
Engst, “Retrospect 6.0: Powerful Backup Program Adds Panther Compatibility and Enterprise Features,” [Online] [Retrieved on Jul. 8, 2009]; Retrieved from the Internet URL: http://www.macworld.com/article/31038/2004/06/retrospect6x0.html, 8 pages. |
Griffiths, “Leopard first looks: Time Machine,” Aug. 8, 2006 [Online] [Retrieved on Nov. 23, 2007] Retrieved from the Internet: URL:http://www.macworld.com/2006/08/firstlooks/leotimemac/index.php?pf=1, pp. 1-2. |
Harder, “Microsoft Windows XP System Restore,” [Online] [Retrieved on Jul. 7, 2009] Retrieved from the Internet URL: http://msdn.microsoft.com/en-us/library/ms997627.aspx, 8 pages. |
“How to Interpret Windows Installer Logs,” [Online] [Retrieved on Dec. 12, 2009] Retrieved from the Internet URL: http://blogs.technet.com/richard—macdonald/archive/2007/04/02/How-to-Interpret-Windows-Installer-Logs.aspx; published Apr. 4, 2007; 6 pages. |
In-nk files, The Open Group Base, Specifications Issue 6 [online]. IEEE Std 1003.1, 2004 Edition. [retrieved on Apr. 6, 2011]. Retrieved from the Internet:URL:http://pubs.opengroup.org/onlinepubs/009695399/utilities/In.html, 5 pages. |
Microsoft-TechNet, “Using Encrypting File System,” Nov. 3, 2005, Microsoft, 40 pages. |
“MSDN Academic Alliance Developer Center, Curriculum Repository Glossary,” [Online] [Retrieved on Apr. 22, 2009] Retrieved from the Internet URL: http://www.academicresourcecenter.net/curriculum/glossary.aspx, 4 pages. |
Posey, Brien M., “Working with the Windows Server 2003 vol. Shadow Copy Service”. Published Jun. 24, 2004. http://www.windowsnetworking.com/articles—tutorials/Windows-Server-2003-Volume-Shadow-Copy-Service.html.; 11 pages. |
Rubel, “Easy Automated Snapshot-Style Backups with Rsync,” [Online] [Retrieved on Nov. 8, 2010] Retrieved from the Internet URL: http://www.mikerubel.org/computers/rsync—snapshots; 18 pages. |
“StorageSync: Backup, Restore, & Synchronization Software User's Guide”, SimpleTech, 2003, 100 pages. |
Sun Microsystems, Inc., “ZFS On-Disk Specification,” Draft: Dec. 9, 2005, [Online] [Retrieved on Jan. 22, 2008]; Retrieved from the Internet URL: http://opensolaris.org/os/community/zfs/docs/ondiskformat0822.pdf 55 pages. |
Tittel, “An EAZ Way to Restore Crippled and Inoperable Systems,” ChannelWeb, Apr. 25, 2005, [Online] [Retrieved on Aug. 13, 2008] Retrieved from the Internet URL: http://www.crn.com/white-box/161502165, 10 pages. |
“What's New in Word 2002,” Wellesly College Information Services Computing Documentation, Jan. 2002, [Online] Retrieved on Aug. 14, 2008] Retrieved from the Internet URL: http://www.wellesley.edu/Computing/Office02/Word02/word02.html, 19 pages. |
International Search Report and Written Opinion, PCT/US2007/074729, Jul. 12, 2007, 11 pages. |
International Search Report and Written Opinion, PCT/US2007/074881, Jul. 12, 2007, 11 pages. |
International Search Report and Written Opinion, PCT/US2007/074653, Aug. 14, 2008, 14 pages. |
International Search Report and Written Opinion, PCT/US2008/065146, Oct. 31, 2008, 21 pages. |
International Search Report and Written Opinion, PCT/US2008/066212, Mar. 9, 2009, 26 pages. |
International Search Report and Written Opinion, PCT/US2007/074863 Apr. 21, 2009, 20 pages. |
Communication pursuant to Article 94(3) EPC for Application No. EP 07 799 899.5, dated May 14, 2009, 2 pages. |
Communication pursuant to Article 94(3) EPC for Application No. EP 07 799 899.5, dated Oct. 7, 2009, 4 pages. |
Microsoft Technet: “Restore a previous version of a file,” Jan. 21, 2005, [Online] [Retrieved on Oct. 20, 2011] Retrieved from the Internet URL: http://technet.microsoft.com/en-us/library/cc778220(d=printer,v=WS.10).aspx , pp. 1-2. (From 18962-0128EP1 OA dated Oct. 27, 2011). |
Examination Report from European Application No. 07 813 605.8 dated Oct. 27, 2011, 5 pages. |
Examination Report from European Application No. 07 813 540.7 dated Oct. 27, 2011, 5 pages. |
Extended European Search Report, European Application No. 11184579.8, Nov. 17, 2011, 6 pages. |
Office Action dated Feb. 29, 2012 from related Chinese Application No. 200880024710.0, 11 pages. |
Godfrey, Michael et al., “Using Original Analysis to Detect Merging and Splitting of Source Code Entities,” IEEE Transactions on Software Engineering, vol. 31, No. 2. Feb. 2005. pp. 166-181. |
Microsoft Technet: “Restore a previous version of a file,” Jan. 21, 2005, [Online] [Retrieved on Oct. 20, 2011] Retrieved from the Internet URL: http://technet.microsoft.com/en-us/library/cc778220(d=printer,v=WS.10).aspx , pp. 1-2. |
Communication pursuant to Article 94(3) EPC for Application No. EP 07 813 540.7, dated Jun. 23, 2009, 2 pages. |
Extended International Search Report and Written Opinion, EP 11171738.5, Aug. 29, 2011, 5 pages. |
“Charles Rubin, Mary Millhollon and Katherine Murray,” Microsoft Office Word 2003, Official Manual, First Edition, Japan, Nikkei BP Softpress, Jul. 12, 2004, vol. 1, p. 300, 815-818. |
Microsoft Corporation, “Description of the AutoRecover Functions in Excel,” [online] Microsoft Corporation, Aug. 10, 2007, Article ID 289273; URL: http://support.microsoft.com/kb/289273/en-us. |
Office Action dated Apr. 1, 2015 from related Chinese Application No. 201310073409.1, 13 pages. |
Number | Date | Country | |
---|---|---|---|
20110302502 A1 | Dec 2011 | US |
Number | Date | Country | |
---|---|---|---|
Parent | 11760708 | Jun 2007 | US |
Child | 13211273 | US |