WO2009029531A1 - Reusing components in a running application - Google Patents

Reusing components in a running application Download PDF

Info

Publication number
WO2009029531A1
WO2009029531A1 PCT/US2008/074059 US2008074059W WO2009029531A1 WO 2009029531 A1 WO2009029531 A1 WO 2009029531A1 US 2008074059 W US2008074059 W US 2008074059W WO 2009029531 A1 WO2009029531 A1 WO 2009029531A1
Authority
WO
WIPO (PCT)
Prior art keywords
reusable
component
reusable component
source application
application window
Prior art date
Application number
PCT/US2008/074059
Other languages
French (fr)
Inventor
Roger R. Webster
Original Assignee
Adobe Systems Incorporated
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 Adobe Systems Incorporated filed Critical Adobe Systems Incorporated
Priority to CN200880111163.XA priority Critical patent/CN101821714B/en
Publication of WO2009029531A1 publication Critical patent/WO2009029531A1/en

Links

Classifications

    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F8/00Arrangements for software engineering
    • G06F8/30Creation or generation of source code
    • G06F8/36Software reuse

Definitions

  • the present disclosure relates to identifying reusable components in an existing application, and to systems and methods for inserting a reusable component into a separate application, such as an application that is under development.
  • Object-oriented programming emphasizes concepts including encapsulation, inheritance, and modularity.
  • Specific purpose modules can be created using object-oriented techniques, such that the modules receive input from and/or provide output to one or more other modules. Additionally, separate modules in a program can be configured to communicate by passing data organized in accordance with constructs, such as classes, subclasses, and objects. Once created, such specific purpose modules can be reused in other programs by copying the source code and associated definitions.
  • Java further expanded the principles of object-oriented programming by introducing the concept of a virtual machine, which makes it possible to execute an application in a platform-independent environment.
  • the virtual machine exists as an environment above the operating system and the computing platform in which an application executes. Because a virtual machine can operate on a variety of computing platforms, an application can be executed in the virtual machine on any of the supported platforms without requiring customization. Thus, an application can be generated for use with a virtual machine such that the application is reusable across a variety of separate computing platforms.
  • IDEs integrated development environments
  • a programming tool can be used to prototype, code, debug, and maintain one or more software applications.
  • IDEs often include a graphical programming environment, in which features can be at least partially configured through the use of graphical tools.
  • IDEs also can include a palette of standard components, such as controls and displays, that can be inserted into an application without having to be independently developed. Additionally, IDEs provide the ability to analyze and modify an existing application for which the source code is available.
  • An existing application such as an application executing within the context of an application environment, can be configured to identify one or more reusable components included in the application. For example, a reusable component can be displayed such that it is visually distinguishable from the non-reusable components of an application, including through highlighting, low-lighting, outlining, shading, or any other such visual indication. Further, a reusable component can be inserted into a separate application that is being executed within the same application environment.
  • the application environment can be configured such that a reusable component included in an existing application, the source application, can be selected and transferred to a target application through a graphical user interface command, such as a drag-and-drop operation. Additionally, the reusable component can be automatically inserted into the target application in response to being "dropped" in a display space associated with the target application.
  • the present inventor recognized the need to permit switching a running application into a mode that facilitates reuse of one or more components. Further, the present inventor recognized the need to automatically insert instructions associated with a reusable component into the code of a target application into which the reusable component is transferred. In order to facilitate reuse of components, the present inventor recognized that it was beneficial to permit an application developer to designate a component as reusable, such as by setting a flag or variable to a particular value.
  • the present inventor also recognized the need to permit a developer to retain some level of control over the reusability of a component, including the ability to restrict the degree to which a component can be modified and to require that a license be taken in order to use the component. Further, the present inventor recognized the need to prevent a component from being reused. Accordingly, the systems and apparatus described here can implement methods for identifying and sharing one or more reusable components between a plurality of applications.
  • the subject matter can be implemented to include executing a source application in an application environment; presenting a reusable component in a source application window corresponding to the source application, wherein the reusable component is visibly distinguishable from one or more non-reusable components displayed in the source application window; receiving input selecting the reusable component in the source application window and adding the reusable component to a target application window corresponding to a target application; and inserting one or more computer-readable instructions associated with the reusable component into the target application.
  • the subject matter also can be implemented such that the received input comprises a drag-and-drop operation.
  • the subject matter further can be implemented to include receiving input activating a reuse function associated with the source application.
  • the subject matter can be implemented such that the reusable component is presented in the source application window only when the reuse function is active.
  • the subject matter can be implemented such that the reusable component is visibly distinguishable from one or more non-reusable components displayed in the source application window only when the reuse function is active.
  • the subject matter also can be implemented to include determining that a data input included in the reusable component is unassigned; identifying a second component in the target application window that includes an unassigned data output; and establishing in the target application a connection between the data input included in the reusable component and the data output included in the second component.
  • the subject matter further can be implemented to include receiving input from a user confirming the connection between the data input included in the reusable component and the data output included in the second component.
  • the subject matter can be implemented such that the reusable component is visibly distinguishable from one or more non-reusable components based on a display attribute associated with the reusable component comprising at least one of highlighting, shading, an enhanced border, and a glow effect.
  • the techniques can be implemented as a computer program product, encoded on a computer-readable medium, operable to cause data processing apparatus to perform operations comprising executing a source application in an application environment; presenting a reusable component in a source application window corresponding to the source application, wherein the reusable component is visibly distinguishable from one or more non-reusable components displayed in the source application window; receiving input selecting the reusable component in the source application window and adding the reusable component to a target application window corresponding to a target application; and inserting one or more computer-readable instructions associated with the reusable component into the target application.
  • the subject matter can be implemented such that the received input comprises a drag-and-drop operation.
  • the subject matter also can be implemented to be operable to cause data processing apparatus to perform operations comprising receiving input activating a reuse function associated with the source application.
  • the subject matter can be implemented such that the reusable component is presented in the source application window only when the reuse function is active.
  • the subject matter can be implemented such that the reusable component is visibly distinguishable from one or more non-reusable components displayed in the source application window only when the reuse function is active.
  • the subject matter also can be implemented to be further operable to cause data processing apparatus to perform operations comprising determining that a data input included in the reusable component is unassigned; identifying a second component in the target application window that includes an unassigned data output; and establishing in the target application a connection between the data input included in the reusable component and the data output included in the second component.
  • the subject matter can be implemented to be further operable to cause data processing apparatus to perform operations comprising receiving input from a user confirming the connection between the data input included in the reusable component and the data output included in the second component.
  • the subject matter further can be implemented such that the reusable component is visibly distinguishable from one or more non-reusable components based on a display attribute associated with the reusable component comprising at least one of highlighting, shading, an enhanced border, and a glow effect.
  • the subject matter can be implemented as a system including a source application stored on a computer-readable medium and a computing system including processor electronics configured to perform operations comprising executing the source application in an application environment; presenting a reusable component in a source application window corresponding to the source application, wherein the reusable component is visibly distinguishable from one or more non-reusable components displayed in the source application window; receiving input selecting the reusable component in the source application window and adding the reusable component to a target application window corresponding to a target application; and inserting one or more computer-readable instructions associated with the reusable component into the target application.
  • the subject matter also can be implemented such that the received input comprises a drag-and-drop operation. Further, the subject matter can be implemented such that the processor electronics are further configured to perform operations comprising receiving input activating a reuse function associated with the source application. Also, the subject matter can be implemented such that the reusable component is presented in the source application window only when the reuse function is active. Additionally, the subject matter can be implemented such that the reusable component is visibly distinguishable from one or more non-reusable components displayed in the source application window only when the reuse function is active.
  • the subject matter also can be implemented such that the processor electronics are further configured to perform operations comprising determining that a data input included in the reusable component is unassigned; identifying a second component in the target application window that includes an unassigned data output; and establishing in the target application a connection between the data input included in the reusable component and the data output included in the second component. Additionally, the subject matter can be implemented such that the processor electronics are further configured to perform operations comprising receiving input from a user confirming the connection between the data input included in the reusable component and the data output included in the second component. Further, the subject matter can be implemented such that the reusable component is visibly distinguishable from one or more non-reusable components based on a display attribute associated with the reusable component comprising at least one of highlighting, shading, an enhanced border, and a glow effect.
  • the subject matter can be implemented to transfer or otherwise copy a reusable component from a source application into a target application without having to manually access the source code associated with the reusable component.
  • the subject matter can be implemented such that a reusable component can be dragged from a running application and dropped into an application that is being developed, including new applications and applications that are being revised.
  • the subject matter also can be implemented to share both low-level components, such as controls, and high-level components, such as complex widgets and tools.
  • the subject matter can be implemented to permit restricting the degree to which a reusable component can be shared and modified, such as through licensing or "read-only" protections.
  • FIGS. IA- 1C show an exemplary interface that can be used to share one or more reusable components between two or more applications.
  • FIG. 2 shows a flowchart describing an exemplary process for inserting a reusable component into an application.
  • FIG. 3 shows an exemplary interface that can be used to share reusable components included in two or more applications.
  • FIG. 4 shows a flowchart describing an exemplary process for associating two reusable components in a target application.
  • FIG. 5 shows a computer-implemented method of reusing a component.
  • FIG. IA shows an exemplary interface that can be used to share one or more reusable components between two or more applications.
  • a reusable component is an element of a computer program, which includes one or more instructions that implement one or more functions, where the computer program component can be extracted from one application program and used again to construct a new application program.
  • An application from which a reusable component is shared is referred to as a source application and an application into which a reusable component is inserted is referred to as a target application.
  • the one or more source applications and one or more target applications between which reusable components can be shared are associated with a common application environment.
  • the application environment can be a cross-operating system runtime, such as Adobe® Integrated Runtime offered by Adobe Systems Incorporated of San Jose, California.
  • the interface can be presented in a graphical user interface ("GUI") environment, such as a desktop 100 presented by an operating system or the application environment.
  • GUI graphical user interface
  • the desktop 100 can be configured to permit launching one or more applications (or "computer programs"). Further, the desktop 100 can permit a user to interact with an application through one or more inputs and controls, including graphical controls. For example, a user can control a cursor 102 displayed in the desktop 100 through a physical input device, such as a mouse or trackball, and enter commands to perform one or more operations.
  • a source application executing in the application environment can be represented in the desktop 100 by a source application window 105.
  • the source application window 105 can include a command menu 110 that lists a plurality of commands associated with functions that can be performed by the source application.
  • the command menu 110 can include a plurality of menu titles, each of which corresponds to a list of one or more options and sub-menus.
  • the command menu 100 also can include one or more command buttons associated with specific functions, such as minimizing or closing the source application window 105. Further, the command menu 100 can be implemented as a reusable component.
  • the source application also can include a scroll bar 115 that allows for the selective display of the source application window 105.
  • the scroll bar 115 also can be implemented as a reusable component.
  • one or more other components associated with the source application can be displayed in the source application window 105.
  • a weather monitor 120 can be configured to display the current weather conditions for a particular region of the terrestrial globe.
  • the weather monitor 120 also can be configured to present other information, such as time, temperature, and forecast data.
  • the information presented by the weather monitor 120 can be collected from one or more data sources, including remote data sources.
  • a stock ticker 125 can be configured to present quotes for one or more securities or indexes.
  • the stock ticker 125 also can be configured to retrieve quote data from one or more data sources, including remote data sources.
  • a monitor 130 can be displayed in the source application window 105.
  • the monitor 130 can provide a graphical representation of the values associated with a data source.
  • the monitor 130 can provide a visual representation of sound being received through a microphone that is connected to the computing platform on which the source application is hosted or sound data stored in an electronic file.
  • a target application can be represented in the desktop 100 by a target application window 135.
  • the target application can be a newly created (or "blank") application that is being developed.
  • a blank application can be created by selecting a New Application option from a menu, such as a command menu 140.
  • a blank application also can be created by selecting a New Application option from a context menu, such as a menu displayed in response to right clicking in an existing application executing within the application environment or the desktop 100. Further, the blank application can be configured in accordance with an application template and then launched within the application environment as an executing application. Alternatively, the target application can be an existing application that is being modified.
  • any existing application can be modified unless it has been locked to prevent further modifications.
  • the command menu 140 can be configured to list a plurality of commands associated with functions that can be performed by the target application. If the target application is a newly created application, the command menu 140 can include standard functions, such as save, exit, and help. As functionality is added to the target application, such as through the addition of one or more components, the command menu 140 can be expanded to include options and sub-menus associated with the expanded functionality. In an implementation, the command menu 140 also can be modified through the use of an application development tool. FIG. IB shows an example of selecting the reuse menu 145 in the command menu
  • the reuse menu 145 can be selected by positioning the cursor 102 in proximity to the reuse menu 145 and entering a command through a physical control device, such as a button push on a mouse. Alternatively, the reuse menu 145 can be selected through entry of a predetermined command, such as a function key or key-combination on a keyboard.
  • the reuse menu 145 is configured to permit a user to turn the reuse function of the application on and off. Further, the reuse menu 145 presents a visual indicator to identify the presently selected menu option, such as a marker displayed adjacent to the selected option or by visually distinguishing the text used to represent the selected option. Alternatively, the reuse menu can be presented such that only the current option is displayed and selecting the current option causes it to be toggled (e.g., from "OFF" to "ON").
  • the source application When the reuse function is turned off, the source application performs routine operations, such as executing the functions associated with one or more components included in the source application.
  • routine operations such as executing the functions associated with one or more components included in the source application.
  • the reuse function When the reuse function is turned on, the source application identifies the components that are available for reuse.
  • a reusable component included in the source application can be identified through a wide variety of cues, including visual and/or auditory cues provided through the interface.
  • turning the reuse function on also enables the drag-and-drop functionality that can be used to insert a reusable component into a target application.
  • a source application can be configured such that turning on the reuse function inhibits interaction with reusable components for functions other than insertion into a target application.
  • command interfaces associated with a reusable component can be disabled.
  • selecting a button included in a reusable component will not produce a button "click" event or initiate the corresponding functionality that results when the reuse function is turned off.
  • interaction with non-reusable components included in a source application can be inhibited when the reuse function is turned on.
  • a movie player can be configured to continue playing, but associated controls such as pause and rewind can be disabled so that the movie player is inert.
  • FIG. 1C shows an exemplary interface presented in the desktop 100 when the reuse function is turned on.
  • a visual indicator can be associated with one or more reusable components to distinguish them from other portions of the source application, including components that are not reusable.
  • a visible border can be display around a reusable component, such as the border 150 displayed around the weather monitor 120 or the border 155 displayed around the monitor 130.
  • the visible border can be displayed to create a defined border around a reusable component that includes a different color or texture than the presentation of a non-reusable component included in the same window.
  • the visible border can be presented as a "glow” or "halo" effect that surrounds the reusable component.
  • the visible border can be displayed persistently, or can be displayed intermittently in response to an interface event, such as in response to a cursor coming within a predetermined range of a reusable component.
  • non-reusable components can be visually distinguished from reusable components by diminishing their visual presentation in the application window, such as by fading or graying the non-reusable components. Diminishing the visual presentation of non-reusable components can be performed in conjunction with or instead of enhancing the visual presentation of reusable components, such as through the use of a visible border.
  • Interface components and controls also can include a visible border if they are reusable.
  • the scroll bar 115 can include a visible border 160 to indicate that it is a reusable component.
  • interface components can be highlighted or shaded to indicate that they are reusable.
  • reusable components that generally do not have an associated visual presentation can be represented by an icon when the reuse function is turned on.
  • a database icon 165 can be presented in the source application window 105.
  • the database icon 165 can be used to represent a data source accessible to the source application that does not have a visual representation when the reuse function is turned off. Further, the database icon 165 can be presented with a visible border indicating that it is reusable.
  • a reusable component can be identified by a audible indicator in conjunction with a visual indicator. For example, a distinctive sound can be presented to identify a reusable component in response to an interface event, such as a cursor coming within a predetermined range of the reusable component.
  • a reusable component can be "grabbed" in the interface, such as through the use of a cursor controlled by a mouse. Once grabbed, the reusable component can be inserted into another application through a drag-and-drop operation.
  • the weather monitor 120 can be grabbed in the source application window 105 and dragged 170 across the interface to the target application window 135. By dropping the weather monitor 120 in the target application window 135, a new weather monitor 175 is inserted into the target application.
  • the weather monitor 175 generated through the drag-and-drop operation incorporates all of the functionality of the weather monitor 120 in the source application, including all of the presently selected configuration settings.
  • the weather monitor 175 inserted into the target application can be initialized to a state that corresponds to the state of the weather monitor 120 in the source application when the copy procedure began.
  • the weather monitor 175 inserted into the target application can be configured to present weather data for the same geographical area as the weather monitor 120 associated with the source application.
  • the functionality of the weather monitor 175 inserted into the target application also can be restricted in accordance with one or more limitations imposed by the developer of the reusable component. Unless restricted, however, the weather monitor 175 can be reconfigured in accordance with the requirements of the target application.
  • a new component generated by inserting a reusable component into a target application can be initialized into a default state, either automatically or in response to input from a user. For example, all of the configuration settings associated with the reusable component can be initialized to default values.
  • a reusable component can be manipulated after it has been inserted into the target application.
  • the weather monitor 175 can be resized, moved, or deleted once it is displayed in the target application window 135.
  • a target application can be modified using one or more development tools, such as by opening or accessing the target application in an IDE.
  • a target application that has been populated with one or more reusable components can be opened as a project in an IDE.
  • a menu item can be selected to generate a project from the target application that can be opened in an IDE.
  • code corresponding to one or more components included in the target application can be converted, such as into a markup language or ActionScript, to generate a project.
  • source code can be automatically retrieved for one or more components included in a target application when the application is opened as a project.
  • a source code pointer included in a component such as a URL, can be accessed to retrieve corresponding source code.
  • the binary form of the component can be used in the IDE.
  • FIG. 2 shows a flowchart describing an exemplary process for inserting a reusable component into an application.
  • a reuse option can be selected in a running application to permit identifying and sharing the reusable components included in that application (205).
  • a reusable component can be shared from a running application only when the reuse option has been selected.
  • the reusable components included in the running application are identified (210).
  • the application is configured to visual identify each reusable component and to permit each reusable component to be shared with a separate application, such as through a drag-and- drop operation.
  • the components included in the running application can be polled to determine whether they implement reusability. Alternatively, a record of reusable components maintained by the application can be accessed.
  • a component is identified as reusable through a class definition associated with the component. For example, a standard button can belong to the class Button. Further, a developer can create a new sub-class identified as MyButton that extends the class Button. Additionally, the subclass MyButton can include an interface named Reusable.
  • a component belonging to the sub-class MyButton can include a reference to the interface, such as "implement Reusable", to indicate that the component is reusable.
  • the sub-class MyButton can include a reusability flag, such as a Boolean value that indicates the reusability status.
  • a reusable component further can be identified to a user through the presentation of a visual identifier associated with the component, such as highlighting, shading, or a visible border.
  • a reusable component also can be identified by an audible identifier.
  • a component that does not have an associated visual representation in the application window when reuse is not selected can be represented by an object, such as an icon that includes the visual identifier indicating reusability, when reuse is selected.
  • a user can visually identify all of the reusable components included in an application when a reuse option corresponding to that application has been selected.
  • both low-level components and high-level components can be identified as reusable.
  • low-level interface devices such as buttons, panels, scroll bars, and text boxes can be reused.
  • high-level components including specialized widgets and small applications, also can be reused.
  • one or more components not typically available in the palette of a development tool, such as complex and customized components, can be reused from an existing application.
  • a copy operation associated with a reusable component can be identified while the source application is running (215). For example, a user can initiate a copy operation by selecting a reusable component included in the source application. Further, the reusable component can be transferred to a target application window through a drag-and-drop operation. Alternatively, one or more other transfer operations also can be performed, such as a copy-and-paste operation or a cut-and-paste operation.
  • the target application can be polled to determine whether it is locked (220). For example, a target application can be set to readonly or can be configured to require authorization before it can be modified. If the target application is locked, the copy operation is canceled (225).
  • the reusable component can be accessed to determined whether it includes a source code pointer (230). For example, the binary code associated with a reusable component can be copied from the source application during the copy operation. Further, the binary code can be analyzed to determine whether it includes an embedded pointer that identifies a location at which the full source code for the reusable component can be obtained, such as a web site. If a source code pointer is included, the source code can be retrieved (235). Otherwise, the binary code associated with the reusable component is utilized.
  • Any restrictions associated with the reusable component also are identified (240). If one or more restrictions are associated with the reusable component, the restrictions are implemented (245).
  • the developer or owner of the reusable component can require that one or more conditions for reuse be met, which can be included in the code corresponding to the reusable component. For example, the reusable component can be classified as "read-only", such that no further modifications to the reusable component can be made.
  • a license also can be required before full use of the reusable component is authorized.
  • a reusable component can be licensed for use with a particular application. When the reusable component is invoked, it can determine which application it is operating in and whether it is licensed for use with that application.
  • a reusable component determines that it is not associated with a licensed application, the reusable component can operate in a trial or demonstration mode.
  • a restricted reusable component also can identify instructions for obtaining a license, such as a source from which a full license can be purchased. Further, the reusable component can display a message indicating that it is in trial mode and/or provide only limited functionality.
  • the reusable component can be initialized in the target application (250).
  • a copy of the reusable component included in the source application is created and initialized, to the extent permitted, in the target application.
  • a reusable component can be associated with a library file, which can be accessed by the target application.
  • a reusable component can include a property that identifies the library file with which it is associated. Alternatively, if the reusable component corresponds only to the target application, the property can have a null value.
  • the reusable component also can be executed. A reusable component is copied, to the extent permitted, as a complete component.
  • FIG. 3 shows an exemplary interface that can be used to share reusable components included in two or more applications.
  • a plurality of applications are presented in a GUI environment, such as a desktop 300 presented by an operating system or an application execution environment.
  • a first source application window 305 associated with a first source application includes a bar graph interface 310 that is configured to present information in a graphical format.
  • the first source application window 305 also includes a world wide web icon 315, which represents a data source for the information presented in the bar graph interface 310.
  • the bar graph interface 310 and the world wide web icon 315 can be displayed in conjunction with visual indicators 312 and 317 respectively, to indicate that they are reusable components.
  • a second source application window 320 associated with a second source application includes a meter interface 325 that is configured to present information in a graphical format.
  • the second source application window 320 also includes a database icon 330, which represents a data source for the information presented in the meter interface 325.
  • the meter interface 325 and the database icon 330 can be displayed in conjunction with visual indicators 327 and 332 respectively, to indicate that they are reusable components.
  • a target application window 335 can be displayed in the desktop 300.
  • the target application window 335 can be associated with a new application or an existing application for which modification is permitted.
  • the bar graph interface 310 included in the first source application window 305 can be inserted into the target application window 335 through a drag-and-drop operation 340.
  • a new bar graph interface 350 is created in the target application.
  • the database icon 330 included in the second source application window 320 can be inserted into the target application window 335 through a drag-and-drop operation 345.
  • a new data source 355 corresponding to the database represented by the database icon 330 is created in the target application.
  • the target application can be configured to detect that the bar graph interface 350 includes an input for which a data source has not been specified.
  • the target application also can determine that the data source 355 includes a data output that is not associated with a corresponding data input in the target application.
  • the target application can prompt the user to indicate whether the output of the data source 355 is to be connected to the input of the bar graph interface 350.
  • the target application can be configured to automatically form a connection between a component that includes an unassigned data output and a component that includes an unassigned data input.
  • the output of the data source 355 can be automatically connected to the input of the bar graph interface 350.
  • a user can specify a desired connection between a first component, with a data output, and a second component with a data input, such as by dropping the first component onto the second component.
  • FIG. 4 shows a flowchart describing an exemplary process for associating two reusable components in a target application.
  • a reusable component including an unassigned data input is received in the target application (405).
  • a reusable component including an unassigned data output also is received in the target application (410).
  • the reusable components including the unassigned data input and the unassigned data output can be received in any order. Further, one or more intervening components, or other items, can be received in the target application between receipt of the reusable component including the unassigned data input and receipt of the reusable component including the unassigned data output. Additionally, any period of time can elapse between receipt of the reusable components including the unassigned data input and the unassigned data output.
  • the target application detects the reusable component that includes the unassigned data input and the reusable component that includes the unassigned data output (415).
  • the target application queries the user to determine whether the unassigned data output should be connected to the unassigned data input (420).
  • the target application can be configured to present a prompt to the user asking whether output from a first reusable component should be provided as input to a second reusable component. If the user confirms, a connection between the reusable components is formed (425).
  • a connection is not made and the target application continues to operate until an additional reusable component is received (430).
  • the target application determines whether the additional reusable component includes an unassigned input or output (435). If the additional reusable component includes an unassigned input or output, the target application queries the user to determine whether a connection should be formed (420). Otherwise, the target application continues to operate until another reusable component is received (430).
  • the target application can be configured to permit a user to reconfigure connections between two components and to form connections between two or more components.
  • the target application can be configured to automatically form a connection between a reusable component that includes an unassigned data input and a reusable component that includes an unassigned data output. Further, the target application can be configured to prompt the user to confirm that the connection is correct.
  • FIG. 5 shows a computer-implemented method of reusing a component.
  • a source application is executed in an application environment (505).
  • a reusable component is presented in a source application window corresponding to the source application, wherein the reusable component is visibly distinguishable from one or more non-reusable components displayed in the source application window (510).
  • Input is received selecting the reusable component in the source application window and adding the reusable component to a target application window corresponding to a target application (515).
  • one or more computer-readable instructions associated with the reusable component are inserted into the target application (520).
  • Embodiments of the subject matter and the functional operations described in this specification can be implemented in digital electronic circuitry, or in computer software, firmware, or hardware, including the structures disclosed in this specification and their structural equivalents, or in combinations of one or more of them.
  • Embodiments of the subject matter described in this specification can be implemented as one or more computer program products, i.e., one or more modules of computer program instructions encoded on a computer-readable medium for execution by, or to control the operation of, data processing apparatus.
  • the computer-readable medium can be a machine-readable storage device, a machine-readable storage substrate, a memory device, a composition of matter effecting a machine-readable propagated signal, or a combination of one or more of them.
  • data processing apparatus encompasses all apparatus, devices, and machines for processing data, including by way of example a programmable processor, a computer, or multiple processors or computers.
  • the apparatus can include, in addition to hardware, code that creates an execution environment for the computer program in question, e.g., code that constitutes processor firmware, a protocol stack, a database management system, an operating system, or a combination of one or more of them.
  • a propagated signal is an artificially generated signal, e.g., a machine-generated electrical, optical, or electromagnetic signal, that is generated to encode information for transmission to suitable receiver apparatus.
  • a computer program (also known as a program, software, software application, script, or code) can be written in any form of programming language, including compiled or interpreted languages, and it can be deployed in any form, including as a stand-alone program or as a module, component, subroutine, or other unit suitable for use in a computing environment.
  • a computer program does not necessarily correspond to a file in a file system.
  • a program can be stored in a portion of a file that holds other programs or data (e.g., one or more scripts stored in a markup language document), in a single file dedicated to the program in question, or in multiple coordinated files (e.g., files that store one or more modules, sub-programs, or portions of code).
  • a computer program can be deployed to be executed on one computer or on multiple computers that are located at one site or distributed across multiple sites and interconnected by a communication network.
  • the processes and logic flows described in this specification can be performed by one or more programmable processors executing one or more computer programs to perform functions by operating on input data and generating output.
  • the processes and logic flows can also be performed by, and apparatus can also be implemented as, special purpose logic circuitry, e.g., an FPGA (field programmable gate array) or an ASIC (application-specific integrated circuit).
  • processors suitable for the execution of a computer program include, by way of example, both general and special purpose microprocessors, and any one or more processors of any kind of digital computer.
  • a processor will receive instructions and data from a read-only memory or a random access memory or both.
  • the essential elements of a computer are a processor for performing instructions and one or more memory devices for storing instructions and data.
  • a computer will also include, or be operatively coupled to receive data from or transfer data to, or both, one or more mass storage devices for storing data, e.g., magnetic, magneto-optical disks, or optical disks.
  • mass storage devices for storing data, e.g., magnetic, magneto-optical disks, or optical disks.
  • a computer need not have such devices.
  • a computer can be embedded in another device, e.g., a mobile telephone, a personal digital assistant (PDA), a mobile audio player, a Global Positioning System (GPS) receiver, to name just a few.
  • Computer-readable media suitable for storing computer program instructions and data include all forms of non- volatile memory, media and memory devices, including by way of example semiconductor memory devices, e.g., EPROM, EEPROM, and flash memory devices; magnetic disks, e.g., internal hard disks or removable disks; magneto-optical disks; and CD-ROM and DVD-ROM disks.
  • the processor and the memory can be supplemented by, or incorporated in, special purpose logic circuitry.
  • embodiments of the subject matter described in this specification can be implemented on a computer having a display device, e.g., a CRT (cathode ray tube) or LCD (liquid crystal display) monitor, for displaying information to the user and a keyboard and a pointing device, e.g., a mouse or a trackball, by which the user can provide input to the computer.
  • a display device e.g., a CRT (cathode ray tube) or LCD (liquid crystal display) monitor
  • keyboard and a pointing device e.g., a mouse or a trackball
  • Other kinds of devices can be used to provide for interaction with a user as well; for example, feedback provided to the user can be any form of sensory feedback, e.g., visual feedback, auditory feedback, or tactile feedback; and input from the user can be received in any form, including acoustic, speech, or tactile input.
  • Embodiments of the subject matter described in this specification can be implemented in a computing system that includes a back-end component, e.g., as a data server, or that includes a middleware component, e.g., an application server, or that includes a front-end component, e.g., a client computer having a graphical user interface or a Web browser through which a user can interact with an implementation of the subject matter described is this specification, or any combination of one or more such back-end, middleware, or front-end components.
  • the components of the system can be interconnected by any form or medium of digital data communication, e.g., a communication network. Examples of communication networks include a local area network (“LAN”) and a wide area network (“WAN”), e.g., the Internet.
  • LAN local area network
  • WAN wide area network
  • the computing system can include clients and servers.
  • a client and server are generally remote from each other and typically interact through a communication network.
  • the relationship of client and server arises by virtue of computer programs running on the respective computers and having a client-server relationship to each other.

