WO2000070445A2 - Apparatus and method for transferring information between platforms - Google Patents

Apparatus and method for transferring information between platforms Download PDF

Info

Publication number
WO2000070445A2
WO2000070445A2 PCT/US2000/013070 US0013070W WO0070445A2 WO 2000070445 A2 WO2000070445 A2 WO 2000070445A2 US 0013070 W US0013070 W US 0013070W WO 0070445 A2 WO0070445 A2 WO 0070445A2
Authority
WO
WIPO (PCT)
Prior art keywords
computer
target
source
program
stored
Prior art date
Application number
PCT/US2000/013070
Other languages
French (fr)
Other versions
WO2000070445A3 (en
Inventor
David Henrickson
Eiko Eisen
Original Assignee
Eisenworld International
Priority date (The priority date is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the date listed.)
Filing date
Publication date
Application filed by Eisenworld International filed Critical Eisenworld International
Priority to AU48452/00A priority Critical patent/AU4845200A/en
Publication of WO2000070445A2 publication Critical patent/WO2000070445A2/en
Publication of WO2000070445A3 publication Critical patent/WO2000070445A3/en

Links

Classifications

    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F9/00Arrangements for program control, e.g. control units
    • G06F9/06Arrangements for program control, e.g. control units using stored programs, i.e. using an internal store of processing equipment to receive or retain programs
    • G06F9/44Arrangements for executing specific programs
    • G06F9/445Program loading or initiating
    • G06F9/44505Configuring for program initiating, e.g. using registry, configuration files
    • G06F9/4451User profiles; Roaming
    • YGENERAL TAGGING OF NEW TECHNOLOGICAL DEVELOPMENTS; GENERAL TAGGING OF CROSS-SECTIONAL TECHNOLOGIES SPANNING OVER SEVERAL SECTIONS OF THE IPC; TECHNICAL SUBJECTS COVERED BY FORMER USPC CROSS-REFERENCE ART COLLECTIONS [XRACs] AND DIGESTS
    • Y10TECHNICAL SUBJECTS COVERED BY FORMER USPC
    • Y10STECHNICAL SUBJECTS COVERED BY FORMER USPC CROSS-REFERENCE ART COLLECTIONS [XRACs] AND DIGESTS
    • Y10S707/00Data processing: database and file management or data structures
    • Y10S707/99951File or database maintenance
    • Y10S707/99952Coherency, e.g. same view to multiple users
    • Y10S707/99955Archiving or backup

Definitions

  • the present invention relates to an apparatus and method for intelligently and accurately relocating applications, settings, menus, and data files from a source machine to a target machine.
  • a method of moving documents from computer to computer involves saving the documents on a diskette at a source computer and physically moving the diskette to the target computer for saving thereon. Even if the user were to select only important documents for the move, the selected files might not fit on the diskette. This process, therefore, would become tedious if not impracticable for a user lacking sufficient experience in "disk-spanning.” Further, as the number of files to be moved increases so does the difficulty in completing the process.
  • a second method for relocating the files from a source to target computer utilizes a tape backup unit or other high capacity removable storage device in place of the diskette of the first example. The problem of large file size and some of the complexity of the move noted with respect to the first method is obviated through the use of such a storage device.
  • a third method for relocating files involves the use of a file transfer program. Examples of such programs include pcAnywhere32, LapLink, and FastMove! For machines connected to a network, these programs can be used to electronically transfer files from one computer to another. All three of these approaches may cope with the relatively simple problem of transferring data files from computer to computer, however, most users want not only to transfer selected data files, but also programs, settings and menus. It would be difficult if not impossible for the average user to transfer these types of files using any of the above methods.
  • Another technique for relocating files from one computer to another involves the physical relocation of the hard disk drive from the source computer to the target computer.
  • the older drive is likely to possess a slower access time and diminished storage capacity relative to the drive of the newer computer. Further, the older computer may not have lost all usefulness, as it might be kept as a backup computer or transferred to another user.
  • a final prior art solution to the file relocation problem involves the use of programs that are designed to attempt to indiscriminately copy absolutely every file from the old system to the new one. Most of the conventional hard disk copying methods are unable to produce a copy of every file on the drive, as several critical files resist copying because they are in use. Further one or more of the files that are copied to the target system may leave that system in an unstable state. Examples of programs that copy/duplicate entire disk drives from one machine to another bit for bit include Drive Image Pro, DiskClone, DriveCopy and GHOST.
  • the hard drive duplication programs operate well, however, if and only if the machines are nearly identical.
  • the indiscriminate copying that is utilized by the duplication programs will result in the duplicated operating system having already been configured to function with the hardware of the source computer.
  • the programs of the target computer therefore, will fail to recognize the hardware in the target machine. The user would then have to go through the laborious process of configuring the programs on the target computer to accept the new hardware. Worse, the differences between the computer programs may result in the halting of the target computer requiring re-installation on the target computer.
  • the optimal use of disk duplication requires that the source and target computer be nearly identical.
  • the most likely reason for the user to move from one computer to another, however, is that the user has decided to upgrade to a newer/faster machine.
  • the older computer may have been inadequate to support the new hardware features that became available following its purchase, such as a universal serial bus (USB), digital video disk (DVD), etc.
  • the newer system may have come equipped with newer versions of programs such as an upgraded operating system. By indiscriminately copying all of the programs on the source computer to the target computer, the user would in effect be rendering useless much that he or she would like to have kept on the target machine.
  • the objects of the invention are to provide an efficient procedure for permitting a user to relocate all application programs, settings, menus, files and documents from a source machine to a target machine.
  • the invention comprises a computer program for performing a file transfer between a source computer and a target computer.
  • the program performs a method comprising, aiding a user in completing a connection between the source computer and target computer, comparing stored information from the source computer to stored information from the target computer for selecting a subset of the information for transfer from the source computer to the target computer, and transferring the selected information from the source computer to the target computer.
  • FIG. 1 is a flowchart of an overview of exemplary steps in a first embodiment of a file relocation process.
  • Fig. 2 is a flowchart of an overview of exemplary steps in a second embodiment of a file relocation process.
  • Fig. 3 is a flowchart of exemplary steps in a method of establishing a connection between a source and target machine.
  • Fig. 4 is a flowchart of exemplary steps in a method of developing a relocation plan.
  • Fig. 5 is a flowchart of exemplary steps in a method of finalizing a relocation plan.
  • Fig. 6 is a flowchart of exemplary steps in a method of relocating items.
  • Fig. 7a is a flowchart of exemplary steps in a method of reviewing the relocation procedure.
  • Fig. 7b is a flowchart of exemplary steps in a method of producing a report.
  • Fig. 8 is a flowchart of exemplary steps in a method of performing an undo after a relocation procedure. DESCRIPTION OF THE PREFERRED EMBODIMENT
  • Fig. 1 shows exemplary steps in a relocation process in accordance with the present invention.
  • the relocation process is performed by a relocation program.
  • the relocation process can be controlled by a single relocation program stored on either the target or source machines.
  • the relocation program can be stored on both target and source machines, wherein the programs perform in concert to complete the relocation process. This is called the dual control format.
  • sub-programs each individually designed to operate either on the target or source machine, act together to perform the relocation process. This is called the sub-program format.
  • the first step in the relocation process of Fig. 1 is to start the relocation program (step 10).
  • this step requires starting the program on both of the machines.
  • this step requires starting each of the sub-programs on its designated machine.
  • the second step in the relocation process is to establish a connection between the source and target machines (step 20).
  • the connection is used to transfer electronic information from the source computer to the target computer.
  • Exemplary connection types include a local area network (LAN) or wide area network (e.g., the Internet) to which both computers are connected.
  • the two computers can be directly connected via a serial port, parallel port, or universal serial bus (USB).
  • USB universal serial bus
  • a cable is used to physically connect the two machines. Methods of making these connections are well known in the art and will not be described here in detail.
  • the above listed connection types are considered exemplary in nature, other known methods of transferring information between platforms are not mentioned individually, but are considered to be within the scope of the invention.
  • the third step in the relocation process is to determine the items stored on the source and target machines (step 30). Such a determination can be performed by scanning the hard drives of both the source and target machines.
  • the relocation program on either the source or target machine directly scans its own hard drive to create a list of the items stored thereon and scans the hard drive of the other computer via the connection to create a list of the programs stored thereon.
  • the relocation program or sub-program stored on each machine performs a scan of the hard drive of that machine to create a list of the items stored thereon.
  • the resulting list of items includes such information about each item as its name, existence, version number, date, size, and content.
  • the fourth step in the relocation process is to select the information to be relocated from the source machine to the target machine (step 40).
  • This step is explained here as a single selection step, however, preferably, this step includes two sub-steps, a first substep of developing a relocation plan and second substep of finalizing the relocation plan.
  • the term information is intended to include not only individual items, but also selected data stored within those items.
  • the list of items on the source machine is reviewed (the review process is discussed below) to set an action to be taken with respect to that item.
  • the possible actions include no action, copy, replace, and merge. No action is selected when the item on the source machine is not to be relocated to the target machine. Copy is selected when a copy of the item is to be relocated from the source machine to the target machine.
  • Replace is selected when the item is to be written over a preexisting version of the item on the target machine.
  • Merge is selected when it is determined that a subset of the information within a item is to replace its counterpart information within a item on the target machine while leaving some of the information in that item unchanged.
  • the method by which it is determined which action is to be taken with respect to a specific item can be performed in a number of alternative arrangements.
  • the first form of information selection is called a rules driven process.
  • the relocation program applies selection rules to each item.
  • a selection rule is defined as a pre-programmed logical rule used to compare specific characteristics stored in the list of items on each machine.
  • An exemplary use of a selection rule resulting in the copy function is: if item A exists on source and not on target then set item to "copy.”
  • An exemplary use of a selection rule resulting in no action is: if version number of item A on source is lower than version number of item A on target, then set item to "no action.”
  • An exemplary use of a selection rule resulting in the replace function is: if version number of item A on source is higher than version number of item A on target, then set item to "replace.”
  • the date of the item can be substituted in the comparison for the version number.
  • a default selection rule can be used.
  • An example of a default selection rule is: select the item from the machine having the newer operating system.
  • the merge function discussed above is a special function that parses out data within certain kinds of items, wherein some of the data is replaced onto the target machine and some is left unchanged.
  • the merge function is used for menu and settings files on a source machine having counterpart files on the target machine.
  • the determination of which data to transfer and which to leave unchanged from a setting file is made in view of whether the setting relates to hardware settings, user specific settings, or software specific settings.
  • Hardware settings such as the designation of the modem, printer, monitor, etc., are unlikely to remain the same on the target machine as on the source machine. Such settings, therefore, will not generally be transferred during the relocation process.
  • User specific settings such as Internet bookmarks, e-mail settings, name, address, telephone number, however, will be merged into the counterpart files on the target machine during the relocation process.
  • a third type of settings information is software specific, such as the product ID of an application. This type of setting will be transferred only if the application is also transferred. If the application on the target machine is to be retained, then no action is taken
  • a second type of selection process is called the database driven selection process.
  • the relocation program is pre-programmed to include a database of actions to be taken with respect to individual known applications.
  • the database is the result of experimentation by the programmers of the relocation program to select preferred actions to be taken with respect to a specific versions of each application.
  • a third type of selection process is called the repository selection process.
  • This process operates using both rules and a repository database and is the presently preferred embodiment of the selection process.
  • rules are applied to each application, setting, menu, and data file.
  • an entry is made in a pre-programmed repository database. Entries in the repository database preempt the usual rule result to perform a different action with respect to the specified information.
  • Examples of such a repository database entry are: do not transfer "swap" file, or if transferring application A, items X, Y, and Z must be transferred regardless of the version of items X, Y, and Z. Because new versions of programs are continually released, it is necessary that the repository database information discussed above can be updated using extension files. Further, rules can be altered and updated by adding scripts to the relocation program. Both forms of updates can preferably be performed using the same extension file.
  • an automation file can be created to automatically perform a specific file transfer.
  • This database might include entries relative to a specific application or group of applications and rules for use with that application or group of applications. Specifically, the database might include entries requiring the transfer of application A along with files X, Y, and Z.
  • An exemplary selection rule for use with such an automation file is: transfer all data files ".aaa" for application A.
  • the final step in the relocation process is to relocate the selected information from the source to the target machine (step 50). During this step, the specific function selected with respect to each item in selection step 40 is performed.
  • Fig. 2 shows a second embodiment of the invention for use where a connection between the source and target machines cannot be made.
  • a storage device is substituted for the electronic connection between the computers.
  • Exemplary storage devices for use as the external storage device are a tape drive or a zip drive.
  • the first step in the process here requires starting the relocation program the source machine (step 10). Because the source and target machines are not directly connected, a migration application file (MAF) stored on an external storage device takes the place of the connection.
  • the relocation program on the source machine scans the drives of the source machine to create a list of the items on the source machine (step 60). The source machine next performs the selection step of determining which information is to be relocated from the source to the external storage location (step 70).
  • this step is performed without knowledge of the identity of the information stored on the target machine, this selection process is less selective than that performed when the machines can be connected, i.e., no comparison between item versions on the source and target drives can be performed. Instead, all of the information stored on the source drive, except for the subset of information that is predefined in the repository database to never be transferred, is copied to the MAF.
  • the next step in the relocation process is the creation of a MAF by storing the selected information on the storage device attached to the source machine (step 80).
  • the MAF can take the form of a compressed file on the storage device.
  • the storage device is then connected to the target machine (step 90).
  • the next step in the relocation process is to select the subset of the information from the MAF to be relocated to the target machine (step 100).
  • the target machine now connected to the external storage device, performs a selection step as if the external storage device were a source machine.
  • the applications, settings, menus, and data files stored as the MAF on the external storage device are selected for no action to be taken, or to be copied, replaced, or merged onto the target machine.
  • the final step in the relocation process is to relocate the selected information from the external storage device to the target machine (step 110).
  • the relocation program can perform the relocation processes of Figs. 1 and 2. If, for example, it is determined that a connection between the machines cannot be completed as required by the first relocation process, then the relocation program could perform instead the second relocation process.
  • a backup is made of each item set to be replaced and merged during the relocation process.
  • a relocation log can be created detailing each step in the relocation process.
  • a relocation program user would then be given the option of undoing the entire process at any point during the relocation by using an undo program.
  • the relocation program Upon selection of the "failsafe undo" command, the relocation program would undo that portion of the relocation process that had been performed to that point by erasing each of the copied items and replacing the merged and replaced items with backup items.
  • the relocation program determines the necessary free capacity on the target machine for completion of the relocation process. Should the relocation program determine that the free capacity on the target machine is inadequate to complete the procedure, a program designed to aid the user in allocating more free space on the target hard drive, such as a "disk space" wizard, could be initiated by the relocation program.
  • a first solution is to partition the single drive C: on the target machine into three drives C:, D: and E:, and thereafter relocate the items from the D: and E: drives on the source machine to the corresponding D: and E: sector of the C: drive on the target machine.
  • a second solution to differing drive numbers is to create subfolders on the target drive C:, for example C: ⁇ DRIVE_D and C: ⁇ DRIVE_E for storing the information from drives D: and E: respectively.
  • the relocation program would then automatically change settings, menus, desktop icons, etc.
  • a third solution to the problem of differing drive numbers is to relocate all of the selected information from the source drives to the single destination drive of the target machine. This may result in two items to be transferred to the single C: drive having identical names. This can be solved by conflict resolution between the two items, e.g., by renaming one of the items to be stored.
  • a final solution is to permit the user to de-select one of the multiple drives from the source machine for transfer of information to the target machine.
  • This solution would permit, for example, a user to physically transfer one drive from the source to the target machine while electronically transferring the information from the other drive to the target machine using the relocation program.
  • the invention also envisions that differing amounts of control of the relocation process be given to the user.
  • the relocation program would perform the relocation process by minimizing the input necessary from the user. Problems such as inadequate storage capacity would require input from the user, however, the process itself could be performed with little required of the user.
  • This form of relocation program is termed a go button relocation program. Specifically, many consumers do not have the requisite knowledge to make informed decisions about how best to selectively relocate programs, and so providing the opportunity to alter the decisions made by the relocation program would result in frustration or inefficient relocation procedures. Instead, in this arrangement, the relocation makes the best choice and performs the relocation program automatically, unless problems that it is unable to resolve on its own arise.
  • the relocation program could display the determined relocation plan to the user for review of the plan, whereby the user could modify the plan by adding or removing items to the list of those to be relocated.
  • the display of information could take the form of a tree, whereby after having scanned the available information on the source machine, the relocation produces a item list in the form of a tree from which individual programs or groups of programs could be selected for relocation by clicking on a checkbox associated therewith.
  • a batch command could be issued by the user to selectively alter the relocation process.
  • the different levels of review capability given to the user could be provided by a single program, whereby the user would be given the option of choosing the review level they desire.
  • a separate "pro" version of the program can be produced having a higher level of functionality for those desiring a greater amount of control of the process.
  • FIGs.3-6 show the presently preferred implementation of a relocation process in accordance with the present invention.
  • Fig. 3 shows exemplary steps in the establishment of a connection between the source and target computers.
  • the first step in establishing a connection is to start the relocation program on the source computer (step 200).
  • the relocation program will produce an interface screen in order to query the user regarding certain necessary information such as whether the computer is the source or target computer (step 205).
  • the user starts the relocation program on the target computer (step 210).
  • the relocation program determines the types of connections available (step 215).
  • the relocation program displays the available connection types (step 220) and defaults to the most appropriate one (step 225).
  • the user is given the option to override the selected connection type (step 230).
  • the relocation program attempts to establish a connection using each selected protocol.
  • connection selection step 220 The order of preference of connection types can be either pre-programmed or inputted by the user at connection selection step 220 (step 240).
  • the relocation program next determines whether a connection was successfully made (step 245). If the connection was made, the program exits connection step 10. If no connection was made, the program starts a program called a Help Wizard to aid the user in determining why the connection was unsuccessful. The Help Wizard reviews possible problems with the connection and returns the program to step 220 to repeat the connection attempt (step 240).
  • Figs. 4 and 5 show steps in a preferred embodiment for producing a relocation plan (step 30 of Figs. 1 and 2).
  • Fig. 4 shows steps in a preferred embodiment of a first sub-step of developing a relocation plan in the production of a relocation plan.
  • Fig. 5 shows steps in a preferred embodiment of a second sub- step of finalizing the relocation plan in the production of a relocation plan.
  • the first step in the development of a relocation plan is a pre-scan of the source and target machines performed by the relocation program.
  • the relocation program determines the number of disk drives on the source and target computers, the amount of disk space available on the target computer and the volume of stored data on the source computer (step 300). If incompatibility exists between the number of drives on the source computer and the number of drives on the target computer, the "Drive Letter Wizard" discussed above is initiated.
  • the relocation program next determines whetherthere is adequate disk space available on the target computer (step 305). If the available disk space on the target computer is inadequate, the relocation program starts a program called a Disk Space Wizard to aid the user in allocating space for the relocated items (step 310).
  • the relocation program proceeds to a determination of whether the relocation is to be partial or complete (step 315).
  • the computer chooses partial or complete relocation depending on the relationship between operating systems. An example of a partial relocation would be to select all settings and documents on the source for transfer, but not transfer the applications and menus. If there are major incompatibilities between the operating systems on the source and target computers, the relocation program will allow only a partial relocation. If there are no major incompatibilities, the relocation program will suggest a complete relocation, but will permit the user to select a partial relocation.
  • the incompatibility of operating systems is a predefined characteristic stored within the database repository in the relocation program based on tests performed on relocations from one operating system to another.
  • the next step in the development of a relocation plan is to determine a strategy for resolving conflicts between applications on both source and target computer (step 320).
  • Four options are provided for resolving the conflicts: assume that the applications on the target machine are most up-to-date; assume that the applications on the source machine are most up-to-date; make no assumptions but instead flag all items that are dubious; and most appropriate.
  • the present preferred conflict rule is the most appropriate rule, which selects the appropriate item based on version or date when possible. In situations where the program cannot determine using version or date, for example if that information is missing or incorrect, the relocation program will assume that the version of the item on the target machine is to be used.
  • the next step in the relocation plan is to determine a backup strategy (step 325).
  • the user is given the option to select one or more of a fail-safe undo option, a delayed replacement option and a conserve source items option.
  • the fail-safe undo option produces a backup of the items to be replaced on the target drive.
  • the delayed replacement option delays the replacement of any items on the target machine until reboot.
  • the conserve source items option produces a backup of the items on the source machine that were not selected for relocation from the source machine to the target machine by the relocation process.
  • the results of the general relocation plan including the results of relocation scope determination step 315, conflict resolution determination step 320 and backup strategy determination step 325 are displayed for review by the user (step 330).
  • the user is given the option of accepting the general relocation plan or overriding the plan (step 335). If the plan is not accepted, the relocation program gives the user the ability to alter the plan (340). The program then loops back to step 330. If the plan is accepted, the program proceeds to the finalization of the relocation plan.
  • Fig. 5 shows exemplary steps in the finalization of a relocation plan.
  • the first step in the finalization of the relocation plan is to access the information derived from the pre-scan of the source computer (step 400) and the target computer (step 405) from a file containing that information as a list of entries.
  • the relocation program then individually analyzes information pertaining to each entry (step 410).
  • the step of analyzing each entry includes a number of substeps.
  • the first substep in analyzing an entry is determining the action to be taken with respect to that entry (step 415).
  • the information about each entry will include, for example, its existence, version, date, size, and content.
  • the relocation program determines, for example, that a specific file type has been flagged in the repository database as being a taboo system file or directory, such that the item should not be relocated to the target computer.
  • the relocation program sets an action to be taken for each item among the selected actions of: no action, copy/create directory, replace, and merge.
  • Copy/create directory might be selected, for example, for an application on the source computer where the target computer does not have a version of that application.
  • Replace might be selected, for example, for an application having a newer version on the source computer than the target computer.
  • Merge might be selected, for example, for a directory or setting, wherein some of the data stored in the directory or setting is to be transferred and other data is to remain unchanged.
  • the relocation program includes a repository database of actions to be taken with respect to specific predefined programs.
  • each item is compared against the list of items in the repository database to determine if a predefined action has been set with respect to that item. If an action has been set, then no rule is applied to that item.
  • that item is compared against in the repository database to determine if a predefined action has been set with respect to that item. If an action has been set, the action from the repository database overrides the outcome of the selection rule.
  • the next substep in the step of analyzing each entry is to set a transfer state for each entry (step 420).
  • Transfer states are either yes (copy or replace), no (no action) or partial (merge).
  • the parenthetical expression after each transfer state refers to the action selected in step 415.
  • the backup state of each entry is then set for each item in view of the backup strategy determined during the development of the relocation plan (step 430).
  • a review level is selected for each entry, which sets a flag for the user during the procedure of reviewing the finalized relocation plan (step 435).
  • Review levels include, for example, none (no review needed), low (review is optional), medium (review is recommended), high (review is required). Examples of how review levels can be set are: no review would be selected when a item on the source machine has no counterpart on the target machine, a high review level would be selected if the date assigned to a item is illegal, e.g., the creation date is later than the date modified.
  • the final substep in the analyzing of an entry is the generation of a plain language explanation of the action to be taken with respect to the entry (step 440).
  • the relocation program possesses a finalized relocation plan including a specific storage capacity requirement on the target computer.
  • the relocation program checks the available space on the target computer to determine if the available space is sufficient (step 455). If the space is insufficient, the relocation program starts a program to aid in allocating enough space on the target computer to perform the relocation (step 470). After determining that sufficient space is available, the relocation program determines whether the relocation plan has been accepted (step 460). If major issues have arisen during the finalization process or if the user has chosen to review the finalized relocation plan, then the relocation plan is not accepted and the user reviews the relocation program and make changes to the relocation settings for selected entries (step 475). The relocation program then performs the relocation plan.
  • Fig. 6 shows steps in the presently preferred implementation of a process of performing the relocation plan finalized in the process of Fig. 5.
  • the first step in relocation of each entry in the source machine item list is to separate it into a first category if it is a directory or a second category if it is a file, menu, or setting file (step 600). If the entry is a directory, the relocation program next reviews the action to be taken with respect to that item (step 675). If the action is "copy”, a new directory is created on the target machine corresponding to the directory on the source machine (step 680). If the action is "no action", no action is taken with respect to that entry. The transfer log is then updated with a notation as to the action taken, wherein "no action” is an action (step 690).
  • the relocation program next determines the action set with respect to that entry (step 605). If the action is "replace” or "merge”, the relocation program determines whether the data corresponding to the entry is to be transferred (step 610). If the data is to be transferred, a backup of the original data to be replaced or merged is made on the target machine (step 615). The relocation program next separates the entry into one of two categories based on the action set for that entry (step 625). If the data corresponding to the entry is to be replaced onto the target machine, the data is placed in a staging area on the target machine (step 635).
  • the two sets of data are merged and placed in a staging area on the target machine (step 630).
  • the relocation program next determines whether the relocation or merge is to be deferred till reboot (step 645). If the relocation or merge is to be deferred, the data remains in the staging area till reboot (step 650). If the relocation or merge is not to be deferred, the data is moved to its final location within memory on the target machine (step 655). The relocation or merge actions taken are then added to an undo scripts file (step 685) and the transfer log (step 690).
  • the relocation program determines whether a request had been made to make a backup of the item on the source machine (step 640). If no backup was requested then the actions taken with respect to the entry are added to the transfer log (step 690). If a backup was requested, the backup is made (step 660) and the actions taken are added to the undo scripts file (step 685) and the transfer log (step 690). If the action determined at step 605 is "copy", then a copy of the data corresponding to the entry is created on the target machine (step 665). The actions taken with respect to that entry are then added to the undo scripts file (step 685) and the transfer log (step 690).
  • Fig. 7a shows steps in the presently preferred implementation of a process for reviewing the relocation plan carried out in the relocation process of Fig. 6.
  • the relocation program analyzes the transfer log (step 700) and creates a relocation process report (step 710).
  • the relocation process report includes information about any problems that occurred during the relocation process along with instructions for the user to resolve those problems. Problems may include communications errors, target disk write errors and situations where the item to be transferred was busy on the source. If no significant problems arose, the report need not be displayed to the user.
  • the next step in the relocation process is to reboot the target machine (step 720). The reboot permits the data corresponding to entries that could not be replaced or merged during the relocation process to be transferred from the staging area into their final storage locations.
  • a second relocation process report is then created (step 730).
  • Fig. 7(b) shows exemplary steps in a method of generating a process report in accordance with the invention.
  • the relocation program starts a process report generating program (step 740).
  • the process report generating program determines if any significant problems arose during the relocation (step 745). If no significant problems occurred, the program displays a "success" message to the user (step 750). The program then queries the user as to whether they would like the program to prepare a report of the transfer process (step 755). If no report is requested, the process report generating program is exited (step 790). If significant problems were found at step 745, the program prepares instructions for resolving the problems (step 770). If a report was requested in step 755 or after the preparation of problem resolution instructions at step 770, the process report generating program generates a report and displays it to the user (step 775). The report will include instructions for resolving problems if applicable.
  • the user is given the option of customizing the report (step 780). If the user chooses to customize the report, the user is given a selection of options for filtering unwanted data out of the report (step 760). The user, for example, is given the option of selecting a list of errors that occurred during the process, a list of replaced items, a list of created items and a list of items that were not transferred from the source to the destination computer. The choices are organized by directory.
  • a query is displayed to the user asking whether the report should be saved (785). If the user chooses to save the report, the report is saved to disk (step 765). After the report is saved or if the user chooses not to save the report, the process report generating program is exited (step 790).
  • Fig. 8 shows exemplary steps in a process of undoing a relocation process.
  • the first step in undoing the relocation process is to restart the target computer and the relocation program (step 800).
  • the user selects the undo function from the relocation program (step 810).
  • the relocation program deletes each item created on the target computer, and restores each replaced and merged item by replacing that item with the corresponding backup item previously stored (step 820). Any problems that arise during the undo process can be listed in a log of the undo function.
  • the user restarts the computer, which is now in returned to its original state (step 830).

Abstract

A method and apparatus for relocating application programs, settings, menus, files and documents from a source computer to a target computer. The method and apparatus function properly regardless of whether the source and target computers have the same hardware or operating system. The method includes scanning the source and target machines for all applications programs, settings, menus, files, and documents in order to create a relocation strategy. The relocation strategy is created in view of pre-programmed selection rules or selection rules created by the user. The strategy is then implemented by copying, replacing or merging data from the source machine to the target machine.

Description

APPARATUS AND METHOD FOR TRANSFERRING INFORMATION BETWEEN PLATFORMS BACKGROUND OF THE INVENTION The present application is a continuation of U.S. provisional patent application Ser. No. 60/134,224, filed May 14, 1999, and U.S. patent application Ser. No. 09/378,999, filed August 23, 1999.
A. Field of the Invention
The present invention relates to an apparatus and method for intelligently and accurately relocating applications, settings, menus, and data files from a source machine to a target machine.
B. Description of the Prior Art
For various reasons, computer users have found it necessary to move from one computer system to another. The most common reasons for attempting such a move is the purchase of a new computer. Regardless of the reason for the move, the user is likely to want to bring a great deal of the information stored on the old computer to the new one. That information would include, at least, many of the documents created during the user's tenure on the old computer.
One method of moving documents from computer to computer involves saving the documents on a diskette at a source computer and physically moving the diskette to the target computer for saving thereon. Even if the user were to select only important documents for the move, the selected files might not fit on the diskette. This process, therefore, would become tedious if not impracticable for a user lacking sufficient experience in "disk-spanning." Further, as the number of files to be moved increases so does the difficulty in completing the process. A second method for relocating the files from a source to target computer utilizes a tape backup unit or other high capacity removable storage device in place of the diskette of the first example. The problem of large file size and some of the complexity of the move noted with respect to the first method is obviated through the use of such a storage device. This method, however, requires that both machines have compatible backup units installed. A third method for relocating files involves the use of a file transfer program. Examples of such programs include pcAnywhere32, LapLink, and FastMove! For machines connected to a network, these programs can be used to electronically transfer files from one computer to another. All three of these approaches may cope with the relatively simple problem of transferring data files from computer to computer, however, most users want not only to transfer selected data files, but also programs, settings and menus. It would be difficult if not impossible for the average user to transfer these types of files using any of the above methods. As an example of the problems that would result from trying to use one of the above file transfer schemes to relocate these file types, were a user to attempt to transfer an application directory from a source computer to a target computer, the applications would not be found anywhere in the Windows Start Menu or on the desktop. As these are the locations from which a user would attempt to start the application, the data would exist on the computer but remain functionally unusable. Further, were the user to locate the application, there is little likelihood that it would run. This inability to function properly is due to the reliance of most applications on a number of shared system files called Dynamic Linked Libraries (dlls). While the transfer method may have relocated the application file from the one computer to another, any number of files necessary for the proper functioning of the program could have been left behind on the old computer.
Further, the customizations and settings that were added to each application over time by the user would also likely be left behind during the transfer. While this would not stop an application from running, the expense in time and effort in re- entering, for example, Internet and e-mail settings, re-registering a user's name, address, telephone number, product id/software key, etc., would again render the use of the above file transfer methods undesirable.
Another technique for relocating files from one computer to another involves the physical relocation of the hard disk drive from the source computer to the target computer. The older drive, however, is likely to possess a slower access time and diminished storage capacity relative to the drive of the newer computer. Further, the older computer may not have lost all usefulness, as it might be kept as a backup computer or transferred to another user.
A final prior art solution to the file relocation problem involves the use of programs that are designed to attempt to indiscriminately copy absolutely every file from the old system to the new one. Most of the conventional hard disk copying methods are unable to produce a copy of every file on the drive, as several critical files resist copying because they are in use. Further one or more of the files that are copied to the target system may leave that system in an unstable state. Examples of programs that copy/duplicate entire disk drives from one machine to another bit for bit include Drive Image Pro, DiskClone, DriveCopy and GHOST.
The hard drive duplication programs operate well, however, if and only if the machines are nearly identical. The indiscriminate copying that is utilized by the duplication programs will result in the duplicated operating system having already been configured to function with the hardware of the source computer. The programs of the target computer, therefore, will fail to recognize the hardware in the target machine. The user would then have to go through the laborious process of configuring the programs on the target computer to accept the new hardware. Worse, the differences between the computer programs may result in the halting of the target computer requiring re-installation on the target computer.
As noted above, the optimal use of disk duplication requires that the source and target computer be nearly identical. The most likely reason for the user to move from one computer to another, however, is that the user has decided to upgrade to a newer/faster machine. Specifically, the older computer may have been inadequate to support the new hardware features that became available following its purchase, such as a universal serial bus (USB), digital video disk (DVD), etc. Further, the newer system may have come equipped with newer versions of programs such as an upgraded operating system. By indiscriminately copying all of the programs on the source computer to the target computer, the user would in effect be rendering useless much that he or she would like to have kept on the target machine.
SUMMARY OF THE INVENTION The objects of the invention are to provide an efficient procedure for permitting a user to relocate all application programs, settings, menus, files and documents from a source machine to a target machine.
To achieve the objects and in accordance with the purpose of the invention, as embodied and broadly described herein, the invention comprises a computer program for performing a file transfer between a source computer and a target computer. The program performs a method comprising, aiding a user in completing a connection between the source computer and target computer, comparing stored information from the source computer to stored information from the target computer for selecting a subset of the information for transfer from the source computer to the target computer, and transferring the selected information from the source computer to the target computer.
Additional objects and advantages of the invention will be set forth in part in the description which follows, and in part will be obvious from the description, or may be learned by practice of the invention. The objects and advantages of the invention will be realized and attained by means of the elements and combinations particularly pointed out in the appended claims.
It is to be understood that both the foregoing general description and the following detailed description are exemplary and explanatory only and are not restrictive of the invention, as claimed.
The accompanying drawings, which are incorporated in and constitute a part of this specification, illustrate one embodiment of the invention and together with the description, serve to explain the principles of the invention.
BRIEF DESCRIPTION OF THE DRAWINGS Fig. 1 is a flowchart of an overview of exemplary steps in a first embodiment of a file relocation process. Fig. 2 is a flowchart of an overview of exemplary steps in a second embodiment of a file relocation process.
Fig. 3 is a flowchart of exemplary steps in a method of establishing a connection between a source and target machine. Fig. 4 is a flowchart of exemplary steps in a method of developing a relocation plan.
Fig. 5 is a flowchart of exemplary steps in a method of finalizing a relocation plan.
Fig. 6 is a flowchart of exemplary steps in a method of relocating items. Fig. 7a is a flowchart of exemplary steps in a method of reviewing the relocation procedure.
Fig. 7b is a flowchart of exemplary steps in a method of producing a report.
Fig. 8 is a flowchart of exemplary steps in a method of performing an undo after a relocation procedure. DESCRIPTION OF THE PREFERRED EMBODIMENT
Reference will now be made in detail to the present preferred embodiment of the invention, an example of which is illustrated in the accompanying drawings. Wherever possible, the same reference numbers will be used throughout the drawings to refer to the same or like parts or steps. Fig. 1 shows exemplary steps in a relocation process in accordance with the present invention. The relocation process is performed by a relocation program. In a first arrangement, the relocation process can be controlled by a single relocation program stored on either the target or source machines. Alternatively, the relocation program can be stored on both target and source machines, wherein the programs perform in concert to complete the relocation process. This is called the dual control format. In another alternative arrangement, sub-programs, each individually designed to operate either on the target or source machine, act together to perform the relocation process. This is called the sub-program format.
The first step in the relocation process of Fig. 1 is to start the relocation program (step 10). In the dual control format this step requires starting the program on both of the machines. In the sub-program format this step requires starting each of the sub-programs on its designated machine.
The second step in the relocation process is to establish a connection between the source and target machines (step 20). The connection is used to transfer electronic information from the source computer to the target computer. Exemplary connection types include a local area network (LAN) or wide area network (e.g., the Internet) to which both computers are connected. Alternatively, the two computers can be directly connected via a serial port, parallel port, or universal serial bus (USB). In these connection types, a cable is used to physically connect the two machines. Methods of making these connections are well known in the art and will not be described here in detail. The above listed connection types are considered exemplary in nature, other known methods of transferring information between platforms are not mentioned individually, but are considered to be within the scope of the invention. The third step in the relocation process is to determine the items stored on the source and target machines (step 30). Such a determination can be performed by scanning the hard drives of both the source and target machines. In the single control format, the relocation program on either the source or target machine directly scans its own hard drive to create a list of the items stored thereon and scans the hard drive of the other computer via the connection to create a list of the programs stored thereon. In dual control and sub-program control formats, the relocation program or sub-program stored on each machine performs a scan of the hard drive of that machine to create a list of the items stored thereon. The resulting list of items includes such information about each item as its name, existence, version number, date, size, and content.
The fourth step in the relocation process is to select the information to be relocated from the source machine to the target machine (step 40). This step is explained here as a single selection step, however, preferably, this step includes two sub-steps, a first substep of developing a relocation plan and second substep of finalizing the relocation plan. The term information is intended to include not only individual items, but also selected data stored within those items. The list of items on the source machine is reviewed (the review process is discussed below) to set an action to be taken with respect to that item. The possible actions include no action, copy, replace, and merge. No action is selected when the item on the source machine is not to be relocated to the target machine. Copy is selected when a copy of the item is to be relocated from the source machine to the target machine. Replace is selected when the item is to be written over a preexisting version of the item on the target machine. Merge is selected when it is determined that a subset of the information within a item is to replace its counterpart information within a item on the target machine while leaving some of the information in that item unchanged.
The method by which it is determined which action is to be taken with respect to a specific item can be performed in a number of alternative arrangements. The first form of information selection is called a rules driven process. In this process, the relocation program applies selection rules to each item. A selection rule is defined as a pre-programmed logical rule used to compare specific characteristics stored in the list of items on each machine. An exemplary use of a selection rule resulting in the copy function is: if item A exists on source and not on target then set item to "copy." An exemplary use of a selection rule resulting in no action is: if version number of item A on source is lower than version number of item A on target, then set item to "no action." An exemplary use of a selection rule resulting in the replace function is: if version number of item A on source is higher than version number of item A on target, then set item to "replace." For items having no version number, the date of the item can be substituted in the comparison for the version number. For items having neither a date nor a version number a default selection rule can be used. An example of a default selection rule is: select the item from the machine having the newer operating system.
The merge function discussed above is a special function that parses out data within certain kinds of items, wherein some of the data is replaced onto the target machine and some is left unchanged. The merge function is used for menu and settings files on a source machine having counterpart files on the target machine. The determination of which data to transfer and which to leave unchanged from a setting file is made in view of whether the setting relates to hardware settings, user specific settings, or software specific settings. Hardware settings such as the designation of the modem, printer, monitor, etc., are unlikely to remain the same on the target machine as on the source machine. Such settings, therefore, will not generally be transferred during the relocation process. User specific settings such as Internet bookmarks, e-mail settings, name, address, telephone number, however, will be merged into the counterpart files on the target machine during the relocation process. A third type of settings information is software specific, such as the product ID of an application. This type of setting will be transferred only if the application is also transferred. If the application on the target machine is to be retained, then no action is taken with respect to software specific information.
A second type of selection process is called the database driven selection process. Here, the relocation program is pre-programmed to include a database of actions to be taken with respect to individual known applications. The database is the result of experimentation by the programmers of the relocation program to select preferred actions to be taken with respect to a specific versions of each application.
Finally, a third type of selection process is called the repository selection process. This process operates using both rules and a repository database and is the presently preferred embodiment of the selection process. For this selection process, rules are applied to each application, setting, menu, and data file. For those that are exceptions or special cases (the determination that a specific program is an exception or a special case is made by having previously performed a relocation of that version of the program and analyzing the outcome), an entry is made in a pre-programmed repository database. Entries in the repository database preempt the usual rule result to perform a different action with respect to the specified information. Examples of such a repository database entry are: do not transfer "swap" file, or if transferring application A, items X, Y, and Z must be transferred regardless of the version of items X, Y, and Z. Because new versions of programs are continually released, it is necessary that the repository database information discussed above can be updated using extension files. Further, rules can be altered and updated by adding scripts to the relocation program. Both forms of updates can preferably be performed using the same extension file.
In an alternative arrangement, a version of a repository database called an automation file can be created to automatically perform a specific file transfer. This database might include entries relative to a specific application or group of applications and rules for use with that application or group of applications. Specifically, the database might include entries requiring the transfer of application A along with files X, Y, and Z. An exemplary selection rule for use with such an automation file is: transfer all data files ".aaa" for application A.
The final step in the relocation process is to relocate the selected information from the source to the target machine (step 50). During this step, the specific function selected with respect to each item in selection step 40 is performed.
Because some items set to be replaced on the target machine will be in use on the target machine, they cannot be replaced during this step. Instead, a copy of the item is placed in a "staging area," until reboot, whereupon the process is completed.
Fig. 2 shows a second embodiment of the invention for use where a connection between the source and target machines cannot be made. In this arrangement, a storage device is substituted for the electronic connection between the computers. Exemplary storage devices for use as the external storage device are a tape drive or a zip drive. The first step in the process here requires starting the relocation program the source machine (step 10). Because the source and target machines are not directly connected, a migration application file (MAF) stored on an external storage device takes the place of the connection. Here, the relocation program on the source machine scans the drives of the source machine to create a list of the items on the source machine (step 60). The source machine next performs the selection step of determining which information is to be relocated from the source to the external storage location (step 70). Because this step is performed without knowledge of the identity of the information stored on the target machine, this selection process is less selective than that performed when the machines can be connected, i.e., no comparison between item versions on the source and target drives can be performed. Instead, all of the information stored on the source drive, except for the subset of information that is predefined in the repository database to never be transferred, is copied to the MAF.
The next step in the relocation process is the creation of a MAF by storing the selected information on the storage device attached to the source machine (step 80). In order to conserve space on the storage device, the MAF can take the form of a compressed file on the storage device. The storage device is then connected to the target machine (step 90).
The next step in the relocation process is to select the subset of the information from the MAF to be relocated to the target machine (step 100). The target machine, now connected to the external storage device, performs a selection step as if the external storage device were a source machine. The applications, settings, menus, and data files stored as the MAF on the external storage device are selected for no action to be taken, or to be copied, replaced, or merged onto the target machine. The final step in the relocation process is to relocate the selected information from the external storage device to the target machine (step 110).
In the preferred arrangement of the relocation program of the present invention, the relocation program can perform the relocation processes of Figs. 1 and 2. If, for example, it is determined that a connection between the machines cannot be completed as required by the first relocation process, then the relocation program could perform instead the second relocation process.
An important consideration to be taken into account when performing a relocation is what to do with the original items on the target machine that are set to be replaced. In accordance with another aspect of the invention, therefore, a backup is made of each item set to be replaced and merged during the relocation process. Further, a relocation log can be created detailing each step in the relocation process. A relocation program user would then be given the option of undoing the entire process at any point during the relocation by using an undo program. Upon selection of the "failsafe undo" command, the relocation program would undo that portion of the relocation process that had been performed to that point by erasing each of the copied items and replacing the merged and replaced items with backup items.
Another consideration is limitations on storage capacity on the target machine. In order to ensure the proper completion of the relocation process in accordance with the present invention, the storage device of the target machine must have adequate capacity to store all of the copied and replaced items along with any items set for backup. Therefore, after the determination of the relocation plan in selection step 40, preferably, the relocation program determines the necessary free capacity on the target machine for completion of the relocation process. Should the relocation program determine that the free capacity on the target machine is inadequate to complete the procedure, a program designed to aid the user in allocating more free space on the target hard drive, such as a "disk space" wizard, could be initiated by the relocation program.
In addition to disk space problems, it may occur that the source machine contains multiple hard drives D: and E: while the destination machine possesses only a single hard drive C:. Four solutions to this problem may be offered by a program called "Drive Letter" wizard. A first solution is to partition the single drive C: on the target machine into three drives C:, D: and E:, and thereafter relocate the items from the D: and E: drives on the source machine to the corresponding D: and E: sector of the C: drive on the target machine. A second solution to differing drive numbers is to create subfolders on the target drive C:, for example C:\DRIVE_D and C:\DRIVE_E for storing the information from drives D: and E: respectively. The relocation program would then automatically change settings, menus, desktop icons, etc. to refer to the new locations. A third solution to the problem of differing drive numbers is to relocate all of the selected information from the source drives to the single destination drive of the target machine. This may result in two items to be transferred to the single C: drive having identical names. This can be solved by conflict resolution between the two items, e.g., by renaming one of the items to be stored.
A final solution is to permit the user to de-select one of the multiple drives from the source machine for transfer of information to the target machine. This solution would permit, for example, a user to physically transfer one drive from the source to the target machine while electronically transferring the information from the other drive to the target machine using the relocation program.
The invention also envisions that differing amounts of control of the relocation process be given to the user. For the casual or unsophisticated user, the relocation program would perform the relocation process by minimizing the input necessary from the user. Problems such as inadequate storage capacity would require input from the user, however, the process itself could be performed with little required of the user. This form of relocation program is termed a go button relocation program. Specifically, many consumers do not have the requisite knowledge to make informed decisions about how best to selectively relocate programs, and so providing the opportunity to alter the decisions made by the relocation program would result in frustration or inefficient relocation procedures. Instead, in this arrangement, the relocation makes the best choice and performs the relocation program automatically, unless problems that it is unable to resolve on its own arise.
Alternatively, for more knowledgeable users such as information technology (IT) professionals, the relocation program could display the determined relocation plan to the user for review of the plan, whereby the user could modify the plan by adding or removing items to the list of those to be relocated. The display of information could take the form of a tree, whereby after having scanned the available information on the source machine, the relocation produces a item list in the form of a tree from which individual programs or groups of programs could be selected for relocation by clicking on a checkbox associated therewith. Alternatively a batch command could be issued by the user to selectively alter the relocation process.
In a first arrangement the different levels of review capability given to the user could be provided by a single program, whereby the user would be given the option of choosing the review level they desire. Alternatively a separate "pro" version of the program can be produced having a higher level of functionality for those desiring a greater amount of control of the process.
Figs.3-6 show the presently preferred implementation of a relocation process in accordance with the present invention.
Fig. 3 shows exemplary steps in the establishment of a connection between the source and target computers. The first step in establishing a connection is to start the relocation program on the source computer (step 200). Upon startup, the relocation program will produce an interface screen in order to query the user regarding certain necessary information such as whether the computer is the source or target computer (step 205). Next, the user starts the relocation program on the target computer (step 210). The relocation program then determines the types of connections available (step 215). The relocation program then displays the available connection types (step 220) and defaults to the most appropriate one (step 225). The user is given the option to override the selected connection type (step 230). Next, the relocation program attempts to establish a connection using each selected protocol. The order of preference of connection types can be either pre-programmed or inputted by the user at connection selection step 220 (step 240). The relocation program next determines whether a connection was successfully made (step 245). If the connection was made, the program exits connection step 10. If no connection was made, the program starts a program called a Help Wizard to aid the user in determining why the connection was unsuccessful. The Help Wizard reviews possible problems with the connection and returns the program to step 220 to repeat the connection attempt (step 240). Figs. 4 and 5 show steps in a preferred embodiment for producing a relocation plan (step 30 of Figs. 1 and 2). Fig. 4 shows steps in a preferred embodiment of a first sub-step of developing a relocation plan in the production of a relocation plan. Fig. 5 shows steps in a preferred embodiment of a second sub- step of finalizing the relocation plan in the production of a relocation plan.
The first step in the development of a relocation plan is a pre-scan of the source and target machines performed by the relocation program. In conducting the pre-scan of the target computer, the relocation program determines the number of disk drives on the source and target computers, the amount of disk space available on the target computer and the volume of stored data on the source computer (step 300). If incompatibility exists between the number of drives on the source computer and the number of drives on the target computer, the "Drive Letter Wizard" discussed above is initiated. The relocation program next determines whetherthere is adequate disk space available on the target computer (step 305). If the available disk space on the target computer is inadequate, the relocation program starts a program called a Disk Space Wizard to aid the user in allocating space for the relocated items (step 310).
If the available disk space is adequate, the relocation program proceeds to a determination of whether the relocation is to be partial or complete (step 315). The computer chooses partial or complete relocation depending on the relationship between operating systems. An example of a partial relocation would be to select all settings and documents on the source for transfer, but not transfer the applications and menus. If there are major incompatibilities between the operating systems on the source and target computers, the relocation program will allow only a partial relocation. If there are no major incompatibilities, the relocation program will suggest a complete relocation, but will permit the user to select a partial relocation. The incompatibility of operating systems is a predefined characteristic stored within the database repository in the relocation program based on tests performed on relocations from one operating system to another. The next step in the development of a relocation plan is to determine a strategy for resolving conflicts between applications on both source and target computer (step 320). Four options are provided for resolving the conflicts: assume that the applications on the target machine are most up-to-date; assume that the applications on the source machine are most up-to-date; make no assumptions but instead flag all items that are dubious; and most appropriate. The present preferred conflict rule is the most appropriate rule, which selects the appropriate item based on version or date when possible. In situations where the program cannot determine using version or date, for example if that information is missing or incorrect, the relocation program will assume that the version of the item on the target machine is to be used.
The next step in the relocation plan is to determine a backup strategy (step 325). The user is given the option to select one or more of a fail-safe undo option, a delayed replacement option and a conserve source items option. The fail-safe undo option produces a backup of the items to be replaced on the target drive. The delayed replacement option delays the replacement of any items on the target machine until reboot. The conserve source items option produces a backup of the items on the source machine that were not selected for relocation from the source machine to the target machine by the relocation process. Next, the results of the general relocation plan including the results of relocation scope determination step 315, conflict resolution determination step 320 and backup strategy determination step 325 are displayed for review by the user (step 330). The user is given the option of accepting the general relocation plan or overriding the plan (step 335). If the plan is not accepted, the relocation program gives the user the ability to alter the plan (340). The program then loops back to step 330. If the plan is accepted, the program proceeds to the finalization of the relocation plan.
Fig. 5 shows exemplary steps in the finalization of a relocation plan. The first step in the finalization of the relocation plan is to access the information derived from the pre-scan of the source computer (step 400) and the target computer (step 405) from a file containing that information as a list of entries.
The relocation program then individually analyzes information pertaining to each entry (step 410). The step of analyzing each entry includes a number of substeps. The first substep in analyzing an entry is determining the action to be taken with respect to that entry (step 415). The information about each entry will include, for example, its existence, version, date, size, and content. By reviewing the information, the relocation program determines, for example, that a specific file type has been flagged in the repository database as being a taboo system file or directory, such that the item should not be relocated to the target computer. The relocation program then sets an action to be taken for each item among the selected actions of: no action, copy/create directory, replace, and merge. No action might be selected, for example, for a item on the source computer having an older version than that on the target computer. Copy/create directory might be selected, for example, for an application on the source computer where the target computer does not have a version of that application. Replace might be selected, for example, for an application having a newer version on the source computer than the target computer. Merge might be selected, for example, for a directory or setting, wherein some of the data stored in the directory or setting is to be transferred and other data is to remain unchanged.
As noted above, the relocation program includes a repository database of actions to be taken with respect to specific predefined programs. In a first arrangement, each item is compared against the list of items in the repository database to determine if a predefined action has been set with respect to that item. If an action has been set, then no rule is applied to that item. Alternatively, following the application of a rule to a specific item, that item is compared against in the repository database to determine if a predefined action has been set with respect to that item. If an action has been set, the action from the repository database overrides the outcome of the selection rule. The next substep in the step of analyzing each entry is to set a transfer state for each entry (step 420). Transfer states are either yes (copy or replace), no (no action) or partial (merge). The parenthetical expression after each transfer state refers to the action selected in step 415. The backup state of each entry is then set for each item in view of the backup strategy determined during the development of the relocation plan (step 430).
Next, a review level is selected for each entry, which sets a flag for the user during the procedure of reviewing the finalized relocation plan (step 435). Review levels include, for example, none (no review needed), low (review is optional), medium (review is recommended), high (review is required). Examples of how review levels can be set are: no review would be selected when a item on the source machine has no counterpart on the target machine, a high review level would be selected if the date assigned to a item is illegal, e.g., the creation date is later than the date modified. The final substep in the analyzing of an entry is the generation of a plain language explanation of the action to be taken with respect to the entry (step 440).
An example explanation is "Target file version newer than Source file version...."
Once analyzing step 410 has been performed on each entry (step 450), the relocation program possesses a finalized relocation plan including a specific storage capacity requirement on the target computer. The relocation program checks the available space on the target computer to determine if the available space is sufficient (step 455). If the space is insufficient, the relocation program starts a program to aid in allocating enough space on the target computer to perform the relocation (step 470). After determining that sufficient space is available, the relocation program determines whether the relocation plan has been accepted (step 460). If major issues have arisen during the finalization process or if the user has chosen to review the finalized relocation plan, then the relocation plan is not accepted and the user reviews the relocation program and make changes to the relocation settings for selected entries (step 475). The relocation program then performs the relocation plan. Fig. 6 shows steps in the presently preferred implementation of a process of performing the relocation plan finalized in the process of Fig. 5. The first step in relocation of each entry in the source machine item list is to separate it into a first category if it is a directory or a second category if it is a file, menu, or setting file (step 600). If the entry is a directory, the relocation program next reviews the action to be taken with respect to that item (step 675). If the action is "copy", a new directory is created on the target machine corresponding to the directory on the source machine (step 680). If the action is "no action", no action is taken with respect to that entry. The transfer log is then updated with a notation as to the action taken, wherein "no action" is an action (step 690).
If the entry is a file, menu or setting, the relocation program next determines the action set with respect to that entry (step 605). If the action is "replace" or "merge", the relocation program determines whether the data corresponding to the entry is to be transferred (step 610). If the data is to be transferred, a backup of the original data to be replaced or merged is made on the target machine (step 615). The relocation program next separates the entry into one of two categories based on the action set for that entry (step 625). If the data corresponding to the entry is to be replaced onto the target machine, the data is placed in a staging area on the target machine (step 635). If the data corresponding to the entry is to be merged with corresponding data on the target machine, the two sets of data are merged and placed in a staging area on the target machine (step 630). The relocation program next determines whether the relocation or merge is to be deferred till reboot (step 645). If the relocation or merge is to be deferred, the data remains in the staging area till reboot (step 650). If the relocation or merge is not to be deferred, the data is moved to its final location within memory on the target machine (step 655). The relocation or merge actions taken are then added to an undo scripts file (step 685) and the transfer log (step 690).
If the determination at step 610 was that the entry tagged for relocation or merge is not to be transferred, the relocation program determines whether a request had been made to make a backup of the item on the source machine (step 640). If no backup was requested then the actions taken with respect to the entry are added to the transfer log (step 690). If a backup was requested, the backup is made (step 660) and the actions taken are added to the undo scripts file (step 685) and the transfer log (step 690). If the action determined at step 605 is "copy", then a copy of the data corresponding to the entry is created on the target machine (step 665). The actions taken with respect to that entry are then added to the undo scripts file (step 685) and the transfer log (step 690).
The above relocation steps are repeated until the relocation program determines that all entries have been processed (step 695).
Fig. 7a shows steps in the presently preferred implementation of a process for reviewing the relocation plan carried out in the relocation process of Fig. 6. After all of the entries have been processed, the relocation program analyzes the transfer log (step 700) and creates a relocation process report (step 710). The relocation process report includes information about any problems that occurred during the relocation process along with instructions for the user to resolve those problems. Problems may include communications errors, target disk write errors and situations where the item to be transferred was busy on the source. If no significant problems arose, the report need not be displayed to the user. The next step in the relocation process is to reboot the target machine (step 720). The reboot permits the data corresponding to entries that could not be replaced or merged during the relocation process to be transferred from the staging area into their final storage locations. A second relocation process report is then created (step 730).
Fig. 7(b) shows exemplary steps in a method of generating a process report in accordance with the invention. In the first step of generating a process report, the relocation program starts a process report generating program (step 740). The process report generating program determines if any significant problems arose during the relocation (step 745). If no significant problems occurred, the program displays a "success" message to the user (step 750). The program then queries the user as to whether they would like the program to prepare a report of the transfer process (step 755). If no report is requested, the process report generating program is exited (step 790). If significant problems were found at step 745, the program prepares instructions for resolving the problems (step 770). If a report was requested in step 755 or after the preparation of problem resolution instructions at step 770, the process report generating program generates a report and displays it to the user (step 775). The report will include instructions for resolving problems if applicable.
After the report has been displayed, the user is given the option of customizing the report (step 780). If the user chooses to customize the report, the user is given a selection of options for filtering unwanted data out of the report (step 760). The user, for example, is given the option of selecting a list of errors that occurred during the process, a list of replaced items, a list of created items and a list of items that were not transferred from the source to the destination computer. The choices are organized by directory. Once the user has finished selecting the changes to the report, the process report generating program returns to step 775 to generate a new report.
Once the user is satisfied with the form of the report, i.e., the user chooses not to customize the report at step 780, a query is displayed to the user asking whether the report should be saved (785). If the user chooses to save the report, the report is saved to disk (step 765). After the report is saved or if the user chooses not to save the report, the process report generating program is exited (step 790).
During and after the relocation process, the user is given the option of undoing the relocation process. Fig. 8 shows exemplary steps in a process of undoing a relocation process. The first step in undoing the relocation process is to restart the target computer and the relocation program (step 800). The user then selects the undo function from the relocation program (step 810). Using the undo log as the plan for the undo function, the relocation program deletes each item created on the target computer, and restores each replaced and merged item by replacing that item with the corresponding backup item previously stored (step 820). Any problems that arise during the undo process can be listed in a log of the undo function. Finally, the user restarts the computer, which is now in returned to its original state (step 830).
It will be apparent to those skilled in the art that various modifications and variations can be made in the field of file, application, settings and menu relocation of the present invention without departing from the scope or spirit of the invention.
Other embodiments of the invention will be apparent to those skilled in the art from consideration of the specification and practice of the invention disclosed herein. It is intended that the specification and examples be considered as exemplary only, with a true scope and spirit of the invention being indicated by the following claims.

Claims

WHAT IS CLAIMED IS:
1. A computer implemented method for performing transferring stored items from a source computer having a list of items stored on the source computer to a target computer comprising: establishing a connection between the source computer and the target computer; comparing the source list to information stored on the target computer; and transferring selected information from the source computer to the target computer based on the comparison.
2. The computer implemented method of step 1 , wherein the information to be transferred includes applications, files, menus, directories, and settings.
3. The computer implemented method of step 1 , wherein an item on the source computer not having a corresponding item on the target computer is copied from the source to the target computer.
4. A computer program for performing an information transfer between a source computer and a target computer, the source and target computers being connected together, the program performing a method comprising: selecting information for transfer from the source computer to the target computer by comparing stored information from the source computer to stored information from the target computer; and transferring the selected information from the source computer to the target computer.
5. The program of claim 4, wherein the step of comparing includes comparing a version number of an item stored on the source computer to a version number of a corresponding item stored on the target computer.
6. The program of claim 4, wherein the step of comparing includes determining if an item stored on the source computer is referenced in a repository database stored on the target computer, wherein the repository database specifies actions to be taken with respect to referenced items.
7. The program of claim 4, wherein the step of comparing includes: creating a list of items stored on the source computer, the source list including entries relating to properties of each item stored on the source computer; and selecting an action to be taken with respect to each entry based on whether the entry is referenced in a repository database.
8. The program of claim 7, wherein the step of selecting an action includes comparing a version number of an entry when the entry is not referenced in the repository database.
9. The program of claim 7, wherein the step of selecting an action includes comparing a date of an entry when the entry is not referenced in the repository database.
10. The program of claim 7, wherein the step of selecting an action includes selecting an action for an entry from the repository database when the entry is referenced in the repository database.
11. The program of claim 4, wherein the step of comparing includes: a) creating a list of items stored on the source computer, the source list including entries relating to properties of each item stored on the source computer; b) creating a list of items stored on the target computer, the target list including entries relating to properties of each item stored on the target computer; c) selecting an action to be taken with respect to an entry in the migration list based on a comparison of the entry against the target list; d) determining if the entry is referenced in a repository database; e) changing the selected action based on information stored in the repository database if the entry is referenced in the repository database; f) repeating steps c) through e) for each entry in the source list.
12. The program of claim 4, wherein the step of comparing includes comparing a date of an item stored on the source computer to a date of a corresponding item stored on the target computer.
13. The program of claim 4, wherein the step of comparing includes selecting items to be copied from the source computer to the target computer, selecting items on the target computer to be replaced with items from the source computer, and selecting items from the target computer to be merged with items from the source computer.
14. The program of claim 13, wherein merging includes replacing user specific settings on the target computer with corresponding user specific settings on the source computer.
15. The program of claim 13, wherein merging includes retaining hardware specific settings on the target computer.
16. The program of claim 13, wherein the program includes, after the step of comparing, a step of creating a backup of items to be replaced or merged on the target machine.
17. The program of claim 14, wherein the program, upon selection of an undo command, uses the created backup items to return the target computer to a pre-transfer state.
18. A computer implemented method for performing a data transfer from a source computer to a target computer comprising: storing information from the source computer as a migration application file on an external storage device; creating a list of items stored in the migration application file; creating a list of items stored on the target computer; comparing the migration application file list to the target list to select a subset of information stored in the migration application file for transfer to the target computer; and transferring the selected information from the migration application file to the target computer.
19. The method of claim 18, wherein the information stored as the migration application file includes all information from the source computer except information that is never transferred from a source computer to a target computer.
20. A computer program for performing a transfer between a source computer and a target computer, the program performing a method comprising: storing information from the source computer as a migration application file on an external storage device; selecting information for transfer from the migration application file to the target computer by comparing stored information from the migration application file to stored information from the target computer; and transferring the selected information from the migration application file to the target computer.
21. The program of claim 20, wherein the step of comparing includes comparing a version number of an item stored in the migration application file to a version number of a corresponding item stored on the target computer.
22. The program of claim 20, wherein the step of comparing includes determining if an item stored in the migration application file is referenced in a repository database stored on the target computer, wherein the repository database specifies actions to be taken with respect to referenced items.
23. The program of claim 20, wherein the step of comparing includes: creating a list of items stored on the source computer, the source list including entries relating to properties of each item stored on the source computer; and selecting an action to be taken with respect to each entry based on whether the entry is referenced in a repository database, wherein the action is selected based on one of a version number or date when the entry is not referenced in the repository database.
24. The program of claim 20, wherein the step of comparing includes: a) creating a list of items stored in the migration application file, the migration list including entries relating to properties of each item stored in the migration application file; b) creating a list of items stored on the target computer, the target list including entries relating to properties of each item stored on the target computer; c) selecting an action to be taken with respect to an entry in the migration list based on a comparison of the entry against the target list; d) determining if the entry is referenced in a repository database; e) modifying the selected action based on information stored in the repository database if the entry is referenced in the repository database; f) repeating steps c) through e) for each entry in the migration list.
25. The program of claim 20, wherein the step of comparing includes comparing a date of an item stored on the source computer to a date of a corresponding item stored on the target computer.
26. The program of claim 20, wherein the step of comparing includes selecting items to be copied from the source computer to the target computer, selecting items on the target computer to be replaced with items from the source computer, and selecting items from the target computer to be merged with items from the source computer.
27. The program of claim 26, wherein merging includes replacing user specific settings on the target computer with corresponding user specific settings on the source computer.
28. The program of claim 26, wherein merging includes retaining hardware specific settings on the target computer.
29. The program of claim 26, wherein the program includes, after the step of comparing, a step of creating a backup of items to be replaced or merged on the target machine.
30. A computer readable medium containing a program for performing an information transfer between a source computer and a target computer, the source and target computers being connected together, the program performing a method comprising: selecting information for transfer from the source computer to the target computer by comparing stored information from the source computer to stored information from the target computer; and transferring the selected information from the source computer to the target computer.
31. The computer readable medium of claim 30, wherein the step of comparing includes: creating a list of items stored on the source computer, the source list including entries relating to properties of each item stored on the source computer; and selecting an action to be taken with respect to each entry based on whether the entry is referenced in a repository database, wherein the action is selected based on one of a version number or date when the entry is not referenced in the repository database.
32. The computer readable medium of claim 31 , wherein the step of comparing includes: a) creating a list of items stored on the source computer, the source list including entries relating to properties of each item stored on the source computer; b) creating a list of items stored on the target computer, the target list including entries relating to properties of each item stored on the target computer; c) selecting an action to be taken with respect to an entry in the migration list based on a comparison of the entry against the target list d) determining if the entry is referenced in a repository database; e) changing the selected action based on information stored in the repository database if the entry is referenced in the repository database; f) repeating steps c) through e) for each entry in the source list.
33. A system for transferring data between computers comprising: a source computer having a plurality of items stored thereon; a target computer having a plurality of items stored thereon; and a relocation program for selecting a subset of the information stored on the source computer to be transferred to the target computer and for transferring the subset of information.
PCT/US2000/013070 1999-05-14 2000-05-12 Apparatus and method for transferring information between platforms WO2000070445A2 (en)

