In a computer system, there are instances in which a set of operations make changes to application or data state. Performing some, but not all of the related operations can place the system in an undefined or erroneous operating state. For example, in a database storing information about a retail operation, a sale of an item may give rise to a need to decrease a value in a record indicating a quantity of items in stock and to increase a value in a record indicating a quantity of units sold. It would not be appropriate to perform one of these operations if both could not be performed. As another example, when configuring a computer, multiple changes may be made to a registry file. If the configuration process were interrupted before all changes to the registry file were made, the computer could be left in an unintended operating state and would not function properly. Use of transactions make it possible that such related operations can be grouped together, so that all operations are completed or none of them are completed. The activity where these operations are grouped together is referred to as a transaction.
To achieve the intended all or none transaction semantics, a platform component of a computing system may include a “transaction manager” and a “resource manager.” These components ensure that, if all of the operations in a transaction cannot be performed together, then none of the operations are performed. SQL Server, the Windows® operating system and the NET framework, for example, may contain transaction managers and resource managers.
In one known model, the transaction manager and resource manager implement the “two phase commit protocol.” An application programmer wanting to use the platform to execute a transaction will write code as part of the application that accesses platform functions through an application programming interface to the transaction manager. The transaction manager will track the operations of the transaction and interact with the resource managers to determine whether every operation of the transaction can be performed. If so, the transaction manager will “commit” the transaction, meaning that the operations are allowed to actually affect the state of the system. If not, or if an error occurs before that check is complete, the transaction manager will “roll back” the transaction. When a transaction is rolled back, none of the operations that are part of the transaction are allowed to change the state of the resources.
Significant flexibility is provided to users, including programmers and administrators, of a computer system by providing a command shell that supports transactions. The command set recognized by the command shell may include transaction commands, such as commands that start, complete or roll back transactions. These commands may be interspersed with simple commands, some of which may be transacted, that perform operations within the computer system. The transacted commands may be executed within an ambient transaction defined by the transaction commands.
With such a command shell, a user may define transactions by sequencing commands, such as by successively entering commands through a user interface or creating a script that contains a sequence of commands. For example, an administrator may create a transaction to configure the computer system, without using an application specifically designed to execute transactions.
The foregoing is a non-limiting summary of the invention, which is defined by the attached claims.
The accompanying drawings are not intended to be drawn to scale. In the drawings, each identical or nearly identical component that is illustrated in various figures is represented by a like numeral. For purposes of clarity, not every component may be labeled in every drawing. In the drawings:
The inventors have appreciated that operation of a computing system could be improved if transactions could be more readily defined. Rather than limiting transactions to those performed as part of an application designed to support transactions, new transactions can be readily defined for commands specified through a command line. For example, as a computer is frequently configured by a user entering commands through a command line. These commands can be entered through a user interface or as part of a script that is executed. Regardless of how the commands are entered through the command line, there are scenarios in which it would be desirable to provide a simple mechanism for a set of such commands to be transacted. Use of transactions helps ensure that the computer is not left in an undefined or unintended operating state as a result of incomplete execution of a sequence of operations.
Moreover, because commands associated with multiple applications can be entered through a command line, providing transaction support for command line processing enables transactions that can include transactional instructions provided as part of multiple applications, even though those applications were not specifically designed to work together in a transaction.
According to some embodiments, transaction support is incorporated in a computer system through the use of a command shell that facilitates transaction processing. The command shell may resemble a command shell as known in the art. However, the command shell may respond to transaction commands, such as commands that start, complete or undo a transaction. The command shell may also receive and process simple commands, some of which may be transacted.
For greater control over definition of a transaction, the commands processed by the command shell may include parameters that define operating characteristics. For example, the command shell may support nested transactions or non-nested transactions, which may be distinguished based on parameters associated with a start transaction command.
The distinction between nested and non-nested transactions may be useful, for example, when streams of commands may be predefined and one stream of transaction may invoke another stream. If a user intends operations within the called stream to be disposed of separately from operations in the calling stream, a transaction started in the called stream may be nested with a transaction started in the calling stream. In contrast, when it is intended that all of the operations in both streams are disposed of as a single transaction, a transaction started in the called stream may be non-nested relative to a transaction started in the calling stream.
Any suitable mechanisms may be incorporated into the computer system to support transaction processing. In some embodiments, the command shell may include a transaction manager that interacts with transacted task modules to log transactional instructions in those modules and to commit them, when appropriate. Moreover, whether to log transactional instructions and when to commit them may be determined based on coding within the task modules as well as transaction-related state information maintained within the command shell. For example, conditional instructions may be defined for use in coding transacted task modules such that execution of instructions in those modules may depend on a dynamically defined transaction state.
Though embodiments of the invention will provide capabilities not heretofore provided in a computer system, these capabilities may be implemented using techniques as is known in the art. For example, platforms that execute transactions are known.
As an example of techniques and technology that may be adapted to implement transactions through a command line interface,
Regardless of the form of input 212, computer-executable instructions within application 230 may execute in response. In this example, instructions 232, 234 and 236 may be executed to perform the transaction. In the example of
This transactional behavior can be achieved through the interaction of application 230 with transaction manager 220 and resource manager 222. These components may interact to implement a “two phase commit protocol.” Such a transaction may be implemented as follows:
In the embodiment illustrated, application 230 is implemented using a series of computer executable instructions that perform an operation as part of the transaction. In
Though
The inventors have appreciated that a two phase commit protocol may be adapted to enable commands provided through a command shell to be transacted. A command shell is a known component of many computer operating systems. A shell receives input, such as through user input or from a script, that contains a sequence of instructions, sometimes called “cmdlets.” Each cmdlet identifies a set of computer-executable instructions, which is described herein as a “task module,” that, when executed perform the operations associated with the cmdlet. In some instances, a task module may invoke other cmdlets. Nonetheless, by invoking a task module in response to a cmdlet, a set of operations associated with a cmdlet may be processed.
The inventors have recognized and appreciated that an application, such as application 230, could be invoked in response to user input received through a command shell. However, simply invoking a transacted application, such as application 230, may not provide a desired behavior in all scenarios. By encoding the transactional behavior into the application, it may not be possible to dynamically specify the transactional behavior with input provided after the application is written. For example, a user may desire to create a transaction involving multiple cmdlets developed at different times by different parties. In this scenario, the desired transactional behavior, such as when to create or complete a transaction, cannot be written in advance into the application.
Accordingly, task modules that implement cmdlets to be part of a transaction defined through a command shell may be coded differently than transacted applications. Furthermore, the command shell itself may be adapted to support transactional behavior. Accordingly, in some embodiments a command shell may process cmdlets defining transactional behavior. In addition, the command shell may maintain transaction state information.
In the example of
Other instructions within task module 250 may similarly be processed within the context of a transaction. For example, transactional instructions 254B are within a code block processed in the context of a transaction. Instruction 252B, preceding that code block, likewise identifies the transaction as one maintained by the command shell.
It is not necessary that all of the instructions within task module 250 be transactional instructions. As illustrated by the example of
In addition to providing the capability for instructions to be processed in the context of a transaction defined outside the task module, task module 250 differs from task module 230 (
As illustrated in
Providing for the possibility of conditional processing instructions that are based on the state of transaction processing within a command shell allows a developer of task modules, such as task modules 250 and 260, to define behaviors that are appropriate for many circumstances and may facilitate composing transactions through a command line interface. For example, task module 250 is an appropriate encoding of operations that are performed in the context of a transaction. Invoking task module 250 in a different context where no transaction has been defined may generate an error. In contrast, invoking task module 260 in a context where no transaction has been defined will not produce an error. However, task module 260 may perform different functions based on the environment in which it is invoked.
As illustrated in
Though any suitable mechanism may be used for interactions between a command shell and one or more task modules,
In the example of
Also, as known in the art, the commands executed by command shell 310 may be obtained from one or more sources. In this example, commands may be provided through a user interface 314. Through such a user interface, a user of a computer configured as illustrated in
As another example, commands may be input to command shell 310 through an application programming interface 312. Commands may be input through API 312 under control of script 316. Script 316 may be implemented as a series of commands typed into a file, as is known art. However, the mechanisms by which commands are input to command shell 310 are not limitations on the invention and any suitable mechanism may be used.
Command shell 310 may differ from a command shell as is known in the art in that it may be adapted to support transactions. One way in which command shell 310 may support transactions is that it may process commands that alter the state of transaction processing. Additionally, command shell 310 may interact with other components of the system in a way that implements transacted behavior consistent with the transactional commands it receives.
As a specific example, execution engine 311 within command shell 310 may process transaction commands, some of which define the start of transactions and others of which define dispositions of transactions. A transaction may be disposed of by completing the transaction, which commits all of the transactional instructions that are part of the task modules executed as part of the transaction. Though, a transaction may be disposed of in other ways, such as by undoing the transaction. In the embodiment illustrated, command shell 310 may respond to transaction commands that perform start, complete and undo transactions.
As command shell 310 responds to such transactional commands, state module 313 may record the transactional state of command shell 310. In addition, as commands are executed that depend on transactional state, state module 313 may provide state information to execution engine 311, so that the commands can be executed based on the state information. Known programming techniques may be used to enable the components depicted in
Part of the processing described below may entail creating or disposing of transactions based on changes of transactional state. Transactions may be represented using techniques as known in the art. For example transaction manager 318 may create an object 320 in response to input indicating that a transaction should be started. Object 320 may be implemented in the same fashion as object 246, though any suitable mechanism for representing a transaction may be used. However, rather than creating such an object in response to an instruction from an application, transaction manager 318 may create such an object in response to a command from command shell 310.
In some embodiments illustrated, transactions may be nested, creating the possibility that multiple transactions may be defined at one time. Accordingly,
Transaction stack 330 may be maintained by a stack module within command shell 310 or in any other suitable way. The stack 330 may be implemented as a data structure in computer-readable media associated with a computer on which command shell 310 resides. However, any suitable mechanism may be used to implement transaction stack 330.
Transaction stack 330 may include a frame for each transaction in existence. In this example, identifier 332 and counter 334 form a first frame and identifier 336 and counter 338 form a second frame, each associated with one of the transactions. Accordingly, command shell 310 may add and remove such frames as transactions are created or disposed of. Command shell may use the frame at the top of stack 330 to identify the current, or ambient, transaction.
When command shell 310 executes a transactional command that completes a transaction, it may notify transaction manager 318. Transaction manager 318 may then commit the transaction by interacting with resource mangers, such as resource managers 350A and 350B. These interactions may be performed according to a two phase commit protocol as known in the art. However, any suitable processing to complete a transaction may be used.
Command shell 310 may also process simple commands that access resources or perform other actions within a computer system. The simple commands may be analogous to those performed by a command shell as is known in the art. Though, simple commands may be processed according to a process described in more detail in connection with
When task modules include transactional instructions that are to be processed based on the current transactional state of the system, those transactional instructions may be processed using techniques as are known in the art. For example, a transaction manager 318 and resource managers 350A and 350B may be used to identify transactional instructions and execute them or roll them back upon disposition of a transaction. Though, any suitable mechanism for selectively executing instructions that are part of a transaction may be used.
Transaction manager 318 may interact with resources managers, such as resource managers 350A and 350B, to process task modules that may be transacted. In the example of
In the example illustrated, simple, non-transacted commands may be processed in the same way that known command shells process commands. Specifically, when a cmdlet implemented by a non-transacted task module, such as task module 340C, is processed, the task module may be invoked without receiving or altering transactional state information. Any instructions within task module 340C may be executed when the module is invoked, even if those instructions alter the state of resource 346B upon which task module 340C operates.
When command shell 310 processes a cmdlet implemented as a transacted task module, shell 310 may provide the task module with information on the current transaction. This information may be provided in any suitable way. For example, execution of an instruction, such as instruction 252A (
The information about the current transaction may be used to log transactional instructions in a resource manager and associate those instructions with a transaction. Each resource manager, such as resource mangers 350A and 350B, that processes transactional instructions in a task module may be provided with an indication of the current transaction. The resource manager can then enlist in that transaction, log the instructions for execution, and permanently apply the updates done in the transaction if that transaction is committed.
In the example of
To enable command shell 310 to distinguish between transacted task modules and non-transacted task modules, a mechanism may be incorporated to identify transacted task modules. In this example, the transacted task modules 340A and 340B are coded with a flag, illustrated as flags 342A and 342B, respectively. Command shell 310 may ascertain whether a task module that is to be invoked in response to processing a command is transacted. As one example, each task module may expose an interface through which a transacted flag may be read, if such a flag is present. Though, other mechanisms may be used to identify a transacted task module. For example, a flag may be associated with a command provided to command shell 310 which, when executed, is intended to invoke a task module. Accordingly, the specific mechanism by which transacted task modules are identified is not critical to the invention.
Regardless of the specific implementation, the process of
Once the command is received, processing proceeds to decision block 412. At decision block 412 the process branches depending on whether the received command is a transaction command. In the example of
Any suitable mechanism may be used to allow shell 310 to identify transaction commands. As one example, each command may include a unique identifier. Command shell 310 may include a mapping table or other suitable mechanism to select, based on command identifiers, those commands that are transaction commands.
Regardless of the mechanism by which transaction commands are identified, when a transaction command is received, processing may branch from decision block 412 to decision block 420. At decision block 420, the process may again branch based on whether the received command indicates that a transaction should be started. If the received command indicates the start of the transaction, the process branches to perform subprocess A, which is described in more detail in conjunction with
Conversely, if the received command is not a start transaction command, the process proceeds to decision block 422. At decision block 422, the process again branches depending on whether the received command is a complete transaction command. If the received command is a complete transaction command, the process proceeds to subprocess B, described in more detail below in conjunction with
If the received command is not a complete transaction command, the process proceeds to decision block 424. At decision block 424, the process again branches depending on whether the received command is an undo command. If the received command is an undo command, the process proceeds to subprocess C, described in more detail in conjunction with
In the embodiment illustrated, command shell 310 supports three transaction commands, start, complete and undo. Accordingly, if the process exits decision block 424 without being diverted to one of subprocesses A, B or C, then an error has occurred. Accordingly, if, as determined at decision block 424, the received command is not an undo command, the process ends at an error termination point. Such processing is appropriate when only the three described transaction commands are supported within command shell 310. If command shell 310 supports other transaction commands, other decision processing may be performed to determine whether the received command corresponds with a supported transaction command before error processing begins.
Returning to decision block 412, if it is determined at decision block 412 that the received command is not a transaction command, the process branches from decision block 412 to block 430. At block 430, command shell 310 may select a task module containing instructions implementing the command. A conventional command shell may invoke a task module in response to a received command. A similar mechanism may be employed for transaction processing as described herein. In this case, each task module may be in the form of task modules such as task module 250 (
Regardless of how the task module is selected, the processing may proceed to decision block 432. At decision block 432, the process may branch depending on whether the selected task module is transacted. As described above in connection with
If a received command, or the selected task module that will execute it, is not indicated to be transacted, the processing branches from decision block 432 to block 440. At block 440, the task module is executed. If processing reaches block 440, the task module is not executed within a transaction. Accordingly, processing at block 440 may be performed as is known in the art for executing a task module invoked by a command shell. Thereafter, processing may loop back to the start of the process illustrated in
If the selected task module is transacted, however, processing may branch from decision block 432 to decision block 434. At decision block 434, the process may again branch based on whether transactional behavior is to be bypassed. In the example of
When the bypass flag set, processing may branch from decision block 434 to block 440. As described above, if processing reaches block 440, the selected cmdlet may be executed without transactional behavior. When bypassed, rather than logging instructions for later execution, each instruction may be executed as processed. Though, any other suitable behavior may be implemented when a transaction is bypassed, including processing the task module as if it were invoked in a context in which no transaction is defined, which may produce an error if the task module includes instructions that require a transaction.
Conversely, if the bypass flag is not set, processing may proceed to decision block 436. If processing reaches decision block 436, the selected cmdlet is implemented as a transacted task module intended to be executed with transactional behavior. However, if no transaction has been defined by command shell 310, the task module may not execute appropriately. Accordingly, in the embodiment illustrated, processing branches from decision block 436 to block 442 if no transaction is available within which to execute the transacted task module.
At block 442, error processing is performed. Any suitable error processing may be performed at block 442. For example, the error processing may entail generating an error message to a user or taking other corrective action. Thereafter, processing may loop back to the start of the process illustrated in
However, if a transaction is available, the selected cmdlet is executed within the context of that transaction. Such processing is described below in further detail in conjunction with
Turning to
Regardless of how the state of command shell 310 is determined, processing branches to block 512 when command shell 310 is not in a transaction. At block 512, processing that places command shell 310 in a state for processing transacted commands is initiated. At block 512, command shell 310 indicates to transaction manager 318 that a new transaction is required and transaction manager 318 creates an object, such as object 320 or 322 to represent that transaction.
The process then proceeds to block 514 where a mechanism to track the current transaction state of command shell 310 is implemented. In the embodiment of
Other information used in implementing transactions within command shell 310 may likewise be stored within the stack. For example, at block 516 a counter, such as counter 334 may be initialized. In this example, the counter is initialized to a value of one. As described in greater detail below, this counter may be used to aid in grouping instructions from different task modules into a single transaction when such behavior is desired.
Though not expressly shown, different or additional information may also be stored in the stack frame associated with the new transaction. Regardless of the specific information stored, once the state of command shell 310 is altered to indicate that a transaction is in process, the processing of
Alternatively, if a start transaction command is received when command shell 310 is already in a transaction, processing may branch from decision block 510 to decision block 520. The processing branches at decision block 520 depending on the type of nesting behavior specified for the commands being processed.
In the example illustrated, command shell 310 processes two types of start transaction commands: nested or non-nested. These different types of transactions provide different behaviors when a script, encoded to support a transaction, calls another second script, also encoded to support a transaction. In some instances, the commands in the second script may be intended to be treated as a transaction separate from the commands in the calling series. In this scenario, the two scripts may be regarded as defining nested transactions, with the series of commands in the second script being disposed of separately from the series of commands in the first script. If both scripts are intended to be executed together as one transaction, the scripts should be specified non-nested.
Any suitable mechanism may be used to differentiate between a nested and a non-nested start transaction command. In this example, a flag may be incorporated in the start transaction command to indicate whether the transaction to be started is intended to be nested or non-nested. In such an embodiment, processing at block 520 may entail checking for such a flag associated with the received start command to be processed. However, separate nested and non-nested commands may be defined or the distinction may be presented in any suitable way.
Regardless of the specific mechanism used to identify whether the transaction being started is intended to be nested, if the transaction is non-nested, processing branches from decision block 520 to block 522. At block 522, the transaction subscriber counter associated with the current transaction is increased by one. In the example of
In the embodiment illustrated, the subscriber counter indicates the number of start transaction commands executed within successive non-nested transactions. In the embodiment illustrated, start and complete transaction commands are intended to be implemented in pairs. Thus, while new transactions are not being nested, the number of start transaction commands executed is an indication of the number of complete transaction commands that must be executed to reach the complete transaction command that signals the end of the non-nested transactions.
Conversely, if the start transaction command being processed in
A new stack frame may be created for the nested transaction at block 532. Creating the stack frame will indicate to command shell 310, and any task modules obtaining state information relating to transaction processing within command shell 310, that the current transaction is the new nested transaction established as a result of executing the start transaction command. In the embodiment in which a stack frame includes a subscriber counter, processing within
As noted above, different or additional information may be stored to reflect the state of command shell 310, and the processing illustrated in
Turning to
Conversely, if the complete transaction command is received while a transaction is in process, the process proceeds from decision block 540 to decision block 542. At decision block 542, the process branches, depending on the subscriber count associated with the current transaction. In the embodiment illustrated in
As described above, the subscriber counter is used to determine whether the last complete transaction command in a non-nested transaction has been reached. In the embodiment illustrated, a subscriber count of one indicates that the last complete transaction command has been reached and the transactional instructions that have been logged with the current transaction should be committed. Accordingly, processing branches from decision block 542 to block 548, which is the start of processing to commit logged transactional instructions.
At block 548, transaction manager 318 begins the process of committing the instructions associated with the outermost transaction. This processing may be performed in any suitable way. However, in the embodiment illustrated a two phase commit protocol is used. As part of this protocol, transaction manager 318 may obtain information about the outermost transaction from an object, such as object 322. That information may include the resource managers that have enlisted in the transaction. Transaction manager 318 may then use this information to poll the enlisted resource managers to determine whether the transaction can be committed. If so, transaction manager 318 may indicate to the resource managers that the instructions they have logged in the context of the outermost transaction should be executed. In the example of
Regardless of the manner in which the logged instructions are executed, processing proceeds to block 550. Because the logged instructions have been executed, the logs may be removed from the system. However, removing the log is not critical to the invention. Alternatively or additionally, the log may be archived or otherwise left as part of the computer system in which transaction processing occurs.
Processing then proceeds to block 552 where the stack frame associated with the transaction that was completed by executing instructions at block 548 is removed from the stack. The stack frame may be removed using known stack management principles or in any other suitable way.
Once operations associated with committing the instructions of the transaction have been performed, processing may loop back to the start of processing illustrated in
Conversely, if the subscriber counter is greater than one, processing branches from decision block 542 to block 546. As described above, the subscriber counter associated with each transaction is used as a mechanism to determine whether a complete transaction command indicates the end of non-nested transaction. If the subscriber counter is greater than one, the end of the non-nested transaction has not been reached. At block 546, the subscriber counter is decreased by one. However, the transactional commands associated with the active transaction are not committed. Accordingly, following block 546, processing may loop back to the start of the processing illustrated in
Turning to
However, if command shell 310 is processing a transaction, the process may branch from decision block 560 to block 562. Block 562 may represent the beginning of processing to roll-back the transaction to be undone. In the example in which transactions may be nested, execution of an undo transaction command results in the outermost transaction being undone. As indicated, such processing includes removing the logs associated with the outermost transaction at block 562. This action may be directed by transaction manager 318, which maintains a record of resource managers that have enlisted in each transaction.
At block 564, the stack frame associated with the outermost transaction, the transaction being undone, is also removed. The processing at blocks 562 and 564 is performed without executing the logged instructions. In this way, the transactional instructions that were part of the undone transaction do not alter the underlying resources. Once these actions are taken, processing may loop back to the start of processing of
Turning to
In implementations in which each command being processed as a transacted command should have at least one flag set, a command received with no flags set may indicate an error. In the embodiment of
If no error is detected at decision block 570, processing proceeds to loop start 572. Within the loop following loop start 572, each instruction within the task module selected at block 430 is processed. Processing within the loop begins at decision block 574. At decision block 574, the process branches depending on whether the instruction is within a block for which a transaction is to be used. For example, in
Regardless of the manner in which transactional instructions are identified, if an instruction is not transactional, the process branches to block 580. At block 580, the instruction may be executed. Processing at block 580 may entail execution of an instruction using techniques as are known in the art or in any other suitable way.
Regardless of the manner in which the instruction is executed, following execution processing may proceed to decision block 590. At decision block 590 the process loops back to loop start 572 if additional instructions within the task module remain for processing. Conversely, if no further instructions remain, the process may branch from decision block 590 back to the start of the loop at the beginning of processing in
Conversely, when an instruction within a task module is intended to be executed as part of a transaction, the process of
If the instruction is executable, the instruction is added to the log for the current transaction kept by the resource manager. In the embodiment of
In the system of
Regardless of the manner in which the instruction is logged, processing may then proceed to decision block 590. At decision block 590, the process may branch depending on whether further instructions remain for execution of the selected cmdlet. If so, the process loops back to loop start 572. If not, processing returns to the start of processing indicated in
Though not illustrated in
Command line processing of transactions may be implemented in any suitable computer environment.
Neither should the computing environment 100 be interpreted as having any dependency or requirement relating to any one or combination of components illustrated in the exemplary operating environment 100.
The invention is operational with numerous other general purpose or special purpose computing system environments or configurations. Examples of well known computing systems, environments, and/or configurations that may be suitable for use with the invention include, but are not limited to, personal computers, server computers, hand-held or laptop devices, multiprocessor systems, microprocessor-based systems, set top boxes, programmable consumer electronics, network PCs, minicomputers, mainframe computers, distributed computing environments that include any of the above systems or devices, and the like.
The invention may be described in the general context of computer-executable instructions, such as program modules, being executed by a computer. Generally, program modules include routines, programs, objects, components, data structures, etc. that perform particular tasks or implement particular abstract data types. The invention may also be practiced in distributed computing environments where tasks are performed by remote processing devices that are linked through a communications network. In a distributed computing environment, program modules may be located in both local and remote computer storage media including memory storage devices.
With reference to
Computer 110 typically includes a variety of computer readable media. Computer readable media can be any available media that can be accessed by computer 110 and includes both volatile and nonvolatile media, removable and non-removable media. By way of example, and not limitation, computer readable media may comprise computer storage media and communication media. Computer storage media includes both volatile and nonvolatile, removable and non-removable media implemented in any method or technology for storage of information such as computer readable instructions, data structures, program modules or other data. Computer storage media includes, but is not limited to, RAM, ROM, EEPROM, flash memory or other memory technology, CD-ROM, digital versatile disks (DVD) or other optical disk storage, magnetic cassettes, magnetic tape, magnetic disk storage or other magnetic storage devices, or any other medium which can be used to store the desired information and which can accessed by computer 110. Communication media typically embodies computer readable instructions, data structures, program modules or other data in a modulated data signal such as a carrier wave or other transport mechanism and includes any information delivery media. The term “modulated data signal” means a signal that has one or more of its characteristics set or changed in such a manner as to encode information in the signal. By way of example, and not limitation, communication media includes wired media such as a wired network or direct-wired connection, and wireless media such as acoustic, RF, infrared and other wireless media. Combinations of the any of the above should also be included within the scope of computer readable media.
The system memory 130 includes computer storage media in the form of volatile and/or nonvolatile memory such as read only memory (ROM) 131 and random access memory (RAM) 132. A basic input/output system 133 (BIOS), containing the basic routines that help to transfer information between elements within computer 110, such as during start-up, is typically stored in ROM 131. RAM 132 typically contains data and/or program modules that are immediately accessible to and/or presently being operated on by processing unit 120. By way of example, and not limitation,
The computer 110 may also include other removable/non-removable, volatile/nonvolatile computer storage media. By way of example only,
The drives and their associated computer storage media discussed above and illustrated in
The computer 110 may operate in a networked environment using logical connections to one or more remote computers, such as a remote computer 180. The remote computer 180 may be a personal computer, a server, a router, a network PC, a peer device or other common network node, and typically includes many or all of the elements described above relative to the computer 110, although only a memory storage device 181 has been illustrated in
When used in a LAN networking environment, the computer 110 is connected to the LAN 171 through a network interface or adapter 170. When used in a WAN networking environment, the computer 110 typically includes a modem 172 or other means for establishing communications over the WAN 173, such as the Internet. The modem 172, which may be internal or external, may be connected to the system bus 121 via the user input interface 160, or other appropriate mechanism. In a networked environment, program modules depicted relative to the computer 110, or portions thereof, may be stored in the remote memory storage device. By way of example, and not limitation,
Having thus described several aspects of at least one embodiment of this invention, it is to be appreciated that various alterations, modifications, and improvements will readily occur to those skilled in the art.
Such alterations, modifications, and improvements are intended to be part of this disclosure, and are intended to be within the spirit and scope of the invention. Accordingly, the foregoing description and drawings are by way of example only.
The above-described embodiments of the present invention can be implemented in any of numerous ways. For example, the embodiments may be implemented using hardware, software or a combination thereof. When implemented in software, the software code can be executed on any suitable processor or collection of processors, whether provided in a single computer or distributed among multiple computers.
Further, it should be appreciated that a computer may be embodied in any of a number of forms, such as a rack-mounted computer, a desktop computer, a laptop computer, or a tablet computer. Additionally, a computer may be embedded in a device not generally regarded as a computer but with suitable processing capabilities, including a Personal Digital Assistant (PDA), a smart phone or any other suitable portable or fixed electronic device.
Also, a computer may have one or more input and output devices. These devices can be used, among other things, to present a user interface. Examples of output devices that can be used to provide a user interface include printers or display screens for visual presentation of output and speakers or other sound generating devices for audible presentation of output. Examples of input devices that can be used for a user interface include keyboards, and pointing devices, such as mice, touch pads, and digitizing tablets. As another example, a computer may receive input information through speech recognition or in other audible format.
Such computers may be interconnected by one or more networks in any suitable form, including as a local area network or a wide area network, such as an enterprise network or the Internet. Such networks may be based on any suitable technology and may operate according to any suitable protocol and may include wireless networks, wired networks or fiber optic networks.
Also, the various methods or processes outlined herein may be coded as software that is executable on one or more processors that employ any one of a variety of operating systems or platforms. Additionally, such software may be written using any of a number of suitable programming languages and/or programming or scripting tools, and also may be compiled as executable machine language code or intermediate code that is executed on a framework or virtual machine.
In this respect, the invention may be embodied as a computer readable medium (or multiple computer readable media) (e.g., a computer memory, one or more floppy discs, compact discs, optical discs, magnetic tapes, flash memories, circuit configurations in Field Programmable Gate Arrays or other semiconductor devices, or other tangible computer storage medium) encoded with one or more programs that, when executed on one or more computers or other processors, perform methods that implement the various embodiments of the invention discussed above. The computer readable medium or media can be transportable, such that the program or programs stored thereon can be loaded onto one or more different computers or other processors to implement various aspects of the present invention as discussed above.
The terms “program” or “software” are used herein in a generic sense to refer to any type of computer code or set of computer-executable instructions that can be employed to program a computer or other processor to implement various aspects of the present invention as discussed above. Additionally, it should be appreciated that according to one aspect of this embodiment, one or more computer programs that when executed perform methods of the present invention need not reside on a single computer or processor, but may be distributed in a modular fashion amongst a number of different computers or processors to implement various aspects of the present invention.
Computer-executable instructions may be in many forms, such as program modules, executed by one or more computers or other devices. Generally, program modules include routines, programs, objects, components, data structures, etc. that perform particular tasks or implement particular abstract data types. Typically the functionality of the program modules may be combined or distributed as desired in various embodiments.
Also, data structures may be stored in computer-readable media in any suitable form. For simplicity of illustration, data structures may be shown to have fields that are related through location in the data structure. Such relationships may likewise be achieved by assigning storage for the fields with locations in a computer-readable medium that conveys relationship between the fields. However, any suitable mechanism may be used to establish a relationship between information in fields of a data structure, including through the use of pointers, tags or other mechanisms that establish relationship between data elements.
Various aspects of the present invention may be used alone, in combination, or in a variety of arrangements not specifically discussed in the embodiments described in the foregoing and is therefore not limited in its application to the details and arrangement of components set forth in the foregoing description or illustrated in the drawings. For example, aspects described in one embodiment may be combined in any manner with aspects described in other embodiments.
Also, the invention may be embodied as a method, of which an example has been provided. The acts performed as part of the method may be ordered in any suitable way. Accordingly, embodiments may be constructed in which acts are performed in an order different than illustrated, which may include performing some acts simultaneously, even though shown as sequential acts in illustrative embodiments.
Use of ordinal terms such as “first,” “second,” “third,” etc., in the claims to modify a claim element does not by itself connote any priority, precedence, or order of one claim element over another or the temporal order in which acts of a method are performed, but are used merely as labels to distinguish one claim element having a certain name from another element having a same name (but for use of the ordinal term) to distinguish the claim elements.
Also, the phraseology and terminology used herein is for the purpose of description and should not be regarded as limiting. The use of “including,” “comprising,” or “having,” “containing,” “involving,” and variations thereof herein, is meant to encompass the items listed thereafter and equivalents thereof as well as additional items.