Abstract

Methods, systems, and apparatus, including computer program products, for reusing a component. In one aspect, a method includes executing a source application in an application environment; presenting a reusable component in a source application window corresponding to the source application, wherein the reusable component is visibly distinguishable from one or more non-reusable components displayed in the source application window; receiving input selecting the reusable component in the source application window and adding the reusable component to a target application window corresponding to a target application; and inserting one or more computer-readable instructions associated with the reusable component into the target application. Further, input can be received to activate a reuse function associated with the source application. Additionally, the reusable component can be visibly distinguishable from one or more non-reusable components displayed in the source application window only when the reuse function is active.

Description

REUSING COMPONENTS IN A RUNNING APPLICATION
BACKGROUND
The present disclosure relates to identifying reusable components in an existing application, and to systems and methods for inserting a reusable component into a separate application, such as an application that is under development.
The development of software applications has seen many advances since the inception of computing. For example, low-level languages utilized constructs that were very closely related to the hardware of the computing system on which programs were executed. The creation of high-level programming languages provided tools that were more abstract than corresponding low-level programming languages and delivered greater portability across different platforms. High-level programming languages also permitted programmers to express operations in terms of variables, mathematical formulas, and Boolean expressions, rather than memory addresses and registers.
The development of object-oriented programming concepts and object-oriented languages, such as C++, further permitted programmers to modularize software applications.
Object-oriented programming emphasizes concepts including encapsulation, inheritance, and modularity. Specific purpose modules can be created using object-oriented techniques, such that the modules receive input from and/or provide output to one or more other modules. Additionally, separate modules in a program can be configured to communicate by passing data organized in accordance with constructs, such as classes, subclasses, and objects. Once created, such specific purpose modules can be reused in other programs by copying the source code and associated definitions.
Java further expanded the principles of object-oriented programming by introducing the concept of a virtual machine, which makes it possible to execute an application in a platform-independent environment. Once configured, the virtual machine exists as an environment above the operating system and the computing platform in which an application executes. Because a virtual machine can operate on a variety of computing platforms, an application can be executed in the virtual machine on any of the supported platforms without requiring customization. Thus, an application can be generated for use with a virtual machine such that the application is reusable across a variety of separate computing platforms.
Programming tools, or integrated development environments (IDEs), still further enhanced the ability of programmers to efficiently develop software applications. A programming tool can be used to prototype, code, debug, and maintain one or more software applications. Further, IDEs often include a graphical programming environment, in which features can be at least partially configured through the use of graphical tools. IDEs also can include a palette of standard components, such as controls and displays, that can be inserted into an application without having to be independently developed. Additionally, IDEs provide the ability to analyze and modify an existing application for which the source code is available.
SUMMARY This specification describes technologies relating to reusing one or more components included in an existing application. An existing application, such as an application executing within the context of an application environment, can be configured to identify one or more reusable components included in the application. For example, a reusable component can be displayed such that it is visually distinguishable from the non-reusable components of an application, including through highlighting, low-lighting, outlining, shading, or any other such visual indication. Further, a reusable component can be inserted into a separate application that is being executed within the same application environment. The application environment can be configured such that a reusable component included in an existing application, the source application, can be selected and transferred to a target application through a graphical user interface command, such as a drag-and-drop operation. Additionally, the reusable component can be automatically inserted into the target application in response to being "dropped" in a display space associated with the target application.
The present inventor recognized the need to permit switching a running application into a mode that facilitates reuse of one or more components. Further, the present inventor recognized the need to automatically insert instructions associated with a reusable component into the code of a target application into which the reusable component is transferred. In order to facilitate reuse of components, the present inventor recognized that it was beneficial to permit an application developer to designate a component as reusable, such as by setting a flag or variable to a particular value.
The present inventor also recognized the need to permit a developer to retain some level of control over the reusability of a component, including the ability to restrict the degree to which a component can be modified and to require that a license be taken in order to use the component. Further, the present inventor recognized the need to prevent a component from being reused. Accordingly, the systems and apparatus described here can implement methods for identifying and sharing one or more reusable components between a plurality of applications.
In general, in one aspect, the subject matter can be implemented to include executing a source application in an application environment; presenting a reusable component in a source application window corresponding to the source application, wherein the reusable component is visibly distinguishable from one or more non-reusable components displayed in the source application window; receiving input selecting the reusable component in the source application window and adding the reusable component to a target application window corresponding to a target application; and inserting one or more computer-readable instructions associated with the reusable component into the target application.
The subject matter also can be implemented such that the received input comprises a drag-and-drop operation. The subject matter further can be implemented to include receiving input activating a reuse function associated with the source application. Also, the subject matter can be implemented such that the reusable component is presented in the source application window only when the reuse function is active. Additionally, the subject matter can be implemented such that the reusable component is visibly distinguishable from one or more non-reusable components displayed in the source application window only when the reuse function is active.
The subject matter also can be implemented to include determining that a data input included in the reusable component is unassigned; identifying a second component in the target application window that includes an unassigned data output; and establishing in the target application a connection between the data input included in the reusable component and the data output included in the second component. The subject matter further can be implemented to include receiving input from a user confirming the connection between the data input included in the reusable component and the data output included in the second component. Additionally, the subject matter can be implemented such that the reusable component is visibly distinguishable from one or more non-reusable components based on a display attribute associated with the reusable component comprising at least one of highlighting, shading, an enhanced border, and a glow effect. In general, in another aspect, the techniques can be implemented as a computer program product, encoded on a computer-readable medium, operable to cause data processing apparatus to perform operations comprising executing a source application in an application environment; presenting a reusable component in a source application window corresponding to the source application, wherein the reusable component is visibly distinguishable from one or more non-reusable components displayed in the source application window; receiving input selecting the reusable component in the source application window and adding the reusable component to a target application window corresponding to a target application; and inserting one or more computer-readable instructions associated with the reusable component into the target application.
Further, the subject matter can be implemented such that the received input comprises a drag-and-drop operation. The subject matter also can be implemented to be operable to cause data processing apparatus to perform operations comprising receiving input activating a reuse function associated with the source application. Also, the subject matter can be implemented such that the reusable component is presented in the source application window only when the reuse function is active. Additionally, the subject matter can be implemented such that the reusable component is visibly distinguishable from one or more non-reusable components displayed in the source application window only when the reuse function is active. The subject matter also can be implemented to be further operable to cause data processing apparatus to perform operations comprising determining that a data input included in the reusable component is unassigned; identifying a second component in the target application window that includes an unassigned data output; and establishing in the target application a connection between the data input included in the reusable component and the data output included in the second component. Additionally, the subject matter can be implemented to be further operable to cause data processing apparatus to perform operations comprising receiving input from a user confirming the connection between the data input included in the reusable component and the data output included in the second component. The subject matter further can be implemented such that the reusable component is visibly distinguishable from one or more non-reusable components based on a display attribute associated with the reusable component comprising at least one of highlighting, shading, an enhanced border, and a glow effect.
In general, in another aspect, the subject matter can be implemented as a system including a source application stored on a computer-readable medium and a computing system including processor electronics configured to perform operations comprising executing the source application in an application environment; presenting a reusable component in a source application window corresponding to the source application, wherein the reusable component is visibly distinguishable from one or more non-reusable components displayed in the source application window; receiving input selecting the reusable component in the source application window and adding the reusable component to a target application window corresponding to a target application; and inserting one or more computer-readable instructions associated with the reusable component into the target application.
The subject matter also can be implemented such that the received input comprises a drag-and-drop operation. Further, the subject matter can be implemented such that the processor electronics are further configured to perform operations comprising receiving input activating a reuse function associated with the source application. Also, the subject matter can be implemented such that the reusable component is presented in the source application window only when the reuse function is active. Additionally, the subject matter can be implemented such that the reusable component is visibly distinguishable from one or more non-reusable components displayed in the source application window only when the reuse function is active.
The subject matter also can be implemented such that the processor electronics are further configured to perform operations comprising determining that a data input included in the reusable component is unassigned; identifying a second component in the target application window that includes an unassigned data output; and establishing in the target application a connection between the data input included in the reusable component and the data output included in the second component. Additionally, the subject matter can be implemented such that the processor electronics are further configured to perform operations comprising receiving input from a user confirming the connection between the data input included in the reusable component and the data output included in the second component. Further, the subject matter can be implemented such that the reusable component is visibly distinguishable from one or more non-reusable components based on a display attribute associated with the reusable component comprising at least one of highlighting, shading, an enhanced border, and a glow effect.
Particular embodiments of the subject matter described in this specification can be implemented to realize one or more of the following advantages. For example, the subject matter can be implemented to transfer or otherwise copy a reusable component from a source application into a target application without having to manually access the source code associated with the reusable component. Further, the subject matter can be implemented such that a reusable component can be dragged from a running application and dropped into an application that is being developed, including new applications and applications that are being revised. The subject matter also can be implemented to share both low-level components, such as controls, and high-level components, such as complex widgets and tools. Additionally, the subject matter can be implemented to permit restricting the degree to which a reusable component can be shared and modified, such as through licensing or "read-only" protections.
This subject matter can be implemented using an apparatus, a method, a system, a computer program product, or any combination of an apparatus, methods, systems, and computer program products. The details of one or more embodiments of the invention are set forth in the accompanying drawings and the description below. Other features, aspects, and advantages of the invention will become apparent from the description, the drawings, and the claims.
BRIEF DESCRIPTION OF THE DRAWINGS
FIGS. IA- 1C show an exemplary interface that can be used to share one or more reusable components between two or more applications.
FIG. 2 shows a flowchart describing an exemplary process for inserting a reusable component into an application. FIG. 3 shows an exemplary interface that can be used to share reusable components included in two or more applications.
FIG. 4 shows a flowchart describing an exemplary process for associating two reusable components in a target application.
FIG. 5 shows a computer-implemented method of reusing a component. Like reference numbers and designations in the various drawings indicate like elements.
DETAILED DESCRIPTION
FIG. IA shows an exemplary interface that can be used to share one or more reusable components between two or more applications. A reusable component is an element of a computer program, which includes one or more instructions that implement one or more functions, where the computer program component can be extracted from one application program and used again to construct a new application program. An application from which a reusable component is shared is referred to as a source application and an application into which a reusable component is inserted is referred to as a target application. Further, the one or more source applications and one or more target applications between which reusable components can be shared are associated with a common application environment. In an implementation, the application environment can be a cross-operating system runtime, such as Adobe® Integrated Runtime offered by Adobe Systems Incorporated of San Jose, California.
The interface can be presented in a graphical user interface ("GUI") environment, such as a desktop 100 presented by an operating system or the application environment. The desktop 100 can be configured to permit launching one or more applications (or "computer programs"). Further, the desktop 100 can permit a user to interact with an application through one or more inputs and controls, including graphical controls. For example, a user can control a cursor 102 displayed in the desktop 100 through a physical input device, such as a mouse or trackball, and enter commands to perform one or more operations. A source application executing in the application environment can be represented in the desktop 100 by a source application window 105. The source application window 105 can include a command menu 110 that lists a plurality of commands associated with functions that can be performed by the source application. For example, the command menu 110 can include a plurality of menu titles, each of which corresponds to a list of one or more options and sub-menus. The command menu 100 also can include one or more command buttons associated with specific functions, such as minimizing or closing the source application window 105. Further, the command menu 100 can be implemented as a reusable component.
The source application also can include a scroll bar 115 that allows for the selective display of the source application window 105. The scroll bar 115 also can be implemented as a reusable component. Additionally, one or more other components associated with the source application can be displayed in the source application window 105. For example, a weather monitor 120 can be configured to display the current weather conditions for a particular region of the terrestrial globe. The weather monitor 120 also can be configured to present other information, such as time, temperature, and forecast data. The information presented by the weather monitor 120 can be collected from one or more data sources, including remote data sources. Further, a stock ticker 125 can be configured to present quotes for one or more securities or indexes. Similar to the weather monitor 120, the stock ticker 125 also can be configured to retrieve quote data from one or more data sources, including remote data sources. Additionally, a monitor 130 can be displayed in the source application window 105. The monitor 130 can provide a graphical representation of the values associated with a data source. For example, the monitor 130 can provide a visual representation of sound being received through a microphone that is connected to the computing platform on which the source application is hosted or sound data stored in an electronic file. A target application can be represented in the desktop 100 by a target application window 135. The target application can be a newly created (or "blank") application that is being developed. In an implementation, a blank application can be created by selecting a New Application option from a menu, such as a command menu 140. A blank application also can be created by selecting a New Application option from a context menu, such as a menu displayed in response to right clicking in an existing application executing within the application environment or the desktop 100. Further, the blank application can be configured in accordance with an application template and then launched within the application environment as an executing application. Alternatively, the target application can be an existing application that is being modified.
In an implementation, any existing application can be modified unless it has been locked to prevent further modifications. The command menu 140 can be configured to list a plurality of commands associated with functions that can be performed by the target application. If the target application is a newly created application, the command menu 140 can include standard functions, such as save, exit, and help. As functionality is added to the target application, such as through the addition of one or more components, the command menu 140 can be expanded to include options and sub-menus associated with the expanded functionality. In an implementation, the command menu 140 also can be modified through the use of an application development tool. FIG. IB shows an example of selecting the reuse menu 145 in the command menu
110 of the source application window 105. The reuse menu 145 can be selected by positioning the cursor 102 in proximity to the reuse menu 145 and entering a command through a physical control device, such as a button push on a mouse. Alternatively, the reuse menu 145 can be selected through entry of a predetermined command, such as a function key or key-combination on a keyboard. The reuse menu 145 is configured to permit a user to turn the reuse function of the application on and off. Further, the reuse menu 145 presents a visual indicator to identify the presently selected menu option, such as a marker displayed adjacent to the selected option or by visually distinguishing the text used to represent the selected option. Alternatively, the reuse menu can be presented such that only the current option is displayed and selecting the current option causes it to be toggled (e.g., from "OFF" to "ON").
When the reuse function is turned off, the source application performs routine operations, such as executing the functions associated with one or more components included in the source application. When the reuse function is turned on, the source application identifies the components that are available for reuse. A reusable component included in the source application can be identified through a wide variety of cues, including visual and/or auditory cues provided through the interface. In an implementation, turning the reuse function on also enables the drag-and-drop functionality that can be used to insert a reusable component into a target application. Further, a source application can be configured such that turning on the reuse function inhibits interaction with reusable components for functions other than insertion into a target application. For example, when the reuse function is turned on in a source application, command interfaces associated with a reusable component can be disabled. Thus, selecting a button included in a reusable component will not produce a button "click" event or initiate the corresponding functionality that results when the reuse function is turned off. Additionally, interaction with non-reusable components included in a source application can be inhibited when the reuse function is turned on. For example, a movie player can be configured to continue playing, but associated controls such as pause and rewind can be disabled so that the movie player is inert. FIG. 1C shows an exemplary interface presented in the desktop 100 when the reuse function is turned on. A visual indicator can be associated with one or more reusable components to distinguish them from other portions of the source application, including components that are not reusable. For example, a visible border can be display around a reusable component, such as the border 150 displayed around the weather monitor 120 or the border 155 displayed around the monitor 130. The visible border can be displayed to create a defined border around a reusable component that includes a different color or texture than the presentation of a non-reusable component included in the same window. Alternatively, the visible border can be presented as a "glow" or "halo" effect that surrounds the reusable component. Further, the visible border can be displayed persistently, or can be displayed intermittently in response to an interface event, such as in response to a cursor coming within a predetermined range of a reusable component. In an implementation, non-reusable components can be visually distinguished from reusable components by diminishing their visual presentation in the application window, such as by fading or graying the non-reusable components. Diminishing the visual presentation of non-reusable components can be performed in conjunction with or instead of enhancing the visual presentation of reusable components, such as through the use of a visible border. Interface components and controls also can include a visible border if they are reusable. For example, the scroll bar 115 can include a visible border 160 to indicate that it is a reusable component. Alternatively, interface components can be highlighted or shaded to indicate that they are reusable.
Additionally, reusable components that generally do not have an associated visual presentation can be represented by an icon when the reuse function is turned on. For example, when reuse is turned on through the reuse menu 145 of the source application, a database icon 165 can be presented in the source application window 105. The database icon 165 can be used to represent a data source accessible to the source application that does not have a visual representation when the reuse function is turned off. Further, the database icon 165 can be presented with a visible border indicating that it is reusable. In some implementations, a reusable component can be identified by a audible indicator in conjunction with a visual indicator. For example, a distinctive sound can be presented to identify a reusable component in response to an interface event, such as a cursor coming within a predetermined range of the reusable component.
A reusable component can be "grabbed" in the interface, such as through the use of a cursor controlled by a mouse. Once grabbed, the reusable component can be inserted into another application through a drag-and-drop operation. For example, the weather monitor 120 can be grabbed in the source application window 105 and dragged 170 across the interface to the target application window 135. By dropping the weather monitor 120 in the target application window 135, a new weather monitor 175 is inserted into the target application.
The weather monitor 175 generated through the drag-and-drop operation incorporates all of the functionality of the weather monitor 120 in the source application, including all of the presently selected configuration settings. Thus, the weather monitor 175 inserted into the target application can be initialized to a state that corresponds to the state of the weather monitor 120 in the source application when the copy procedure began. For example, the weather monitor 175 inserted into the target application can be configured to present weather data for the same geographical area as the weather monitor 120 associated with the source application.
In some implementations, the functionality of the weather monitor 175 inserted into the target application also can be restricted in accordance with one or more limitations imposed by the developer of the reusable component. Unless restricted, however, the weather monitor 175 can be reconfigured in accordance with the requirements of the target application. In other implementations, a new component generated by inserting a reusable component into a target application can be initialized into a default state, either automatically or in response to input from a user. For example, all of the configuration settings associated with the reusable component can be initialized to default values.
Additionally, a reusable component can be manipulated after it has been inserted into the target application. For example, the weather monitor 175 can be resized, moved, or deleted once it is displayed in the target application window 135. Further, a target application can be modified using one or more development tools, such as by opening or accessing the target application in an IDE. For example, a target application that has been populated with one or more reusable components can be opened as a project in an IDE. In an implementation, a menu item can be selected to generate a project from the target application that can be opened in an IDE.
Further, code corresponding to one or more components included in the target application can be converted, such as into a markup language or ActionScript, to generate a project. In some implementations, source code can be automatically retrieved for one or more components included in a target application when the application is opened as a project. For example, a source code pointer included in a component, such as a URL, can be accessed to retrieve corresponding source code. Alternatively, if a source code pointer is not available, the binary form of the component can be used in the IDE.
FIG. 2 shows a flowchart describing an exemplary process for inserting a reusable component into an application. A reuse option can be selected in a running application to permit identifying and sharing the reusable components included in that application (205). In some implementations, a reusable component can be shared from a running application only when the reuse option has been selected.
Further, the reusable components included in the running application are identified (210). The application is configured to visual identify each reusable component and to permit each reusable component to be shared with a separate application, such as through a drag-and- drop operation. The components included in the running application can be polled to determine whether they implement reusability. Alternatively, a record of reusable components maintained by the application can be accessed. In an implementation, a component is identified as reusable through a class definition associated with the component. For example, a standard button can belong to the class Button. Further, a developer can create a new sub-class identified as MyButton that extends the class Button. Additionally, the subclass MyButton can include an interface named Reusable. Thus, a component belonging to the sub-class MyButton can include a reference to the interface, such as "implement Reusable", to indicate that the component is reusable. Alternatively, the sub-class MyButton can include a reusability flag, such as a Boolean value that indicates the reusability status. A reusable component further can be identified to a user through the presentation of a visual identifier associated with the component, such as highlighting, shading, or a visible border. A reusable component also can be identified by an audible identifier. Further, a component that does not have an associated visual representation in the application window when reuse is not selected can be represented by an object, such as an icon that includes the visual identifier indicating reusability, when reuse is selected. Thus, a user can visually identify all of the reusable components included in an application when a reuse option corresponding to that application has been selected. Additionally, both low-level components and high-level components can be identified as reusable. For example, low-level interface devices, such as buttons, panels, scroll bars, and text boxes can be reused. Further, high-level components, including specialized widgets and small applications, also can be reused. Thus, one or more components not typically available in the palette of a development tool, such as complex and customized components, can be reused from an existing application.
A copy operation associated with a reusable component can be identified while the source application is running (215). For example, a user can initiate a copy operation by selecting a reusable component included in the source application. Further, the reusable component can be transferred to a target application window through a drag-and-drop operation. Alternatively, one or more other transfer operations also can be performed, such as a copy-and-paste operation or a cut-and-paste operation. The target application can be polled to determine whether it is locked (220). For example, a target application can be set to readonly or can be configured to require authorization before it can be modified. If the target application is locked, the copy operation is canceled (225). If the target application is not locked, the reusable component can be accessed to determined whether it includes a source code pointer (230). For example, the binary code associated with a reusable component can be copied from the source application during the copy operation. Further, the binary code can be analyzed to determine whether it includes an embedded pointer that identifies a location at which the full source code for the reusable component can be obtained, such as a web site. If a source code pointer is included, the source code can be retrieved (235). Otherwise, the binary code associated with the reusable component is utilized.
Any restrictions associated with the reusable component also are identified (240). If one or more restrictions are associated with the reusable component, the restrictions are implemented (245). The developer or owner of the reusable component can require that one or more conditions for reuse be met, which can be included in the code corresponding to the reusable component. For example, the reusable component can be classified as "read-only", such that no further modifications to the reusable component can be made. A license also can be required before full use of the reusable component is authorized. For example, a reusable component can be licensed for use with a particular application. When the reusable component is invoked, it can determine which application it is operating in and whether it is licensed for use with that application. If a reusable component determines that it is not associated with a licensed application, the reusable component can operate in a trial or demonstration mode. A restricted reusable component also can identify instructions for obtaining a license, such as a source from which a full license can be purchased. Further, the reusable component can display a message indicating that it is in trial mode and/or provide only limited functionality.
If there are no restrictions, or once the restrictions have been implemented, the reusable component can be initialized in the target application (250). Thus, a copy of the reusable component included in the source application is created and initialized, to the extent permitted, in the target application. Additionally, a reusable component can be associated with a library file, which can be accessed by the target application. Thus, a reusable component can include a property that identifies the library file with which it is associated. Alternatively, if the reusable component corresponds only to the target application, the property can have a null value. Once initialized in the target application, the reusable component also can be executed. A reusable component is copied, to the extent permitted, as a complete component. Thus, the reusable component can be configured to be fully functional once it is inserted into the target application. FIG. 3 shows an exemplary interface that can be used to share reusable components included in two or more applications. A plurality of applications are presented in a GUI environment, such as a desktop 300 presented by an operating system or an application execution environment. A first source application window 305 associated with a first source application includes a bar graph interface 310 that is configured to present information in a graphical format. The first source application window 305 also includes a world wide web icon 315, which represents a data source for the information presented in the bar graph interface 310. The bar graph interface 310 and the world wide web icon 315 can be displayed in conjunction with visual indicators 312 and 317 respectively, to indicate that they are reusable components. Further, a second source application window 320 associated with a second source application includes a meter interface 325 that is configured to present information in a graphical format. The second source application window 320 also includes a database icon 330, which represents a data source for the information presented in the meter interface 325. The meter interface 325 and the database icon 330 can be displayed in conjunction with visual indicators 327 and 332 respectively, to indicate that they are reusable components.
Additionally, a target application window 335 can be displayed in the desktop 300. The target application window 335 can be associated with a new application or an existing application for which modification is permitted. The bar graph interface 310 included in the first source application window 305 can be inserted into the target application window 335 through a drag-and-drop operation 340. Upon being dropped into the target application window 335, a new bar graph interface 350 is created in the target application. Similarly, the database icon 330 included in the second source application window 320 can be inserted into the target application window 335 through a drag-and-drop operation 345. Upon being dropped into the target application window 335, a new data source 355 corresponding to the database represented by the database icon 330 is created in the target application.
Additionally, the target application can be configured to detect that the bar graph interface 350 includes an input for which a data source has not been specified. The target application also can determine that the data source 355 includes a data output that is not associated with a corresponding data input in the target application. Thus, the target application can prompt the user to indicate whether the output of the data source 355 is to be connected to the input of the bar graph interface 350. Alternatively, the target application can be configured to automatically form a connection between a component that includes an unassigned data output and a component that includes an unassigned data input. Thus, the output of the data source 355 can be automatically connected to the input of the bar graph interface 350. In another implementation, a user can specify a desired connection between a first component, with a data output, and a second component with a data input, such as by dropping the first component onto the second component.
FIG. 4 shows a flowchart describing an exemplary process for associating two reusable components in a target application. A reusable component including an unassigned data input is received in the target application (405). A reusable component including an unassigned data output also is received in the target application (410). The reusable components including the unassigned data input and the unassigned data output can be received in any order. Further, one or more intervening components, or other items, can be received in the target application between receipt of the reusable component including the unassigned data input and receipt of the reusable component including the unassigned data output. Additionally, any period of time can elapse between receipt of the reusable components including the unassigned data input and the unassigned data output. The target application detects the reusable component that includes the unassigned data input and the reusable component that includes the unassigned data output (415). The target application then queries the user to determine whether the unassigned data output should be connected to the unassigned data input (420). For example, the target application can be configured to present a prompt to the user asking whether output from a first reusable component should be provided as input to a second reusable component. If the user confirms, a connection between the reusable components is formed (425).
Otherwise, a connection is not made and the target application continues to operate until an additional reusable component is received (430). The target application then determines whether the additional reusable component includes an unassigned input or output (435). If the additional reusable component includes an unassigned input or output, the target application queries the user to determine whether a connection should be formed (420). Otherwise, the target application continues to operate until another reusable component is received (430).
Additionally, the target application can be configured to permit a user to reconfigure connections between two components and to form connections between two or more components. In other implementations, the target application can be configured to automatically form a connection between a reusable component that includes an unassigned data input and a reusable component that includes an unassigned data output. Further, the target application can be configured to prompt the user to confirm that the connection is correct.
FIG. 5 shows a computer-implemented method of reusing a component. Initially, a source application is executed in an application environment (505). A reusable component is presented in a source application window corresponding to the source application, wherein the reusable component is visibly distinguishable from one or more non-reusable components displayed in the source application window (510). Input is received selecting the reusable component in the source application window and adding the reusable component to a target application window corresponding to a target application (515). Once the input has been received, one or more computer-readable instructions associated with the reusable component are inserted into the target application (520). Embodiments of the subject matter and the functional operations described in this specification can be implemented in digital electronic circuitry, or in computer software, firmware, or hardware, including the structures disclosed in this specification and their structural equivalents, or in combinations of one or more of them. Embodiments of the subject matter described in this specification can be implemented as one or more computer program products, i.e., one or more modules of computer program instructions encoded on a computer-readable medium for execution by, or to control the operation of, data processing apparatus. The computer-readable medium can be a machine-readable storage device, a machine-readable storage substrate, a memory device, a composition of matter effecting a machine-readable propagated signal, or a combination of one or more of them. The term
"data processing apparatus" encompasses all apparatus, devices, and machines for processing data, including by way of example a programmable processor, a computer, or multiple processors or computers. The apparatus can include, in addition to hardware, code that creates an execution environment for the computer program in question, e.g., code that constitutes processor firmware, a protocol stack, a database management system, an operating system, or a combination of one or more of them. A propagated signal is an artificially generated signal, e.g., a machine-generated electrical, optical, or electromagnetic signal, that is generated to encode information for transmission to suitable receiver apparatus.
A computer program (also known as a program, software, software application, script, or code) can be written in any form of programming language, including compiled or interpreted languages, and it can be deployed in any form, including as a stand-alone program or as a module, component, subroutine, or other unit suitable for use in a computing environment. A computer program does not necessarily correspond to a file in a file system. A program can be stored in a portion of a file that holds other programs or data (e.g., one or more scripts stored in a markup language document), in a single file dedicated to the program in question, or in multiple coordinated files (e.g., files that store one or more modules, sub-programs, or portions of code). A computer program can be deployed to be executed on one computer or on multiple computers that are located at one site or distributed across multiple sites and interconnected by a communication network. The processes and logic flows described in this specification can be performed by one or more programmable processors executing one or more computer programs to perform functions by operating on input data and generating output. The processes and logic flows can also be performed by, and apparatus can also be implemented as, special purpose logic circuitry, e.g., an FPGA (field programmable gate array) or an ASIC (application-specific integrated circuit).
Processors suitable for the execution of a computer program include, by way of example, both general and special purpose microprocessors, and any one or more processors of any kind of digital computer. Generally, a processor will receive instructions and data from a read-only memory or a random access memory or both. The essential elements of a computer are a processor for performing instructions and one or more memory devices for storing instructions and data. Generally, a computer will also include, or be operatively coupled to receive data from or transfer data to, or both, one or more mass storage devices for storing data, e.g., magnetic, magneto-optical disks, or optical disks. However, a computer need not have such devices. Moreover, a computer can be embedded in another device, e.g., a mobile telephone, a personal digital assistant (PDA), a mobile audio player, a Global Positioning System (GPS) receiver, to name just a few. Computer-readable media suitable for storing computer program instructions and data include all forms of non- volatile memory, media and memory devices, including by way of example semiconductor memory devices, e.g., EPROM, EEPROM, and flash memory devices; magnetic disks, e.g., internal hard disks or removable disks; magneto-optical disks; and CD-ROM and DVD-ROM disks. The processor and the memory can be supplemented by, or incorporated in, special purpose logic circuitry. To provide for interaction with a user, embodiments of the subject matter described in this specification can be implemented on a computer having a display device, e.g., a CRT (cathode ray tube) or LCD (liquid crystal display) monitor, for displaying information to the user and a keyboard and a pointing device, e.g., a mouse or a trackball, by which the user can provide input to the computer. Other kinds of devices can be used to provide for interaction with a user as well; for example, feedback provided to the user can be any form of sensory feedback, e.g., visual feedback, auditory feedback, or tactile feedback; and input from the user can be received in any form, including acoustic, speech, or tactile input.
Embodiments of the subject matter described in this specification can be implemented in a computing system that includes a back-end component, e.g., as a data server, or that includes a middleware component, e.g., an application server, or that includes a front-end component, e.g., a client computer having a graphical user interface or a Web browser through which a user can interact with an implementation of the subject matter described is this specification, or any combination of one or more such back-end, middleware, or front-end components. The components of the system can be interconnected by any form or medium of digital data communication, e.g., a communication network. Examples of communication networks include a local area network ("LAN") and a wide area network ("WAN"), e.g., the Internet.
The computing system can include clients and servers. A client and server are generally remote from each other and typically interact through a communication network. The relationship of client and server arises by virtue of computer programs running on the respective computers and having a client-server relationship to each other.
While this specification contains many specifics, these should not be construed as limitations on the scope of the invention or of what may be claimed, but rather as descriptions of features specific to particular embodiments of the invention. Certain features that are described in this specification in the context of separate embodiments can also be implemented in combination in a single embodiment. Conversely, various features that are described in the context of a single embodiment can also be implemented in multiple embodiments separately or in any suitable subcombination. Moreover, although features may be described above as acting in certain combinations and even initially claimed as such, one or more features from a claimed combination can in some cases be excised from the combination, and the claimed combination may be directed to a subcombination or variation of a subcombination.
Similarly, while operations are depicted in the drawings in a particular order, this should not be understood as requiring that such operations be performed in the particular order shown or in sequential order, or that all illustrated operations be performed, to achieve desirable results. In certain circumstances, multitasking and parallel processing may be advantageous. Moreover, the separation of various system components in the embodiments described above should not be understood as requiring such separation in all embodiments, and it should be understood that the described program components and systems can generally be integrated together in a single software product or packaged into multiple software products.
Thus, particular embodiments of the invention have been described. Other embodiments are within the scope of the following claims. For example, the actions recited in the claims can be performed in a different order and still achieve desirable results.