Priority Applications (1)

Application Number Priority Date Filing Date Title
AU48452/00A AU4845200A (en) 1999-05-14 2000-05-12 Apparatus and method for transferring information between platforms

Applications Claiming Priority (4)

Application Number Priority Date Filing Date Title
US13422499P 1999-05-14 1999-05-14
US60/134,224 1999-05-14
US09/378,999 1999-08-23
US09/378,999 US6625622B1 (en) 1999-05-14 1999-08-23 Apparatus and method for transfering information between platforms

Publications (2)

Publication Number Publication Date
WO2000070445A2 true WO2000070445A2 (en) 2000-11-23
WO2000070445A3 WO2000070445A3 (en) 2001-02-01

Family

ID=26832083

Family Applications (1)

Application Number Title Priority Date Filing Date
PCT/US2000/013070 WO2000070445A2 (en) 1999-05-14 2000-05-12 Apparatus and method for transferring information between platforms

Country Status (3)

Country Link
US (1) US6625622B1 (en)
AU (1) AU4845200A (en)
WO (1) WO2000070445A2 (en)

Cited By (4)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US6370646B1 (en) 2000-02-16 2002-04-09 Miramar Systems Method and apparatus for multiplatform migration
WO2002075546A2 (en) * 2001-03-21 2002-09-26 Angele Sebastien Method for saving and restoring all configuration parameters for a computer platform by means of a server
US7356816B2 (en) 2001-02-13 2008-04-08 Computer Associates Think, Inc. Method and apparatus for multiplatform migration
WO2009156577A1 (en) * 2008-06-27 2009-12-30 Nokia Corporation Method, apparatus, and computer program product for personalizing a device

