Command line applications (such as the Powershell® cmdlets, DOS batch files or SQL command) enable a user to execute functionality from a textual command line. To perform meaningful execution, the user needs an understanding of the set of input parameters that apply and the valid range of values for each parameter.
For some programming languages, it is possible to reflect on the command line application and automatically generate a user interface, thus enabling a non-command line user or a novice to execute the functionality via the automatically generated user interface, even though the original application did not include a user interface. For example, Powershell® 3.0 includes “ShowCommand” functionality that serves this purpose.
However, such existing reflection functionality is designed to be very general, so that the generated user interface widely applies to many scenarios. As a result, this “one size fits all” form of user interface generation works for simple scenarios, but is inadequate for many other scenarios.
This Summary is provided to introduce a selection of representative concepts in a simplified form that are further described below in the Detailed Description. This Summary is not intended to identify key features or essential features of the claimed subject matter, nor is it intended to be used in any way that would limit the scope of the claimed subject matter.
Briefly, various aspects of the subject matter described herein are directed towards a technology by which an intermediary model is generated from a program that takes as inputs one or more input parameters and one or more commands. The intermediary model comprises a user interface template corresponding to a default user interface and a code template corresponding to a default transformation program. The intermediary model may be maintained in memory to allow modification of the intermediary model into a modified model that includes modified user interface data and/or modified code. A modified program corresponding to the modified model is output.
In one aspect, a model generator program is configured to process an input program into an intermediary model comprising a user interface template and a code template comprising declaratives. The model generator program persists the intermediary model to provide for editing the intermediary model into a modified model that is configured to be interpreted or compiled into an executable program.
In one aspect, an intermediary model comprising a user interface template corresponding to a default user interface and a code template corresponding to a default transformation program is generated. A modified model that is based upon the intermediary model is persisted, in which the modified model includes a modified user interface data, at least one modified parameter, one or more flow conditions and/or one or more rules that is/are not specified in the intermediary model.
Other advantages may become apparent from the following detailed description when taken in conjunction with the drawings.
The present invention is illustrated by way of example and not limited in the accompanying figures in which like reference numerals indicate similar elements and in which:
Various aspects of the technology described herein are generally directed towards reflecting on and interpreting command line applications (or commandlets or modules), and then composing an intermediary (e.g., declarative) model used for composing user interface models. In one implementation, an intermediary model is generated to represent a default user interface and default code transformation process. The intermediary model is defined using primarily declarative-based mechanisms
Thus, rather than simply generating a user interface, the technology described herein generates an intermediary model that may then be displayed using a display user interface layout manager and code transformation process, for example. Moreover, the intermediary model may be persisted and modified by end-users, thus enabling customized guidance experiences. When the intermediary model is specified in a declarative manner, non-developers are able to modify the default behavior of the user interface, and people are able to share this work.
It should be understood that any of the examples herein are non-limiting. As such, the present invention is not limited to any particular embodiments, aspects, concepts, structures, functionalities or examples described herein. Rather, any of the embodiments, aspects, concepts, structures, functionalities or examples described herein are non-limiting, and the present invention may be used various ways that provide benefits and advantages in computers and management tooling in general.
In this example, the user executes a model generator program 108 which takes as an input program 102 (e.g., the Windows® Powershell® cmdlet) for which a UI is to be generated. The program 108 may reflect on the signature of the cmdlet function, the number of parameters, the types of these parameters and whether they are optional or mandatory, for example. This information is then used by the model generator program 108 to generate a default UI model 110 (e.g., an Extensible Application Markup Language (XAML)-based form, such as defining a set of pages in text files and how they interact with each other, e.g., an introduction page, interaction page and error-handling page) and appropriate input validation logic. The information is also used to generate a default code template 112, e.g., having code in declarative form such as XAML-based.
Note that in extensible scenarios, the model generator program 108 presents the generated model to the user to decide on single cmdlet versus a pipeline or a workflow. This user input allows for composing complex application execution scenarios.
This is exemplified in
Once the implicit model 104 is generated, it may be persisted or otherwise accessed by an expert 224 or the like (who also may provide some or all of the domain expertise 222). In this way, experts can further customize and provide default parameters and flow conditions/rules as desired to the model 104.
The expert 224 may modify the code template 212 and/or UI model 210 for other purposes, e.g., to reuse a UI with a translated language, a different company name, and so on. The expert may add flow conditions and other rules to the code template 212, as generally described below with reference to
The expert 224 (or even a slightly skilled user) also may determine whether to use the model in a single operation 226, or implement it as part of a pipeline 228 or other workflow 230. For example, the model 204 may be used to present a wizard to a user to obtain user-entered values, with the result of running the program with those wizard-obtained values chained to another program (e.g., in series or possibly conditionally selected, (e.g., with the output used to determine a branching direction), which in turn may obtain more data and/or performs more processing, and so on, to produce a final output.
Returning to
After the user completes the wizard 116, a transformation program 118 takes the input parameters and inserts them into the code template 112 via transformation. This results in a modified (e.g., customized) program 120 (e.g., a Windows® Powershell® script or a pipeline of Windows® Powershell® scripts that are executable by the Windows® Powershell® interpreter). Each script can be shown to the user prior to execution or executed transparently. The artifacts generated by these processes such as UI Wizards, associated models and context may be collectively referred to herein as guidance packages.
In general and as described above, a given model generator program (e.g., 108) is typically configured with domain expertise 222 that enables the model generator program 108 to know what to look for in its input objects (e.g., parameters and types of parameters for PowerShell®, HTML domain object model, or DOM, for forms and so on), such that the model generator program 108 can then generate an appropriate model.
By way of example, consider a model generator that is designed for web forms, e.g., an HTML form that is used to provide credit card information for an e-commerce site. The model generator is programmed to incorporate domain expertise, such that it is able to recognize input controls that are relevant to this process and then build a model. That model (conceivably) may be used on other ecommerce sites, except that in many cases the forms will have different naming conventions. Thus, a user may modify the model such that the model alters its behavior on different sites. The model interpreter thus may be provided with the ability to customize behavior depending on who the host is.
As another example, consider a deployment process in which someone deploying a product has to type a large number of commands into a command line interface in order to have the deployment solution install. Each of these commands has different points of variability, and some of these will be significant for someone else that also may want to perform that same set of actions (e.g., steps).
In such an instance, a model generator may be configured to “record” the actions being performed, and use the recorded information to generate a model that makes it possible for an advanced user to then go and remove/customize/add to those steps based on an understanding of what is possible at each of the steps. It is feasible to have a model generator that is taught how to look for this expertise in a general class of problems, e.g., a model generator that works across multiple command line environments and is able to infer characteristics about these environments, which it may then use to support implementation in a specific class of command line environments.
Turning to another aspect, users may want to customize the behavior of the UI, e.g., to enable a standardized guidance experience within an organization or across a type of user. As described herein, this may be done via editing or similar interaction to provide a customized program for a command line application. Moreover, customization may be further extended to enable more complex execution scenarios, such as where the user may need to execute a workflow having of a sequence of command line applications. This is based upon chaining of command line applications, where the inputs may be collected in each step of execution based on the conditions involved.
Moreover, the user interface model does not need to be sequential as in the example of a wizard. Instead, the implicit model may include internal branching logic, (as well as be coupled for input from and/or output to other models). For example, for a debit card, the user interface may branch to another page or the like to obtain the user's debit card PIN, whereas for a credit card, the user interface may branch to another page to obtain some form of credit card signature or validation data such as expiration date/security code. The user interface model also may be configured to automatically gather data from other sources, e.g., for automated balance checking, credit check approval, and/or the like.
When the code in block 332 is run as Transformation program1, as represented via block 333, the code will present page A to the user to receive input for the specified parameter associated with page A, namely Parameter7. Note that via the model, input parameters need not be limited to standard command line input such as single values, but may include complex parameters such as name/value pair (maps to literal/text field) displays, e.g., arrays, collections of variably typed information, XML structures and so forth.
Based upon the user input, at step 340 of Transformation program1 334, the value entered determines the next page to output, e.g., Page B for Parameter7=X, Page C for Parameter7=Y, or no further page for Parameter7 equal to something other than X or Y, e.g., default values are used for output.
If Page B is output at step 342, this page collects a value for a parameter Q. If instead page C is output at step 344, this page collects a value for a different parameter R.
In the example of
As can be seen, the technology (e.g., tooling) described herein removes the typical constraints (e.g., hard coded wizards with no insight into execution logic) that typically accompanies management tools. Branching logic, different user interfaces, and the like allow different combinations of parameters to be used to execute different functionality. Also, input parameters may have complex interdependencies not easily inferred through conventional command-line reflection.
In addition, the technology helps in compiling complex applications with greater confidence, as well as removing cumbersome/complex issues. For example, users of command line applications normally get guidance help from explicit invocation of the desired command with proper help parameters (-help option or ‘?’). This is cumbersome for complex command line applications where the user needs guidance, sample scripts/snippets, and/or knowledge articles along the way, including for example, an option to execute the application in a sandbox and see the results. This technology helps to inject proper guidance to the command execution pipeline and thus helps the end user to execute code, with confidence.
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, tablet 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, and so forth, which 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 local and/or remote computer storage media including memory storage devices.
With reference to
The computer 410 typically includes a variety of computer-readable media. Computer-readable media can be any available media that can be accessed by the computer 410 and includes both volatile and nonvolatile media, and 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 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 the computer 410. 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 may also be included within the scope of computer-readable media.
The system memory 430 includes computer storage media in the form of volatile and/or nonvolatile memory such as read only memory (ROM) 431 and random access memory (RAM) 432. A basic input/output system 433 (BIOS), containing the basic routines that help to transfer information between elements within computer 410, such as during start-up, is typically stored in ROM 431. RAM 432 typically contains data and/or program modules that are immediately accessible to and/or presently being operated on by processing unit 420. By way of example, and not limitation,
The computer 410 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, described above and illustrated in
The computer 410 may operate in a networked environment using logical connections to one or more remote computers, such as a remote computer 480. The remote computer 480 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 410, although only a memory storage device 481 has been illustrated in
When used in a LAN networking environment, the computer 410 is connected to the LAN 471 through a network interface or adapter 470. When used in a WAN networking environment, the computer 410 typically includes a modem 472 or other means for establishing communications over the WAN 473, such as the Internet. The modem 472, which may be internal or external, may be connected to the system bus 421 via the user input interface 460 or other appropriate mechanism. A wireless networking component 474 such as comprising an interface and antenna may be coupled through a suitable device such as an access point or peer computer to a WAN or LAN. In a networked environment, program modules depicted relative to the computer 410, or portions thereof, may be stored in the remote memory storage device. By way of example, and not limitation,
An auxiliary subsystem 499 (e.g., for auxiliary display of content) may be connected via the user interface 460 to allow data such as program content, system status and event notifications to be provided to the user, even if the main portions of the computer system are in a low power state. The auxiliary subsystem 499 may be connected to the modem 472 and/or network interface 470 to allow communication between these systems while the main processing unit 420 is in a low power state.
In an embodiment, a method comprises, generating an intermediary model from a program that takes as inputs one or more input parameters and one or more commands, the intermediary model comprising a user interface template corresponding to a default user interface and a code template corresponding to a default transformation program, maintaining the intermediary model in memory to allow modification into a modified model that includes modified user interface data or modified code, or both modified user interface data and modified code, and outputting a modified program corresponding to the modified model.
In an embodiment, the outputting the modified program corresponding to the modified model comprises interpreting the model into user interface data that is rendered, and transforming the model based upon input received via the user interface data.
In an embodiment, the method further comprises coupling the modified program to at least one other program.
In an embodiment, the coupling the modified program comprises including the modified program in a pipeline of programs, in which at least one program's output is consumed as input by at least one other program.
In an embodiment, the coupling the modified program comprises including the modified program in a workflow of programs, in which at least one program's output determines a branching direction between a plurality of other programs.
In an embodiment, the method further comprises, executing the modified program corresponding to the modified model, in which the modified program includes branching logic that was added during a modification of the intermediary model into the modified model.
In an embodiment, the maintaining the intermediary model in memory comprises persisting the intermediary model in non-volatile storage.
In an embodiment, the generating the intermediary model includes recording actions being performed, and using at least one of the recorded actions to generate the intermediary model.
In another embodiment, a system comprises, a model generator program configured to process an input program into an intermediary model comprising a user interface template and a code template comprising declaratives, the model generator program further configured to persist the intermediary model to provide for editing the intermediary model into a modified model, the modified model configured to be interpreted or compiled into an executable program.
In an embodiment, the model generator program is configured to be constructed with domain-specific data.
In an embodiment, the executable program is configured to receive input from one program or to provide output to another program, or to both receive input from one program and provide output to another program.
In an embodiment, the executable program is implemented as a component in a serial pipeline of components.
In an embodiment, the executable program is implemented as a component in a conditional workflow containing components.
In an embodiment, the modified model contains at least one conditional branch.
In an embodiment, the input program comprises a command line application.
In an embodiment, the model generator program reflects on a commandlet associated with the input program.
In an embodiment, the model generator program reflects on a module associated with the input program.
In an embodiment, the executable program inputs complex parameters.
In another embodiment, one or more computer-readable media having computer-executable instructions, which when executed perform steps, comprises, generating an intermediary model comprising a user interface template corresponding to a default user interface and a code template, and persisting a modified model that is based upon the intermediary model, in which the modified model includes at least one of: user interface data, one or more modified parameters, one or more flow conditions or one or more rules that is not specified in the intermediary model.
In an embodiment, further computer-executable instructions comprise, executing executable code corresponding to the modified model.
While the invention is susceptible to various modifications and alternative constructions, certain illustrated embodiments thereof are shown in the drawings and have been described above in detail. It should be understood, however, that there is no intention to limit the invention to the specific forms disclosed, but on the contrary, the intention is to cover all modifications, alternative constructions, and equivalents falling within the spirit and scope of the invention.
This application is a continuation of allowed U.S. application Ser. No. 13/802,612 filed on Mar. 13, 2013, titled “Executable Guidance Experiences Based on Implicitly Generated Guidance Models,” which is incorporated by reference herein in its entirety.
Number | Date | Country | |
---|---|---|---|
Parent | 13802612 | Mar 2013 | US |
Child | 15636318 | US |