Claims

CLAIMSWhat is claimed is:
1 . A computer-implemented method of reusing a component, the method comprising: executing a source application in an application environment; presenting a reusable component in a source application window corresponding to the source application, wherein the reusable component is visibly distinguishable from one or more non-reusable components displayed in the source application window; receiving input selecting the reusable component in the source application window and adding the reusable component to a target application window corresponding to a target application; and inserting one or more computer-readable instructions associated with the reusable component into the target application.
2. The computer-implemented method of claim 1 , wherein the received input comprises a drag-and-drop operation.
3. The computer-implemented method of claim 1, further comprising: receiving input activating a reuse function associated with the source application.
4. The computer-implemented method of claim 3 , wherein the reusable component is presented in the source application window only when the reuse function is active.
5. The computer-implemented method of claim 3, wherein the reusable component is visibly distinguishable from one or more non-reusable components displayed in the source application window only when the reuse function is active.
6. The computer-implemented method of claim 1, further comprising: determining that a data input included in the reusable component is unassigned; identifying a second component in the target application window that includes an unassigned data output; and establishing in the target application a connection between the data input included in the reusable component and the data output included in the second component.
7. The computer-implemented method of claim 6, further comprising: receiving input from a user confirming the connection between the data input included in the reusable component and the data output included in the second component.
8. The computer-implemented method of claim 1 , wherein the reusable component is visibly distinguishable from one or more non-reusable components based on a display attribute associated with the reusable component comprising at least one of highlighting, shading, an enhanced border, and a glow effect.
9. A computer program product, encoded on a computer-readable medium, operable to cause data processing apparatus to perform operations comprising: executing a source application in an application environment; presenting a reusable component in a source application window corresponding to the source application, wherein the reusable component is visibly distinguishable from one or more non-reusable components displayed in the source application window; receiving input selecting the reusable component in the source application window and adding the reusable component to a target application window corresponding to a target application; and inserting one or more computer-readable instructions associated with the reusable component into the target application.
10. The computer program product of claim 9, wherein the received input comprises a drag-and-drop operation.
1 1 . The computer program product of claim 9, further operable to cause data processing apparatus to perform operations comprising: receiving input activating a reuse function associated with the source application.
12. The computer program product of claim 11 , wherein the reusable component is presented in the source application window only when the reuse function is active.
13. The computer program product of claim 11 , wherein the reusable component is visibly distinguishable from one or more non-reusable components displayed in the source application window only when the reuse function is active.
14. The computer program product of claim 9, further operable to cause data processing apparatus to perform operations comprising: determining that a data input included in the reusable component is unassigned; identifying a second component in the target application window that includes an unassigned data output; and establishing in the target application a connection between the data input included in the reusable component and the data output included in the second component.
15. The computer program product of claim 14, further operable to cause data processing apparatus to perform operations comprising: receiving input from a user confirming the connection between the data input included in the reusable component and the data output included in the second component.
16. The computer program product of claim 9, wherein the reusable component is visibly distinguishable from one or more non-reusable components based on a display attribute associated with the reusable component comprising at least one of highlighting, shading, an enhanced border, and a glow effect.
17. A system comprising: a source application stored on a computer-readable medium; and a computing system including processor electronics configured to perform operations comprising: executing the source application in an application environment; presenting a reusable component in a source application window corresponding to the source application, wherein the reusable component is visibly distinguishable from one or more non-reusable components displayed in the source application window; receiving input selecting the reusable component in the source application window and adding the reusable component to a target application window corresponding to a target application; and inserting one or more computer-readable instructions associated with the reusable component into the target application.
18. The system of claim 17, wherein the received input comprises a drag-and-drop operation.
19. The system of claim 17, wherein the processor electronics are further configured to perform operations comprising: receiving input activating a reuse function associated with the source application.
20. The system of claim 19, wherein the reusable component is presented in the source application window only when the reuse function is active.
21 . The system of claim 19, wherein the reusable component is visibly distinguishable from one or more non-reusable components displayed in the source application window only when the reuse function is active.
22. The system of claim 17, wherein the processor electronics are further configured to perform operations comprising: determining that a data input included in the reusable component is unassigned; identifying a second component in the target application window that includes an unassigned data output; and establishing in the target application a connection between the data input included in the reusable component and the data output included in the second component.
23. The system of claim 22, wherein the processor electronics are further configured to perform operations comprising: receiving input from a user confirming the connection between the data input included in the reusable component and the data output included in the second component.
24. The system of claim 17, wherein the reusable component is visibly distinguishable from one or more non-reusable components based on a display attribute associated with the reusable component comprising at least one of highlighting, shading, an enhanced border, and a glow effect.
PCT/US2008/074059 2007-08-27 2008-08-22 Reusing components in a running application WO2009029531A1 (en)