Families Citing this family (48)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US6938058B2 (en) 1999-08-23 2005-08-30 Eisenworld, Inc. Apparatus and method for transferring information between platforms
WO2001053938A1 (en) * 2000-01-23 2001-07-26 Altiris, Inc. Method and system for describing and extracting application information
US7000230B1 (en) 2000-06-21 2006-02-14 Microsoft Corporation Network-based software extensions
US6883168B1 (en) * 2000-06-21 2005-04-19 Microsoft Corporation Methods, systems, architectures and data structures for delivering software via a network
US7325067B1 (en) * 2000-11-27 2008-01-29 Esaya, Inc. Personalized account migration system and method
US7165088B2 (en) * 2001-01-24 2007-01-16 Microsoft Corporation System and method for incremental and reversible data migration and feature deployment
US20030217062A1 (en) 2001-12-18 2003-11-20 Shawn Thomas Method and system for asset transition project management
US6941328B2 (en) * 2002-01-22 2005-09-06 International Business Machines Corporation Copy process substituting compressible bit pattern for any unqualified data objects
US7503042B2 (en) * 2002-03-08 2009-03-10 Microsoft Corporation Non-script based intelligent migration tool capable of migrating software selected by a user, including software for which said migration tool has had no previous knowledge or encounters
US20030188036A1 (en) * 2002-03-22 2003-10-02 Sun Microsystems, Inc. Methods and systems for program migration
JP3966051B2 (en) * 2002-04-16 2007-08-29 株式会社日立製作所 Communication data reduction method and system
US7299422B2 (en) * 2002-05-08 2007-11-20 Migo Software, Inc. System and method for transferring personalization information among computer systems
US20040133441A1 (en) * 2002-09-04 2004-07-08 Jeffrey Brady Method and program for transferring information from an application
US20040128203A1 (en) * 2002-12-26 2004-07-01 Pierre Christa St. Scheme for creating and delivering a new customized computer system with the "personality" of a user's other computer system pre-installed
US7275216B2 (en) 2003-03-24 2007-09-25 Microsoft Corporation System and method for designing electronic forms and hierarchical schemas
US7415672B1 (en) 2003-03-24 2008-08-19 Microsoft Corporation System and method for designing electronic forms
US7913159B2 (en) 2003-03-28 2011-03-22 Microsoft Corporation System and method for real-time validation of structured data files
WO2004097566A2 (en) * 2003-04-24 2004-11-11 Secureinfo Corporation Automated electronic software distribution and management method and system
US7406660B1 (en) 2003-08-01 2008-07-29 Microsoft Corporation Mapping between structured data and a visual surface
US7334187B1 (en) 2003-08-06 2008-02-19 Microsoft Corporation Electronic form aggregation
WO2005020076A1 (en) * 2003-08-21 2005-03-03 Matsushita Electric Industrial Co., Ltd. Data transmission/reception system, data transmission/reception method, and recording/reproduction device
US7617501B2 (en) 2004-07-09 2009-11-10 Quest Software, Inc. Apparatus, system, and method for managing policies on a computer having a foreign operating system
US20060026587A1 (en) * 2004-07-28 2006-02-02 Lemarroy Luis A Systems and methods for operating system migration
US7392423B2 (en) 2004-08-13 2008-06-24 Microsoft Corporation Combined computer backup, disaster recovery and migration in a shared environment
US7634685B2 (en) * 2004-08-13 2009-12-15 Microsoft Corporation Remote computer disaster recovery and migration tool for effective disaster recovery and migration scheme
US8224784B2 (en) * 2004-08-13 2012-07-17 Microsoft Corporation Combined computer disaster recovery and migration tool for effective disaster recovery as well as the backup and migration of user- and system-specific information
US8458692B2 (en) * 2004-09-28 2013-06-04 Dell Products L.P. System and method for data migration integration with information handling system manufacture
US8487879B2 (en) 2004-10-29 2013-07-16 Microsoft Corporation Systems and methods for interacting with a computer through handwriting to a screen
US7937651B2 (en) 2005-01-14 2011-05-03 Microsoft Corporation Structural editing operations for network forms
US8010515B2 (en) 2005-04-15 2011-08-30 Microsoft Corporation Query to an electronic form
US8200975B2 (en) 2005-06-29 2012-06-12 Microsoft Corporation Digital signatures for network forms
US7506005B2 (en) * 2005-07-14 2009-03-17 Microsoft Corporation Moving data from file on storage volume to alternate location to free space
US8006242B2 (en) * 2005-10-31 2011-08-23 Microsoft Corporation Identification of software configuration data
US7900202B2 (en) * 2005-10-31 2011-03-01 Microsoft Corporation Identification of software execution data
US8001459B2 (en) 2005-12-05 2011-08-16 Microsoft Corporation Enabling electronic documents for limited-capability computing devices
US7664786B2 (en) * 2005-12-12 2010-02-16 Electronics And Telecommunications Research Institute Apparatus and method for managing application context
KR100763526B1 (en) * 2005-12-12 2007-10-04 한국전자통신연구원 Device and method for management of application context
US7904949B2 (en) 2005-12-19 2011-03-08 Quest Software, Inc. Apparatus, systems and methods to provide authentication services to a legacy application
US8087075B2 (en) 2006-02-13 2011-12-27 Quest Software, Inc. Disconnected credential validation using pre-fetched service tickets
US8429712B2 (en) 2006-06-08 2013-04-23 Quest Software, Inc. Centralized user authentication system apparatus and method
US8086710B2 (en) 2006-10-30 2011-12-27 Quest Software, Inc. Identity migration apparatus and method
US8429645B2 (en) * 2007-08-14 2013-04-23 International Business Machines Corporation Method for optimizing migration of software applications to address needs
WO2009158359A2 (en) * 2008-06-23 2009-12-30 Sntech, Inc. Data transfer between motors
US8255984B1 (en) 2009-07-01 2012-08-28 Quest Software, Inc. Single sign-on system for shared resource environments
US20120117558A1 (en) * 2010-11-04 2012-05-10 Microsoft Corporation Mobile application migration service
US20120137278A1 (en) 2010-11-30 2012-05-31 International Business Machines Corporation Generating a customized set of tasks for migration of a deployed software solution
JP5954738B2 (en) * 2013-03-19 2016-07-20 インターナショナル・ビジネス・マシーンズ・コーポレーションInternational Business Machines Corporation Computer, system, method and program for performing file backup processing
US20150089382A1 (en) * 2013-09-26 2015-03-26 Wu-chi Feng Application context migration framework and protocol