Priority Applications (1)

Application Number Priority Date Filing Date Title
CN200880111163.XA CN101821714B (en) 2007-08-27 2008-08-22 Reusing components in running application

Applications Claiming Priority (2)

Application Number Priority Date Filing Date Title
US11/845,703 US8156467B2 (en) 2007-08-27 2007-08-27 Reusing components in a running application
US11/845,703 2007-08-27

Publications (1)

Publication Number Publication Date
WO2009029531A1 true WO2009029531A1 (en) 2009-03-05

Family

ID=40210586

Family Applications (1)

Application Number Title Priority Date Filing Date
PCT/US2008/074059 WO2009029531A1 (en) 2007-08-27 2008-08-22 Reusing components in a running application

Country Status (3)

Country Link
US (1) US8156467B2 (en)
CN (1) CN101821714B (en)
WO (1) WO2009029531A1 (en)

Cited By (1)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
WO2015185328A1 (en) * 2014-06-06 2015-12-10 Rode Oliver Computer-implemented method and signal sequence for a program for reusing software configurations that can be executed for software systems, and computer system, and a computer program with program code for carrying out the method

Families Citing this family (24)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
EP1654633A2 (en) * 2003-08-06 2006-05-10 Koninklijke Philips Electronics N.V. A method of presenting a plurality of items
US9218166B2 (en) * 2008-02-20 2015-12-22 Embarcadero Technologies, Inc. Development system with improved methodology for creation and reuse of software assets
US8191036B2 (en) * 2008-05-19 2012-05-29 Apple Inc. Mechanism to support orphaned and partially configured objects
KR101580999B1 (en) * 2009-01-06 2015-12-30 삼성전자주식회사 Apparatus and method for moving contents between applications
US8661408B2 (en) * 2009-11-23 2014-02-25 Michael James Psenka Integrated development environment and methods of using the same
US8577904B2 (en) * 2009-12-07 2013-11-05 International Business Machines Corporation Composite copy and paste for composite user interfaces
US20140040789A1 (en) * 2012-05-08 2014-02-06 Adobe Systems Incorporated Tool configuration history in a user interface
US20150153918A1 (en) * 2013-12-04 2015-06-04 General Electric Company System and method for dashboard software maintained by an end user
CN104699363B (en) * 2013-12-10 2018-09-21 阿里巴巴集团控股有限公司 A kind of window interface shows method and system
US9720659B2 (en) * 2015-02-12 2017-08-01 International Business Machines Corporation Sparse object instantiation
EP3106980A1 (en) * 2015-06-19 2016-12-21 Ecole Nationale de l'Aviation Civile A processing unit, software and method for controlling interactive components
US10152694B2 (en) * 2016-09-30 2018-12-11 Sap Se Semi-automatic object reuse across application parts
CN110235122B (en) * 2016-12-21 2023-07-07 开文公司 System and method for converting web content into reusable templates and components
CN107608594B (en) * 2017-09-08 2019-03-01 维沃移动通信有限公司 A kind of display methods more applied and mobile terminal
CN107885570A (en) * 2017-11-16 2018-04-06 口碑(上海)信息技术有限公司 It is multiplexed the method and device of view component
US11269500B2 (en) * 2018-05-21 2022-03-08 Samsung Electronics Co., Ltd. Method and system for modular widgets in smart devices
JP7007486B2 (en) * 2018-08-03 2022-01-24 日立Astemo株式会社 How to identify project components and their reusability detection system
US11392284B1 (en) * 2018-11-01 2022-07-19 Northrop Grumman Systems Corporation System and method for implementing a dynamically stylable open graphics library
EP3726373B1 (en) * 2019-04-15 2024-03-06 Mendix Technology B.V. Creating an app method and system
US11269712B1 (en) 2020-08-26 2022-03-08 Spirent Communications, Inc. Customized categorial error handling framework for heterogeneous component-based testing in a portable automation framework
US11216347B1 (en) 2020-08-26 2022-01-04 Spirent Communications, Inc. Automatically locating resources using alternative locator expressions during heterogeneous component-based testing in a portable automation framework
US11449414B2 (en) 2020-08-26 2022-09-20 Spirent Communications, Inc. Mapping test parameter data elements during heterogeneous component-based testing in a portable automation framework in both API mode and UI mode
US11310680B2 (en) * 2020-08-26 2022-04-19 Spirent Communications, Inc. Reusing provisioned resources during heterogeneous component-based testing in a portable automation framework
CN114579020A (en) * 2020-11-30 2022-06-03 华为技术有限公司 Method for migrating display elements across applications and electronic equipment

Family Cites Families (183)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US4752893A (en) 1985-11-06 1988-06-21 Texas Instruments Incorporated Graphics data processing apparatus having image operations with transparent color having a selectable number of bits
FR2647239B1 (en) 1989-05-22 1991-07-05 Bull Sa METHOD FOR GENERATING INTERFACES FOR USER APPLICATIONS VISUALIZABLE ON THE SCREEN OF A COMPUTER SYSTEM AND DEVICE FOR IMPLEMENTING SAID METHOD
US5168441A (en) 1990-05-30 1992-12-01 Allen-Bradley Company, Inc. Methods for set up and programming of machine and process controllers
US5388201A (en) 1990-09-14 1995-02-07 Hourvitz; Leonard Method and apparatus for providing multiple bit depth windows
US5289574A (en) 1990-09-17 1994-02-22 Hewlett-Packard Company Multiple virtual screens on an "X windows" terminal
JPH0520044A (en) 1991-07-15 1993-01-29 Personal Joho Kankyo Kyokai User interface device
EP0528631B1 (en) 1991-08-13 1998-05-20 Xerox Corporation Electronic image generation
CA2077173C (en) 1991-11-22 2003-04-22 Michael Chen Method and apparatus for direct manipulation of 3-d objects on computer displays
JPH0644339A (en) 1992-03-06 1994-02-18 Hewlett Packard Co <Hp> Graphic object operation system and method
US5357603A (en) 1992-06-15 1994-10-18 Microsoft Corporation Method and system for changing a shape type while maintaining existing graphic characteristics
CA2101864A1 (en) 1992-08-27 1994-02-28 Claudia Carpenter Customizable program control interface for a computer system
EP0605945B1 (en) 1992-12-15 1997-12-29 Sun Microsystems, Inc. Method and apparatus for presenting information in a display system using transparent windows
US5588107A (en) 1993-03-22 1996-12-24 Island Graphics Corporation Method and apparatus for selectably expandable menus
US5638501A (en) 1993-05-10 1997-06-10 Apple Computer, Inc. Method and apparatus for displaying an overlay image
US5764238A (en) 1993-09-10 1998-06-09 Ati Technologies Inc. Method and apparatus for scaling and blending an image to be displayed
US6983051B1 (en) 1993-11-18 2006-01-03 Digimarc Corporation Methods for audio watermarking and decoding
US5522022A (en) 1993-11-24 1996-05-28 Xerox Corporation Analyzing an image showing a node-link structure
US5796402A (en) 1993-12-03 1998-08-18 Microsoft Corporation Method and system for aligning windows on a computer screen
US6031937A (en) 1994-05-19 2000-02-29 Next Software, Inc. Method and apparatus for video compression using block and wavelet techniques
US6757438B2 (en) 2000-02-28 2004-06-29 Next Software, Inc. Method and apparatus for video compression using microwavelets
US5835693A (en) 1994-07-22 1998-11-10 Lynch; James D. Interactive system for simulation and display of multi-body systems in three dimensions
AUPM704194A0 (en) 1994-07-25 1994-08-18 Canon Information Systems Research Australia Pty Ltd Efficient methods for the evaluation of a graphical programming language
US5564002A (en) 1994-08-01 1996-10-08 International Business Machines Corporation Method and apparatus for implementing a virtual desktop through window positioning
US5835692A (en) 1994-11-21 1998-11-10 International Business Machines Corporation System and method for providing mapping notation in interactive video displays
JP3647487B2 (en) 1994-12-02 2005-05-11 株式会社ソニー・コンピュータエンタテインメント Texture mapping device
JP3578498B2 (en) 1994-12-02 2004-10-20 株式会社ソニー・コンピュータエンタテインメント Image information processing device
US5949409A (en) 1994-12-02 1999-09-07 Sony Corporation Image processing in which the image is divided into image areas with specific color lookup tables for enhanced color resolution
US5537630A (en) 1994-12-05 1996-07-16 International Business Machines Corporation Method and system for specifying method parameters in a visual programming system
US5877762A (en) 1995-02-27 1999-03-02 Apple Computer, Inc. System and method for capturing images of screens which display multiple windows
JP3517301B2 (en) 1995-03-28 2004-04-12 富士通株式会社 Virtual screen display processing system
US6307574B1 (en) 1995-05-08 2001-10-23 Apple Computer, Inc. Graphical user interface with hierarchical structure for customizable menus and control objects
US5877741A (en) 1995-06-07 1999-03-02 Seiko Epson Corporation System and method for implementing an overlay pathway
US5731819A (en) 1995-07-18 1998-03-24 Softimage Deformation of a graphic object to emphasize effects of motion
US6331856B1 (en) 1995-11-22 2001-12-18 Nintendo Co., Ltd. Video game system with coprocessor providing high speed efficient 3D graphics and digital audio signal processing
US5809230A (en) 1996-01-16 1998-09-15 Mclellan Software International, Llc System and method for controlling access to personal computer system resources
US5838316A (en) 1996-01-26 1998-11-17 International Business Machines Corporation Method and system for presenting a plurality of animated display objects to a user for selection on a graphical user interface in a data processing system
ES2205176T3 (en) 1996-02-29 2004-05-01 Sony Computer Entertainment Inc. IMAGE PROCESSOR AND IMAGE PROCESSING METHOD.
US6154601A (en) 1996-04-12 2000-11-28 Hitachi Denshi Kabushiki Kaisha Method for editing image information with aid of computer and editing system
US5764229A (en) 1996-05-09 1998-06-09 International Business Machines Corporation Method of and system for updating dynamic translucent windows with buffers
US6542166B1 (en) 1996-05-09 2003-04-01 National Instruments Corporation System and method for editing a control
JP3537259B2 (en) 1996-05-10 2004-06-14 株式会社ソニー・コンピュータエンタテインメント Data processing device and data processing method
AUPO002196A0 (en) 1996-05-22 1996-06-13 Canon Information Systems Research Australia Pty Ltd A method of optimising an expression tree for the production of images
US5947819A (en) 1996-05-22 1999-09-07 Konami Co., Ltd. Object-throwing video game system
US5920659A (en) 1996-06-24 1999-07-06 Intel Corporation Method and apparatus for scaling image data having associated transparency data
US6006231A (en) 1996-09-10 1999-12-21 Warp 10 Technologies Inc. File format for an image including multiple versions of an image, and related system and method
US5933155A (en) 1996-11-06 1999-08-03 Silicon Graphics, Inc. System and method for buffering multiple frames while controlling latency
US6195664B1 (en) 1997-02-21 2001-02-27 Micrografx, Inc. Method and system for controlling the conversion of a file from an input format to an output format
US5913063A (en) 1997-02-26 1999-06-15 Oracle Corporation Drag and drop object subclassing
US6204851B1 (en) 1997-04-04 2001-03-20 Intergraph Corporation Apparatus and method for applying effects to graphical images
US6144381A (en) 1997-05-14 2000-11-07 International Business Machines Corporation Systems, methods and computer program products for compass navigation of avatars in three dimensional worlds
IL120867A0 (en) 1997-05-20 1997-09-30 Cadent Ltd Computer user interface for orthodontic use
US6011562A (en) 1997-08-01 2000-01-04 Avid Technology Inc. Method and system employing an NLE to create and modify 3D animations by mixing and compositing animation data
US6128010A (en) 1997-08-05 2000-10-03 Assistive Technology, Inc. Action bins for computer user interface
US5978579A (en) 1997-08-12 1999-11-02 International Business Machines Corporation Architecture for customizable component system
US6005568A (en) 1997-09-30 1999-12-21 The United States Of America As Represented By The Secretary Of The Navy Computer system providing platform independent universal client device
US6272558B1 (en) 1997-10-06 2001-08-07 Canon Kabushiki Kaisha Application programming interface for manipulating flashpix files
US6469714B2 (en) 1998-01-26 2002-10-22 International Business Machines Corporation Infocenter user interface for applets and components
US6278448B1 (en) 1998-02-17 2001-08-21 Microsoft Corporation Composite Web page built from any web content
US6412021B1 (en) 1998-02-26 2002-06-25 Sun Microsystems, Inc. Method and apparatus for performing user notification
US6266053B1 (en) 1998-04-03 2001-07-24 Synapix, Inc. Time inheritance scene graph for representation of media content
US6310621B1 (en) 1998-04-03 2001-10-30 Avid Technology, Inc. Extended support for numerical controls
US6272484B1 (en) 1998-05-27 2001-08-07 Scansoft, Inc. Electronic document manager
US6353437B1 (en) 1998-05-29 2002-03-05 Avid Technology, Inc. Animation system and method for defining and using rule-based groups of objects
US6771264B1 (en) 1998-08-20 2004-08-03 Apple Computer, Inc. Method and apparatus for performing tangent space lighting and bump mapping in a deferred shading graphics processor
US6577317B1 (en) 1998-08-20 2003-06-10 Apple Computer, Inc. Apparatus and method for geometry operations in a 3D-graphics pipeline
JP3566889B2 (en) 1998-10-08 2004-09-15 株式会社ソニー・コンピュータエンタテインメント Information adding method, video game machine, and recording medium
US6427230B1 (en) * 1998-11-09 2002-07-30 Unisys Corporation System and method for defining and managing reusable groups software constructs within an object management system
US6993721B2 (en) 1998-11-30 2006-01-31 Sony Corporation Web channel guide graphical interface system and method
US6356903B1 (en) 1998-12-30 2002-03-12 American Management Systems, Inc. Content management system
US6753878B1 (en) 1999-03-08 2004-06-22 Hewlett-Packard Development Company, L.P. Parallel pipelined merge engines
US6714201B1 (en) 1999-04-14 2004-03-30 3D Open Motion, Llc Apparatuses, methods, computer programming, and propagated signals for modeling motion in computer applications
US6512522B1 (en) 1999-04-15 2003-01-28 Avid Technology, Inc. Animation of three-dimensional characters along a path for motion video sequences
US6590592B1 (en) 1999-04-23 2003-07-08 Xsides Corporation Parallel interface
US6765592B1 (en) 1999-04-30 2004-07-20 Microsoft Corporation Undockable sub-windows
US6369830B1 (en) 1999-05-10 2002-04-09 Apple Computer, Inc. Rendering translucent layers in a display system
US6321314B1 (en) 1999-06-09 2001-11-20 Ati International S.R.L. Method and apparatus for restricting memory access
US6542160B1 (en) 1999-06-18 2003-04-01 Phoenix Technologies Ltd. Re-generating a displayed image
US6573896B1 (en) 1999-07-08 2003-06-03 Dassault Systemes Three-dimensional arrow
JP3163496B2 (en) 1999-08-20 2001-05-08 株式会社光栄 Group character moving method, recording medium, and game device
US6687745B1 (en) 1999-09-14 2004-02-03 Droplet, Inc System and method for delivering a graphical user interface of remote applications over a thin bandwidth connection
US7061486B2 (en) 1999-09-24 2006-06-13 Sun Microsystems, Inc. Using messaging to manage scene-based rendering
US6483524B1 (en) 1999-10-01 2002-11-19 Global Graphics Software Limited Prepress workflow method using raster image processor
US7050955B1 (en) 1999-10-01 2006-05-23 Immersion Corporation System, method and data structure for simulated interaction with graphical objects
US6618048B1 (en) 1999-10-28 2003-09-09 Nintendo Co., Ltd. 3D graphics rendering system for performing Z value clamping in near-Z range to maximize scene resolution of visually important Z components
US6411301B1 (en) 1999-10-28 2002-06-25 Nintendo Co., Ltd. Graphics system interface
US6452600B1 (en) 1999-10-28 2002-09-17 Nintendo Co., Ltd. Graphics system interface
US7028264B2 (en) 1999-10-29 2006-04-11 Surfcast, Inc. System and method for simultaneous display of multiple information sources
US6457034B1 (en) 1999-11-02 2002-09-24 Ati International Srl Method and apparatus for accumulation buffering in the video graphics system
US6806892B1 (en) 1999-12-20 2004-10-19 International Business Machines Corporation Layer viewport for enhanced viewing in layered drawings
US20030174154A1 (en) 2000-04-04 2003-09-18 Satoru Yukie User interface for interfacing with plural real-time data sources
US6304684B1 (en) 2000-02-15 2001-10-16 Cyberecord, Inc. Information processing system and method of using same
US20010035885A1 (en) 2000-03-20 2001-11-01 Michael Iron Method of graphically presenting network information
US6857061B1 (en) 2000-04-07 2005-02-15 Nintendo Co., Ltd. Method and apparatus for obtaining a scalar value directly from a vector register
US20060123356A1 (en) 2000-05-05 2006-06-08 Microsoft Corporation Dynamic and updateable computing application panes
US7472157B2 (en) 2000-05-08 2008-12-30 H.E.B., Llc Architecture for a system of portable information agents
US6707462B1 (en) 2000-05-12 2004-03-16 Microsoft Corporation Method and system for implementing graphics control constructs
US6910000B1 (en) 2000-06-02 2005-06-21 Mitsubishi Electric Research Labs, Inc. Generalized belief propagation for probabilistic systems
US6717599B1 (en) 2000-06-29 2004-04-06 Microsoft Corporation Method, system, and computer program product for implementing derivative operators with graphics hardware
US6931633B1 (en) 2000-08-01 2005-08-16 National Instruments Corporation System and method of evaluating the performance of an image processing algorithm
EP1323053A4 (en) 2000-08-07 2006-08-16 Active Data Exchange Syndication methodology to dynamically place digital assets on non-related web sites
US6636214B1 (en) 2000-08-23 2003-10-21 Nintendo Co., Ltd. Method and apparatus for dynamically reconfiguring the order of hidden surface processing based on rendering mode
US6580430B1 (en) 2000-08-23 2003-06-17 Nintendo Co., Ltd. Method and apparatus for providing improved fog effects in a graphics system
US6664962B1 (en) 2000-08-23 2003-12-16 Nintendo Co., Ltd. Shadow mapping in a low cost graphics system
US6639595B1 (en) 2000-08-23 2003-10-28 Nintendo Co., Ltd. Achromatic lighting in a graphics system and method
US6609977B1 (en) 2000-08-23 2003-08-26 Nintendo Co., Ltd. External interfaces for a 3D graphics system
US6664958B1 (en) 2000-08-23 2003-12-16 Nintendo Co., Ltd. Z-texturing
US20020065946A1 (en) 2000-10-17 2002-05-30 Shankar Narayan Synchronized computing with internet widgets
US6715053B1 (en) 2000-10-30 2004-03-30 Ati International Srl Method and apparatus for controlling memory client access to address ranges in a memory pool
US6697074B2 (en) 2000-11-28 2004-02-24 Nintendo Co., Ltd. Graphics system interface
JP3548521B2 (en) 2000-12-05 2004-07-28 Necマイクロシステム株式会社 Translucent image processing apparatus and method
US20020078453A1 (en) 2000-12-15 2002-06-20 Hanchang Kuo Hub pages for set top box startup screen
US20040039934A1 (en) 2000-12-19 2004-02-26 Land Michael Z. System and method for multimedia authoring and playback
US7155676B2 (en) 2000-12-19 2006-12-26 Coolernet System and method for multimedia authoring and playback
JP3450833B2 (en) 2001-02-23 2003-09-29 キヤノン株式会社 Image processing apparatus and method, program code, and storage medium
US6760047B2 (en) 2001-02-26 2004-07-06 Microsoft Corporation Method for flagging and relating information in a computer system
TWI243320B (en) 2001-03-28 2005-11-11 Ulead Systems Inc Method for manipulating multiple multimedia objects
TW502180B (en) 2001-03-30 2002-09-11 Ulead Systems Inc Previewing method of editing multimedia effect
US20030005412A1 (en) 2001-04-06 2003-01-02 Eanes James Thomas System for ontology-based creation of software agents from reusable components
US20020174181A1 (en) 2001-04-13 2002-11-21 Songxiang Wei Sharing OpenGL applications using application based screen sampling
US20030046316A1 (en) 2001-04-18 2003-03-06 Jaroslav Gergic Systems and methods for providing conversational computing via javaserver pages and javabeans
AUPR464601A0 (en) 2001-04-30 2001-05-24 Commonwealth Of Australia, The Shapes vector
US7185290B2 (en) 2001-06-08 2007-02-27 Microsoft Corporation User interface for a system and process for providing dynamic communication access and information awareness in an interactive peripheral display
US20020186257A1 (en) 2001-06-08 2002-12-12 Cadiz Jonathan J. System and process for providing dynamic communication access and information awareness in an interactive peripheral display
US7699701B2 (en) 2001-07-05 2010-04-20 Dbs Limited Partnership Method and system for providing real time sports betting information
US7564460B2 (en) 2001-07-16 2009-07-21 Microsoft Corporation Systems and methods for providing intermediate targets in a graphics system
US6985939B2 (en) * 2001-09-19 2006-01-10 International Business Machines Corporation Building distributed software services as aggregations of other services
US6944829B2 (en) 2001-09-25 2005-09-13 Wind River Systems, Inc. Configurable user-interface component management system
US7895522B2 (en) 2001-09-28 2011-02-22 Ntt Docomo, Inc. Layout of platform specific graphical user interface widgets migrated between heterogeneous device platforms
US20030080995A1 (en) 2001-10-12 2003-05-01 United Virtualities, Inc. Contextually adaptive web browser
US7257776B2 (en) 2002-02-05 2007-08-14 Microsoft Corporation Systems and methods for scaling a graphical user interface according to display dimensions and using a tiered sizing schema to define display objects
WO2003071442A1 (en) 2002-02-15 2003-08-28 Tridium, Inc. Real-time data interface and method for browsers and the like
US20030169306A1 (en) 2002-03-07 2003-09-11 Nokia Corporation Creating a screen saver from downloadable applications on mobile devices
US6906720B2 (en) 2002-03-12 2005-06-14 Sun Microsystems, Inc. Multipurpose memory system for use in a graphics system
US7010755B2 (en) 2002-04-05 2006-03-07 Microsoft Corporation Virtual desktop manager
US20040012626A1 (en) 2002-07-22 2004-01-22 Brookins Timothy J. Method for creating configurable and customizable web user interfaces
GB2392072B (en) 2002-08-14 2005-10-19 Autodesk Canada Inc Generating Image Data
US20050282612A1 (en) 2002-08-16 2005-12-22 Marc Mathews Sports theme gaming apparatus and method for playing the same
US20040036711A1 (en) 2002-08-23 2004-02-26 Anderson Thomas G. Force frames in animation
US7610352B2 (en) 2002-09-09 2009-10-27 Meca Communications, Inc. Sharing skins
US7337409B2 (en) 2002-09-25 2008-02-26 Siemens Aktiengesellschaft Customizable drag and drop for industrial software applications
GB0226292D0 (en) 2002-11-12 2002-12-18 Autodesk Canada Inc Generating image data
GB2411994B (en) 2002-12-03 2006-11-15 David Boxenhorn Networked computing using objects
US6911983B2 (en) 2003-03-12 2005-06-28 Nvidia Corporation Double-buffering of pixel data using copy-on-write semantics
US6911984B2 (en) 2003-03-12 2005-06-28 Nvidia Corporation Desktop compositor using copy-on-write semantics
US7343567B2 (en) 2003-04-25 2008-03-11 Microsoft Corporation System and method for providing dynamic user information in an interactive display
US7051282B2 (en) 2003-06-13 2006-05-23 Microsoft Corporation Multi-layer graphical user interface
US7287241B2 (en) 2003-06-17 2007-10-23 Microsoft Corporation Snaplines for control object positioning
US20050021935A1 (en) 2003-06-18 2005-01-27 Openwave Systems Inc. Method and system for downloading configurable user interface elements over a data network
US20050010634A1 (en) 2003-06-19 2005-01-13 Henderson Roderick C. Methods, systems, and computer program products for portlet aggregation by client applications on a client side of client/server environment
US8127248B2 (en) 2003-06-20 2012-02-28 Apple Inc. Computer interface having a virtual single-layer mode for viewing overlapping objects
GB2404546B (en) 2003-07-25 2005-12-14 Purple Interactive Ltd A method of organising and displaying material content on a display to a viewer
US7793227B2 (en) 2003-08-12 2010-09-07 Yahoo! Inc. Method and system of providing customizable buttons
US20050060655A1 (en) 2003-09-12 2005-03-17 Useractive Distance-learning system with dynamically constructed menu that includes embedded applications
US7480873B2 (en) 2003-09-15 2009-01-20 Sun Microsystems, Inc. Method and apparatus for manipulating two-dimensional windows within a three-dimensional display model
US7817163B2 (en) 2003-10-23 2010-10-19 Microsoft Corporation Dynamic window anatomy
US7839419B2 (en) 2003-10-23 2010-11-23 Microsoft Corporation Compositing desktop window manager
US7382378B2 (en) 2003-10-30 2008-06-03 Sensable Technologies, Inc. Apparatus and methods for stenciling an image
US20050093516A1 (en) * 2003-11-04 2005-05-05 Ford Global Technologies, Llc Method and apparatus for measuring electrical cell voltage
US7274370B2 (en) 2003-12-18 2007-09-25 Apple Inc. Composite graphics rendered using multiple frame buffers
US7434153B2 (en) 2004-01-21 2008-10-07 Fuji Xerox Co., Ltd. Systems and methods for authoring a media presentation
US7694271B2 (en) 2004-02-26 2010-04-06 International Business Machines Corporation Rendering GUI widgets with generic look and feel
WO2005089351A2 (en) 2004-03-15 2005-09-29 Igt Event calendar at electronic gaming device
US20050240857A1 (en) 2004-04-02 2005-10-27 Jason Benedict Methods and systems of information portal construction
US7653880B2 (en) 2004-04-13 2010-01-26 Microsoft Corporation Application of data-binding mechanism to perform command binding
US7624160B2 (en) 2004-05-04 2009-11-24 International Business Machines Corporation Methods, systems, and computer program products for client side prefetching and caching of portlets
EP1603035A3 (en) 2004-06-03 2008-03-05 MDL Information Systems, Inc. Methods and apparatus for visual application design
US8762540B2 (en) 2004-09-01 2014-06-24 Hewlett-Packard Development Company, L.P. Managing multiple remote computing sessions displayed on a client device
US20060089840A1 (en) 2004-10-21 2006-04-27 Margaret May Health tracking method and apparatus
US7543244B2 (en) 2005-03-22 2009-06-02 Microsoft Corporation Determining and displaying a list of most commonly used items
US7496888B2 (en) * 2005-04-07 2009-02-24 International Business Machines Corporation Solution builder wizard
US7853934B2 (en) 2005-06-23 2010-12-14 Hewlett-Packard Development Company, L.P. Hot-swapping a dynamic code generator
US8924869B2 (en) 2005-08-12 2014-12-30 Barry Fellman Service for generation of customizable display widgets
US7644391B2 (en) 2005-08-18 2010-01-05 Microsoft Corporation Sidebar engine, object model and schema
US7665032B2 (en) 2005-08-18 2010-02-16 Microsoft Corporation Sidebar engine, object model and schema
US7568165B2 (en) 2005-08-18 2009-07-28 Microsoft Corporation Sidebar engine, object model and schema
CA2622900C (en) 2005-09-15 2014-04-29 Biap, Inc. Self-contained mini-applications system and method for digital television
US20070074157A1 (en) 2005-09-23 2007-03-29 Wdn Holdings, Llc Method and system for runtime graphical assembly of running applications
US9104294B2 (en) 2005-10-27 2015-08-11 Apple Inc. Linked widgets
US7783985B2 (en) 2006-01-04 2010-08-24 Citrix Systems, Inc. Systems and methods for transferring data between computing devices
US7996783B2 (en) 2006-03-02 2011-08-09 Microsoft Corporation Widget searching utilizing task framework
US20070234195A1 (en) * 2006-04-03 2007-10-04 National Instruments Corporation Simultaneous update of a plurality of user interface elements displayed in a web browser
US20080155518A1 (en) 2006-11-27 2008-06-26 Sourcecode Technology Holding, Inc. Methods and apparatus for tokenizing workflow process objects
US20080248834A1 (en) 2007-04-03 2008-10-09 Palm, Inc. System and methods for providing access to a desktop and applications of a mobile device