Citations (3)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US5155847A (en) * 1988-08-03 1992-10-13 Minicom Data Corporation Method and apparatus for updating software at remote locations
US5564051A (en) * 1989-08-03 1996-10-08 International Business Machines Corporation Automatic update of static and dynamic files at a remote network node in response to calls issued by or for application programs
EP0841615A2 (en) * 1996-11-08 1998-05-13 International Computers Limited Updating mechanism for software

Family Cites Families (12)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
JP2783109B2 (en) * 1993-03-04 1998-08-06 三菱電機株式会社 Database system evacuation device, database system restoration device, and database system migration device
JPH076026A (en) * 1993-05-28 1995-01-10 Xerox Corp Method for guarantee of interchangeablity of configuration management and component and method for exclusion of non- interchangeability of resident software and migration software
US5710922A (en) * 1993-06-02 1998-01-20 Apple Computer, Inc. Method for synchronizing and archiving information between computer systems
US5680609A (en) * 1994-06-10 1997-10-21 Intel Corporation Method and apparatus for synchronizing file deletions in computer systems
US5708828A (en) * 1995-05-25 1998-01-13 Reliant Data Systems System for converting data from input data environment using first format to output data environment using second format by executing the associations between their fields
US5819020A (en) * 1995-10-16 1998-10-06 Network Specialists, Inc. Real time backup system
US5727202A (en) * 1995-10-18 1998-03-10 Palm Computing, Inc. Method and apparatus for synchronizing information on two different computer systems
US5832274A (en) * 1996-10-09 1998-11-03 Novell, Inc. Method and system for migrating files from a first environment to a second environment
US5875327A (en) * 1997-02-18 1999-02-23 International Business Machines Corporation Hierarchy of preferences and preference groups
US6301612B1 (en) * 1998-08-12 2001-10-09 Microsoft Corporation Establishing one computer as a replacement for another computer
US6209089B1 (en) * 1998-08-12 2001-03-27 Microsoft Corporation Correcting for changed client machine hardware using a server-based operating system
US6182212B1 (en) * 1998-12-14 2001-01-30 International Business Machine Corporation Method and system for automated migration of user settings to a replacement computer system