Non-Patent Citations (3)

* Cited by examiner, † Cited by third party
Title
DONATIEN GROLAUX ET AL: "Attach Me, Detach Me, Assemble Me Like You Work", HUMAN-COMPUTER INTERACTION - INTERACT 2005 LECTURE NOTES IN COMPUTER SCIENCE;;LNCS, SPRINGER, BERLIN, DE, vol. 3585, 1 January 2005 (2005-01-01), pages 198 - 212, XP019018979, ISBN: 978-3-540-28943-2 *
FLORIAN DANIEL ET AL: "Mashing Up Context-Aware Web Applications: A Component-Based Development Approach", WEB INFORMATION SYSTEMS ENGINEERING - WISE 2008; [LECTURE NOTES IN COMPUTER SCIENCE], vol. 5175, 2008, pages 250 - 263, XP019103131, ISBN: 978-3-540-85480-7 *
STREITZ N A ET AL: "i-LAND: AN INTERACTIVE LANDSCAPE FOR CREATIVITY AND INNOVATION", CHI '99 CONFERENCE PROCEEDINGS HUMAN FACTORS IN COMPUTING SYSTEMS. PITTSBURGH, PA, MAY 15 - 20, 1999; [CHI CONFERENCE PROCEEDINGS. HUMAN FACTORS IN COMPUTING SYSTEMS], NEW YORK, NY : ACM, US, 15 May 1999 (1999-05-15), pages 120 - 127, XP000894211, ISBN: 978-0-201-48559-2 *

Cited By (1)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
WO2015185328A1 (en) * 2014-06-06 2015-12-10 Rode Oliver Computer-implemented method and signal sequence for a program for reusing software configurations that can be executed for software systems, and computer system, and a computer program with program code for carrying out the method

Also Published As

Publication number Publication date
CN101821714B (en) 2013-04-03
US8156467B2 (en) 2012-04-10
CN101821714A (en) 2010-09-01
US20090064106A1 (en) 2009-03-05

Similar Documents

Publication Publication Date Title
US8156467B2 (en) Reusing components in a running application
US8176466B2 (en) System and method for generating an application fragment
US20140040862A1 (en) Copying Reusable Components from a Remote Source
US6868526B2 (en) Graphical subclassing
US7636897B2 (en) System and method for property-based focus navigation in a user interface
US8943424B2 (en) Dynamic interface component control support
TWI413933B (en) Application programming interfaces for graphical user interfaces
US9081579B2 (en) System and method for mobile application development
US9778921B2 (en) Method for creating, exporting, sharing, and installing graphics functional blocks
US9471213B2 (en) Chaining applications
CA2498695A1 (en) Application of data-binding mechanism to perform command binding
CA2443454A1 (en) Data binding method in workflow system
US9015611B2 (en) Transferring component hierarchies between applications
US11741411B2 (en) System and method for software development including column-based process editor
Vogel Eclipse rich client platform
US9104389B2 (en) Hierarchical functional and variable composition diagramming of a programming class
US7966562B1 (en) System and method for providing domain-sensitive help
JP4404993B2 (en) System and method with enhanced functionality
Schuler et al. Rule-based generation of mobile user interfaces
US20140059521A1 (en) Systems and Methods for Editing A Computer Application From Within A Runtime Environment
Freeman et al. Helping programmers help users
MacDonald User Interfaces in C#: Windows Forms and Custom Controls
Speilman The Struts Framework
Grelle et al. Neutron Source Facility Simulator (NSFS)
Navarre et al. Model-based Engineering of Feedforward Usability Function for GUI Widgets

Legal Events

Date Code Title Description
WWE Wipo information: entry into national phase

Ref document number: 200880111163.X

Country of ref document: CN

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

Ref document number: 08798515

Country of ref document: EP

Kind code of ref document: A1

NENP Non-entry into the national phase

Ref country code: DE

122 Ep: pct application non-entry in european phase

Ref document number: 08798515

Country of ref document: EP

Kind code of ref document: A1