Patent Citations (3)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US5155847A (en) * 1988-08-03 1992-10-13 Minicom Data Corporation Method and apparatus for updating software at remote locations
US5564051A (en) * 1989-08-03 1996-10-08 International Business Machines Corporation Automatic update of static and dynamic files at a remote network node in response to calls issued by or for application programs
EP0841615A2 (en) * 1996-11-08 1998-05-13 International Computers Limited Updating mechanism for software

Cited By (6)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US6370646B1 (en) 2000-02-16 2002-04-09 Miramar Systems Method and apparatus for multiplatform migration
US7356816B2 (en) 2001-02-13 2008-04-08 Computer Associates Think, Inc. Method and apparatus for multiplatform migration
WO2002075546A2 (en) * 2001-03-21 2002-09-26 Angele Sebastien Method for saving and restoring all configuration parameters for a computer platform by means of a server
FR2822563A1 (en) * 2001-03-21 2002-09-27 Sebastien Angele Method for saving and restoring platform configuration parameters on a server, uses program sent by server to analyze platform, which returns data to server to prepare program used by platform to save configuration and send to server
WO2002075546A3 (en) * 2001-03-21 2003-04-10 Sebastien Angele Method for saving and restoring all configuration parameters for a computer platform by means of a server
WO2009156577A1 (en) * 2008-06-27 2009-12-30 Nokia Corporation Method, apparatus, and computer program product for personalizing a device

Also Published As

Publication number Publication date
WO2000070445A3 (en) 2001-02-01
US6625622B1 (en) 2003-09-23
AU4845200A (en) 2000-12-05

Similar Documents

Publication Publication Date Title
US6625622B1 (en) Apparatus and method for transfering information between platforms
US7783674B2 (en) Application and method for transferring information between platforms
CN109947773B (en) Deploying changes to key patterns in a multi-tenant database system
US6698018B1 (en) System and method of multiple-stage installation of a suite of applications
EP0490624B1 (en) Graphical configuration of data processing networks
US5909689A (en) Automatic update of file versions for files shared by several computers which record in respective file directories temporal information for indicating when the files have been created
EP0901073B1 (en) Method for automatically installing and transferring data to a computer disk drive
US6567860B1 (en) Method and apparatus for new device driver installation by an operating system
US6990523B2 (en) System and method for synchronizing objects between two devices
US7398480B2 (en) System and method of providing multiple installation actions
US7000231B1 (en) Method of manufacturing operating system master template, method of manufacturing a computer entity and product resulting therefrom, and method of producing a production version of an operating system
US6922831B1 (en) Method and system for providing software utilizing a restore medium and a network
US5892953A (en) Corrective service facility
US6704778B1 (en) Method and apparatus for maintaining consistency among large numbers of similarly configured information handling servers
CN1272649A (en) Movable table top parts mounted by factory
JPH04320526A (en) Software upgrading method in electronic printing system
US6253209B1 (en) Method for parallel, remote administration of mirrored and alternate volume groups in a distributed data processing system
US6526493B1 (en) Method and apparatus for partitioning and formatting a storage media without rebooting by creating a logical device control block (DCB) on-the-fly
JPH11282686A (en) Network computer system
JPH1124896A (en) Software installation method
EP0797159A1 (en) Graphic user interface apparatus and method for computer networking
US20030028868A1 (en) Information processor, method for processing information and computer-readable recording medium recorded with program code for controlling a computer to process information
US6243828B1 (en) System for parallel, remote administration of mirrored and alternate volume groups in a distributed data processing system
US20040153641A1 (en) Computer system manager
JP3546962B2 (en) Installation device, installation method, and medium recording installation program

Legal Events

Date Code Title Description
AK Designated states

Kind code of ref document: A2

Designated state(s): AE AG AL AM AT AU AZ BA BB BG BR BY CA CH CN CR CU CZ DE DK DM DZ EE ES FI GB GD GE GH GM HR HU ID IL IN IS JP KE KG KP KR KZ LC LK LR LS LT LU LV MA MD MG MK MN MW MX NO NZ PL PT RO RU SD SE SG SI SK SL TJ TM TR TT TZ UA UG US UZ VN YU ZA ZW

AL Designated countries for regional patents

Kind code of ref document: A2

Designated state(s): GH GM KE LS MW SD SL SZ TZ UG ZW AM AZ BY KG KZ MD RU TJ TM AT BE CH CY DE DK ES FI FR GB GR IE IT LU MC NL PT SE BF BJ CF CG CI CM GA GN GW ML MR NE SN TD TG

121 Ep: the epo has been informed by wipo that ep was designated in this application
AK Designated states

Kind code of ref document: A3

Designated state(s): AE AG AL AM AT AU AZ BA BB BG BR BY CA CH CN CR CU CZ DE DK DM DZ EE ES FI GB GD GE GH GM HR HU ID IL IN IS JP KE KG KP KR KZ LC LK LR LS LT LU LV MA MD MG MK MN MW MX NO NZ PL PT RO RU SD SE SG SI SK SL TJ TM TR TT TZ UA UG US UZ VN YU ZA ZW

AL Designated countries for regional patents

Kind code of ref document: A3

Designated state(s): GH GM KE LS MW SD SL SZ TZ UG ZW AM AZ BY KG KZ MD RU TJ TM AT BE CH CY DE DK ES FI FR GB GR IE IT LU MC NL PT SE BF BJ CF CG CI CM GA GN GW ML MR NE SN TD TG

DFPE Request for preliminary examination filed prior to expiration of 19th month from priority date (pct application filed before 20040101)
REG Reference to national code

Ref country code: DE

Ref legal event code: 8642

122 Ep: pct application non-entry in european phase
NENP Non-entry into the national phase

Ref country code: JP