WO2011149687A1 - Controlling a running application for live scene graph editing - Google Patents

Controlling a running application for live scene graph editing Download PDF

Info

Publication number
WO2011149687A1
WO2011149687A1 PCT/US2011/036469 US2011036469W WO2011149687A1 WO 2011149687 A1 WO2011149687 A1 WO 2011149687A1 US 2011036469 W US2011036469 W US 2011036469W WO 2011149687 A1 WO2011149687 A1 WO 2011149687A1
Authority
WO
WIPO (PCT)
Prior art keywords
file
application
request
client
application content
Prior art date
Application number
PCT/US2011/036469
Other languages
French (fr)
Inventor
Jean-Francois Denise
Andrew Allenson
Anthony Rogers
John Burkey
Eamonn P. Mcmanus
Original Assignee
Oracle America, Inc.
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 Oracle America, Inc. filed Critical Oracle America, Inc.
Priority to CN201180002458.5A priority Critical patent/CN102473103B/en
Priority to EP11722665.4A priority patent/EP2435912B1/en
Publication of WO2011149687A1 publication Critical patent/WO2011149687A1/en

Links

Classifications

    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L67/00Network arrangements or protocols for supporting network services or applications
    • H04L67/01Protocols
    • H04L67/02Protocols based on web technology, e.g. hypertext transfer protocol [HTTP]
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F8/00Arrangements for software engineering
    • G06F8/60Software deployment
    • G06F8/65Updates
    • G06F8/656Updates while running
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F16/00Information retrieval; Database structures therefor; File system structures therefor
    • G06F16/90Details of database functions independent of the retrieved data types
    • G06F16/95Retrieval from the web
    • G06F16/953Querying, e.g. by the use of web search engines
    • G06F16/9535Search customisation based on user profiles and personalisation
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F8/00Arrangements for software engineering
    • G06F8/60Software deployment

Definitions

  • Modern computer applications may be stored on computers in geographically remote locations, or on multiple computers around the world, in order to provide end users with convenient access to the applications.
  • such applications may be heavily relied upon by end users such that an interruption in access to such applications may cause considerable social and financial frustrations.
  • Typical computer applications are made unavailable to end users for a period of time when a new version of the application is deployed. Further, changes made to typical computer applications may only be viewed once the application has been redeployed after the changes have been made.
  • the invention relates to a computer readable medium including software instructions for performing a method, the method including receiving, by a content server, a first request from a client for an application content file, wherein the application content file is associated with a first Java network launch protocol (JNLP) file, providing, in response to the first request, the application content file; receiving, from the client, a second request to edit the application content file, providing, in response to the second request, an application designer tool to the client; receiving, from the client, an altered application content file generated using the application designer tool, generating a second JNLP file associated with the altered application content file, and providing, to a webserver, the second JNLP file.
  • JNLP Java network launch protocol
  • the invention in general, in one aspect, relates to a system.
  • the system includes a content server which includes a processor, an application content file, and a memory configured to store instructions, wherein the instructions, when executed by the processor, cause the content server to receive a first request from a client for the application content file, wherein the application content file is associated with a first Java network launch protocol (JNLP) file, provide, in response to the first request, the application content file, receive, from the client, a second request to edit the application content file, provide, in response to the second request, an application designer tool to the client; receive, from the client, an altered application content file generated using the application designer tool, generate a second JNLP file associated with the altered application content file, and provide, to a webserver, the second JNLP file.
  • JNLP Java network launch protocol
  • the invention relates to a computer readable medium including software instructions for performing a method, the method including sending, by a client, a first request to a webserver for an application content file, wherein the application content file is associated with a Java network launch protocol (JNLP) file, receiving, from the webserver in response to the first request, the JNLP file, sending a second request to a content server, wherein the second request comprises at least a portion of the JNLP file, receiving, from the content server in response to the second request, the application content file, sending, to the content server, a second request to edit the application content file, receiving, from the content server in response to the third request, an application designer tool to the client, editing the application content file using the application designer tool to obtain an altered content file, sending, to the content server, a fourth request comprising the altered content file.
  • JNLP Java network launch protocol
  • FIG. 1 shows a system in accordance with one or more embodiments of the invention.
  • FIG. 2 shows a flowchart in accordance with one or more embodiments of the invention.
  • FIG. 3 shows a flowchart in accordance with one or more embodiments of the invention.
  • FIG. 4 shows an example in accordance with one or more embodiments of the invention.
  • FIG. 5 shows a computer system in accordance with one or more embodiments of the invention.
  • embodiments of the invention relate to controlling a running JavaFX application for live scene graph editing. More specifically, embodiments of the invention relate a method and system for editing the content and behavior of a deployed (i.e., accessible by an end-user) JavaFX application without interrupting user access to the application.
  • Java ® and JavaFX ® are registered trademarks owned by Sun Microsystems, Inc., Mountain View, CA.
  • FIG. 1 shows a system in accordance with one embodiment of the invention.
  • the system includes a User Browser (100), a Webserver (102), and a Content Server (104).
  • the User Browser (100) includes a Web Start applet (106), an FX designer runtime instance (108), a JavaFX Application instance (110), and an FX Designer Tool instance (112).
  • the Webserver (102) includes a Java Network Launching Protocol (JNLP) file (114).
  • the Content Server (104) includes FX Designer Runtime files (116), JavaFX Application Content files (118), and FX Designer Tool files (120). Each of these components is discussed in detail below.
  • the User Browser is an application executing on a user computer system (not shown) used for interacting with internet content.
  • the User Browser may be any internet browser known in the art capable of executing a Web Start applet (106), examples of which may include Internet Explorer browser (Internet Explorer ® is a registered trademark owned by Microsoft Corp.), Firefox ® browser (Firefox is a registered trademark owned by the Mozilla Foundation), Safari browser (Safari is a registered trademark owned by Apple Computer, Inc.), and Google ChromeTM browser (Google ChromeTM is a trademark owned by Google, Inc.).
  • the User Browser (100) under the control of a user, may navigate to a webpage intended to host a JavaFX application (e.g., JavaFX Application instance (1 10)).
  • the webpage includes a reference to the JNLP file (114) associated with the embedded JavaFX application (e.g., JavaFX Application instance (110)).
  • the User Browser (100) is configured to request the JNLP file (1 14) from the Webserver (102).
  • the Webserver (102) is configured to respond to a request by the User Browser (100) for a JavaFX application (e.g., JavaFX Application instance (110)) by providing, to the User Browser (100), a JNLP file (e.g., JNLP file (1 14)) associated with the JavaFX application(e.g., JavaFX Application instance (1 10)).
  • a JavaFX application e.g., JavaFX Application instance (110)
  • JNLP file e.g., JNLP file (1 14)
  • the Webserver (102) is an application executing on a computer system (not shown), configured to respond to requests sent over a network (e.g., a local area network, a wide area network, the Internet, etc.).
  • the Webserver (102) may store more than one JNLP file (e.g., JNLP file (114)). Further, each JNLP file may be associated with a different application, and multiple JNLP files (e.g., JNLP file (114)) may be associated with different versions of the same application.
  • the User Browser (100) is configured to instantiate a Web Start applet (e.g., Web Start applet (106)) in response to receiving a JNLP file (e.g. , JNLP file (1 14)) from a webserver (e.g., Webserver (102)). In one embodiment of the invention, the User Browser (100) may provide a received JNLP file (e.g., JNLP file (114)) directly to the Web Start applet (106).
  • the Web Start applet (106) creates a platform within the User Browser (100) capable of initializing Java application software (e.g., JavaFX Application instance (110)) using an associated JNLP file (e.g., JNLP file (1 14)). More specifically, in one embodiment of the invention, the Web Start applet (106) includes functionality for retrieving and executing a Java Runtime Environment (JRE) (e.g., FX Designer Runtime instance (108)) capable of executing the Java application (e.g., JavaFX Application instance (110)) associated with the JNLP file (114).
  • JRE Java Runtime Environment
  • the JNLP file (114) includes all necessary information for retrieving and executing the JavaFX Application instance (110).
  • the information may include the network locations of the FX Designer Runtime files (1 14), the application content files (1 16), and the FX designer tool files (118).
  • the information may further include the version number, configuration, and network location of the JRE (e.g. , FX Designer Runtime instance (108)) necessary to execute the Java application (e.g., JavaFX Application instance (110)). Further, the information may specify the version number, configuration, and network location of the JRE for a given computer configuration.
  • a JNLP file (e.g., JNLP file (1 14)) may provide information regarding separate versions, configurations, and network locations based on a computer's hardware specifications, software specifications, or rate of network communication. Those skilled in the art will appreciate that other information may be included in the JNLP file (114).
  • the Web Start applet (106) uses a
  • the Web Start applet (106) also may include functionality to request, from a content server (e.g., Content Server (104)), files associated with the FX Designer runtime (e.g., FX Designer Runtime files (1 16)).
  • the FX Designer Runtime files (1 16) may be used by a Web Start applet (e.g., Web Start applet (106)) to instantiate a FX Designer Runtime instance (e.g., FX Designer Runtime instance (108)).
  • the Web Start applet (106) may include functionality to provide a FX Designer Runtime instance (e.g., FX Designer Runtime instance (108)) with a JNLP file (e.g., JNLP file (114)) provided by a user browser (e.g. , User Browser (100)).
  • FX Designer Runtime instance e.g., FX Designer Runtime instance (108)
  • JNLP file e.g., JNLP file (114)
  • user browser e.g. , User Browser (100)
  • the FX Designer Runtime instance (108) is a JRE which includes functionality to use the contents of a JNLP file (e.g., JNLP file (114)) to retrieve and execute the Java application (e.g. , JavaFX Application instance (1 10)) associated with the JNLP file (e.g., JNLP file (1 14)).
  • the JRE (or more specifically, instances of JREs (e.g. , FX Designer Runtime instance (108))) provides a layer of software between the operating system and the application running within the JRE instance.
  • the JRE instance includes functionality to allow the application to be agnostic with regard to the underlying operating system and hardware of the host machine. Said another way, an application with the ability to execute within a JRE instance may be executed on any machine capable of executing a compatible JRE instance.
  • the FX Designer Runtime instance (108) requests content files (e.g., JavaFX Application Content files (118)) from a content server (e.g., Content Server (104)).
  • the FX Designer Runtime instance (108) uses the content files (e.g., JavaFX Application Content files (1 18)) to launch the application instance (e.g., JavaFX Application instance (1 10)).
  • the JavaFX Application Content files (1 18) include all files necessary for instantiating an application instance (e.g., JavaFX Application instance (110)).
  • the JavaFX Application Content files (118) may include, for example, program code (e.g., Java classes, Java Archives, etc.), graphic files, audio files, etc.
  • the JavaFX Application Content files (118) may be distributed across more than one Content Server (e.g., Content Server (104)).
  • some JavaFX Application Content files (118) may be retrieved only when they are required by the executing application instance (e.g., JavaFX Application instance (110)).
  • the Content Server (104) is a computing system which may include content management software (e.g., Mercurial, Concurrent Versions System (CVS)).
  • content management software e.g., Mercurial, Concurrent Versions System (CVS)
  • the Content Server (104) stores all files necessary to execute the application instance (e.g., JavaFX Application instance (1 10)), including the FX Designer Runtime files ⁇ e.g., FX Designer Runtime files (116)) and the content files ⁇ e.g., JavaFX Application Content files (118)).
  • the Content Server (104) may also maintain a record of changes made to hosted filed (e.g., FX Designer Runtime files (116), JavaFX Application Content files (118)).
  • the Content Server (104) includes the functionality to generate a JNLP file (e.g., JNLP file (1 14)) associated with FX Designer Runtime files (e.g., FX Designer Runtime files (1 16)) and content files ⁇ e.g., JavaFX Application Content files (118)).
  • the Content Server (104) automatically generates an updated JNLP file ⁇ e.g. JNLP file (1 14)) when FX Designer Runtime files ⁇ e.g. , FX Designer Runtime files (116)) or the content files ⁇ e.g., JavaFX Application Content files (1 18)) are altered.
  • the Content Server (104) also includes functionality to transmit the updated JNLP file (e.g., JNLP file (114) to a webserver ⁇ e.g., Webserver (102)).
  • the FX Designer Runtime instance (108) may receive a request to edit a JavaFX Application instance ⁇ e.g., JavaFX Application instance (110)).
  • the request is received via the instance of the application ⁇ e.g., JavaFX Application instance (1 10)).
  • the request is received via an FX Designer Runtime instance (e.g. , FX Designer Runtime instance (108)).
  • the request may be a combination of user inputs known only to the author of the application to allow only the author to edit the application ⁇ e.g., a text password, an ordered series of mouse clicks, etc.).
  • the Content Server (104) responds to a request to edit an application by providing FX Designer Tool files (e.g. , FX Designer Tool files (120)) to the requesting FX Designer Runtime instance (e.g., FX Designer Runtime instance (108)).
  • FX Designer Runtime instance (108) uses the FX Designer Tool files (e.g., FX Designer Tool files (120)) to create an FX Designer Tool instance (e.g., FX Designer Tool instance (112)).
  • the FX Designer Tool instance (1 12) includes functionality to alter the content files (e.g. , JavaFX Application Content files (118)).
  • the FX Designer Tool instance (112) may include the functionality to alter a copy of the content files (not shown) which exist on a user's computer system (e.g., the computer system executing User Browser (100)).
  • the FX Designer Tool instance (112) includes the functionality to alter a copy of the content files (e.g., JavaFX Application Content files (1 18)) contemporaneously with the execution of the application instance (e.g. , JavaFX Application instance (110)).
  • changes made to the JavaFX Application Content files may be immediately incorporated into the application instance (e.g., JavaFX Application instance (110)) executing on the user's computer.
  • the FX Designer Tool instance (112) includes the functionality to send the altered content files (e.g., JavaFX Application Content files (118)) to the content server (e.g., Content Server (104)).
  • the altered JavaFX Application Content files are only available on the author's computer (e.g., the computer executing the User Browser (100)) at least until the altered content files (e.g., JavaFX Application Content files (118)) are sent to the content server (e.g., Content Server (104)).
  • more than one user may concurrently execute instances of the JavaFX Application (e.g., JavaFX Application instance (110)). Further, in one embodiment of the invention, a first user may request the content files (e.g. , JavaFX Application Content files (118)) from the content server (e.g., Content Server (104)) contemporarily while a second user alters the content files (e.g., JavaFX Application Content files (118)).
  • the content server e.g., Content Server (104)
  • a second user alters the content files (e.g., JavaFX Application Content files (118)).
  • FIG. 2 shows a flow chart for launching an application in accordance with one or more embodiments of the invention.
  • one or more of the steps shown in FIG. 2 may be omitted, repeated, and/or performed in a different order than that shown in FIG. 2. Accordingly, the specific arrangement of steps shown in FIG. 2 should not be construed as limiting the scope of the invention.
  • the client requests an Application from the Webserver.
  • the client is a user browser under the control of a user.
  • the client sends a request to the Webserver for a JavaFX application without specifically requesting a JNLP file.
  • the Webserver provides the JNLP file associated with the Application to the Client.
  • the Client loads the JNLP file into the Web Start applet.
  • the Web Start applet requests the FX Designer Runtime files associated with the JNLP file from the Content Server.
  • the FX Designer Runtime files are used to create a FX Designer Runtime instance.
  • the Web Start applet requests the Application Content files from the Content Server.
  • the request is initiated by the FX Designer Runtime.
  • the Application Content files include a Java Archive file.
  • the FX Designer Runtime loads the Application Content files and launches the Application.
  • the Application Content files include one or more files which describe the behavior of the Application (e.g. , Java classes).
  • the Application is launched using a subset of all Application Content files.
  • Application Content files are requested from the Content Server as needed by the Application instance.
  • FIG. 3 shows a flow chart for launching and editing an application in accordance with one or more embodiments of the invention.
  • one or more of the steps shown in FIG. 3 may be omitted, repeated, and/or performed in a different order than that shown in FIG. 3. Accordingly, the specific arrangement of steps shown in FIG. 3 should not be construed as limiting the scope of the invention.
  • Step 310 the Client sends a request to the Webserver, via the Web
  • Step 310 may be performed following the steps described with reference to FIG. 2.
  • the Content Server responds by sending, to the Web Start applet, the FX Designer Tool files.
  • the Web Start applet loads the FX Designer Tools associated with the Application to create an FX Designer Tool instance.
  • the Client alters the Application Content files using the FX Designer Tool instance.
  • altering the Application Content Files may include making changes to a graphic or audio file.
  • altering the Application Content files may include editing code, which dictates the behavior of the elements in the Application.
  • the Application Content files are edited using the FX Designer Tools.
  • Step 316 the Client sends a request to commit the changes to the Application Content files.
  • Step 318 the new Application Content files are saved on the Content Server.
  • Step 320 the Webserver updates the JNLP file with references to the new Application Content files.
  • a new JNLP file is generated with references to the altered Application Content files.
  • FIG. 4 shows an exemplary communication timeline in accordance with one embodiment of the invention.
  • the exemplary timeline is not intended to limit the scope of the invention. Further, some elements unnecessary for the purposes of the exemplary figure may have been omitted.
  • the exemplary communication timeline includes requests and responses over a period of time between the Content Server (400), Client A (402), the Webserver (404), and Client B.
  • Step 410 Client A (402) requests the Application from the
  • the Webserver (404) responds to the request by providing the JNLP file associated with the Application.
  • Client A (402) uses the JNLP file to locate the files necessary to execute the Application, and requests those files from the Content Server (400).
  • the Content Server (400) provides the FX Designer Runtime files associated with the Application to Client A (402).
  • Client A (402) requests the Application Content files associated with the Application.
  • the Content Server (400) provides the Application Content files to Client A (402).
  • Client A (402) executes the Application.
  • Step 424
  • Client B (406) requests the Application from the Webserver (404).
  • the Webserver (404) responds to the request by providing the JNLP file associated with the Application to Client B (406).
  • Client B (406) uses the JNLP file to locate the files necessary to execute the Application, and requests those files from the Content Server (400).
  • the Content Server (400) provides the FX Designer Runtime files and the Application Content files associated with the Application to Client B (406).
  • Client B (406) executes the Application.
  • both Client A (402) and Client B (406) are executing the same version of the Application.
  • Step 434 Client A (402) sends a request to edit the Application to the Content Server (400).
  • the Content Server (400) responds by providing, to Client A (402), the FX Designer Tool files.
  • Client A (402) loads the FX Designer Tool, and edits the Application Content files.
  • Step 440 Client A (402) indicates to the Content Server (400) that the Application Content files have been altered, and the updated Application Content files are sent to the Content Server (400).
  • Client A (402) is executing a new version of the Application.
  • Client B (406) is executing the original Application lacking the updates sent to the Content Server in Step 440.
  • Step 442 the Content Server (400) notifies the Webserver (404) that the Application has been updated.
  • a new JNLP is generated by the Content Server (400) and transmitted to the Webserver (404).
  • the Webserver (404) generates the new JNLP file using information provided by the Content Server (400).
  • Client B (406) terminates the instance of the Application instantiated in Step 432.
  • Client B (406) requests the Application from the Webserver (404).
  • the Webserver (404) responds to the request by providing, to Client B (406), the new JNLP file associated with the updated Application.
  • Client B (406) uses the new JNLP file to locate the updated files necessary to execute the updated Application, and requests those files from the Content Server (400).
  • the Content Server (400) provides the FX Designer Runtime files and the Application Content files associated with the updated Application to Client B (406).
  • Client B (406) executes the updated Application.
  • both Client A (402) and Client B (406) are executing the updated version of the Application.
  • a networked computer system (500) includes a processor (502), associated memory (504), a storage device (506), and numerous other elements and functionalities typical of today's computers (not shown).
  • the networked computer system (500) may also include input means, such as a keyboard (508) and a mouse (510), and output means, such as a monitor (512).
  • the networked computer system (500) is connected to a local area network (LAN) or a wide area network via a network interface connection (not shown).
  • LAN local area network
  • network interface connection not shown.
  • one or more elements of the aforementioned computer (500) may be remotely located and connected to the other elements over a network.
  • software instructions to perform embodiments of the invention may be stored on a computer readable medium such as a compact disc (CD), a diskette, a tape, or any other physical computer readable storage device.

Abstract

In general, in one aspect, the invention relates to a computer readable medium including software instructions for performing a method, the method including receiving, by a content server, a first request from a client for an application content file, wherein the application content file is associated with a first Java network launch protocol (JNLP) file, providing, in response to the first request, the application content file; receiving, from the client, a second request to edit the application content file, providing, in response to the second request, an application designer tool to the client; receiving, from the client, an altered application content file generated using the application designer tool, generating a second JNLP file associated with the altered application content file, and providing, to a webserver, the second JNLP file.

Description

CONTROLLING A RUNNING APPLICATION FOR LIVE
SCENE GRAPH EDITING
BACKGROUND
[0001] Modern computer applications may be stored on computers in geographically remote locations, or on multiple computers around the world, in order to provide end users with convenient access to the applications. In addition, such applications may be heavily relied upon by end users such that an interruption in access to such applications may cause considerable social and financial frustrations.
[0002] Typical computer applications are made unavailable to end users for a period of time when a new version of the application is deployed. Further, changes made to typical computer applications may only be viewed once the application has been redeployed after the changes have been made.
SUMMARY
[0003] In general, in one aspect, the invention relates to a computer readable medium including software instructions for performing a method, the method including receiving, by a content server, a first request from a client for an application content file, wherein the application content file is associated with a first Java network launch protocol (JNLP) file, providing, in response to the first request, the application content file; receiving, from the client, a second request to edit the application content file, providing, in response to the second request, an application designer tool to the client; receiving, from the client, an altered application content file generated using the application designer tool, generating a second JNLP file associated with the altered application content file, and providing, to a webserver, the second JNLP file.
[0004] In general, in one aspect, the invention relates to a system. The system includes a content server which includes a processor, an application content file, and a memory configured to store instructions, wherein the instructions, when executed by the processor, cause the content server to receive a first request from a client for the application content file, wherein the application content file is associated with a first Java network launch protocol (JNLP) file, provide, in response to the first request, the application content file, receive, from the client, a second request to edit the application content file, provide, in response to the second request, an application designer tool to the client; receive, from the client, an altered application content file generated using the application designer tool, generate a second JNLP file associated with the altered application content file, and provide, to a webserver, the second JNLP file.
[0005] In general, in one aspect, the invention relates to a computer readable medium including software instructions for performing a method, the method including sending, by a client, a first request to a webserver for an application content file, wherein the application content file is associated with a Java network launch protocol (JNLP) file, receiving, from the webserver in response to the first request, the JNLP file, sending a second request to a content server, wherein the second request comprises at least a portion of the JNLP file, receiving, from the content server in response to the second request, the application content file, sending, to the content server, a second request to edit the application content file, receiving, from the content server in response to the third request, an application designer tool to the client, editing the application content file using the application designer tool to obtain an altered content file, sending, to the content server, a fourth request comprising the altered content file.
BRIEF DESCRIPTION OF DRAWINGS
[0006] FIG. 1 shows a system in accordance with one or more embodiments of the invention.
[0007] FIG. 2 shows a flowchart in accordance with one or more embodiments of the invention.
[0008] FIG. 3 shows a flowchart in accordance with one or more embodiments of the invention. [0009] FIG. 4 shows an example in accordance with one or more embodiments of the invention.
[0010] FIG. 5 shows a computer system in accordance with one or more embodiments of the invention.
DETAILED DESCRIPTION
[0011] Exemplary embodiments of the invention will be described with reference to the accompanying drawings. Like items in the drawings are shown with the same reference numbers.
[0012] In embodiments of the invention, numerous specific details are set forth in order to provide a more thorough understanding of the invention. However, it will be apparent to one of ordinary skill in the art that the invention may be practiced without these specific details. In other instances, well-known features have not been described in detail to avoid obscuring the invention.
[0013] In general, embodiments of the invention relate to controlling a running JavaFX application for live scene graph editing. More specifically, embodiments of the invention relate a method and system for editing the content and behavior of a deployed (i.e., accessible by an end-user) JavaFX application without interrupting user access to the application. (Java® and JavaFX® are registered trademarks owned by Sun Microsystems, Inc., Mountain View, CA.)
[0014] FIG. 1 shows a system in accordance with one embodiment of the invention. The system includes a User Browser (100), a Webserver (102), and a Content Server (104). The User Browser (100) includes a Web Start applet (106), an FX designer runtime instance (108), a JavaFX Application instance (110), and an FX Designer Tool instance (112). The Webserver (102) includes a Java Network Launching Protocol (JNLP) file (114). The Content Server (104) includes FX Designer Runtime files (116), JavaFX Application Content files (118), and FX Designer Tool files (120). Each of these components is discussed in detail below. [0015] In one embodiment of the invention, the User Browser (100) is an application executing on a user computer system (not shown) used for interacting with internet content. The User Browser may be any internet browser known in the art capable of executing a Web Start applet (106), examples of which may include Internet Explorer browser (Internet Explorer® is a registered trademark owned by Microsoft Corp.), Firefox® browser (Firefox is a registered trademark owned by the Mozilla Foundation), Safari browser (Safari is a registered trademark owned by Apple Computer, Inc.), and Google Chrome™ browser (Google Chrome™ is a trademark owned by Google, Inc.).
[0016] In one embodiment of the invention, the User Browser (100), under the control of a user, may navigate to a webpage intended to host a JavaFX application (e.g., JavaFX Application instance (1 10)). In one embodiment of the invention, the webpage includes a reference to the JNLP file (114) associated with the embedded JavaFX application (e.g., JavaFX Application instance (110)). In one embodiment of the invention, the User Browser (100) is configured to request the JNLP file (1 14) from the Webserver (102).
[0017] In one embodiment of the invention, the Webserver (102) is configured to respond to a request by the User Browser (100) for a JavaFX application (e.g., JavaFX Application instance (110)) by providing, to the User Browser (100), a JNLP file (e.g., JNLP file (1 14)) associated with the JavaFX application(e.g., JavaFX Application instance (1 10)). In one embodiment of the invention, the Webserver (102) is an application executing on a computer system (not shown), configured to respond to requests sent over a network (e.g., a local area network, a wide area network, the Internet, etc.). In one embodiment of the invention, the Webserver (102) may store more than one JNLP file (e.g., JNLP file (114)). Further, each JNLP file may be associated with a different application, and multiple JNLP files (e.g., JNLP file (114)) may be associated with different versions of the same application. In one embodiment of the invention, the User Browser (100) is configured to instantiate a Web Start applet (e.g., Web Start applet (106)) in response to receiving a JNLP file (e.g. , JNLP file (1 14)) from a webserver (e.g., Webserver (102)). In one embodiment of the invention, the User Browser (100) may provide a received JNLP file (e.g., JNLP file (114)) directly to the Web Start applet (106).
[0018] In one embodiment of the invention, the Web Start applet (106) creates a platform within the User Browser (100) capable of initializing Java application software (e.g., JavaFX Application instance (110)) using an associated JNLP file (e.g., JNLP file (1 14)). More specifically, in one embodiment of the invention, the Web Start applet (106) includes functionality for retrieving and executing a Java Runtime Environment (JRE) (e.g., FX Designer Runtime instance (108)) capable of executing the Java application (e.g., JavaFX Application instance (110)) associated with the JNLP file (114).
[0019] In one embodiment of the invention, the JNLP file (114) includes all necessary information for retrieving and executing the JavaFX Application instance (110). The information may include the network locations of the FX Designer Runtime files (1 14), the application content files (1 16), and the FX designer tool files (118). The information may further include the version number, configuration, and network location of the JRE (e.g. , FX Designer Runtime instance (108)) necessary to execute the Java application (e.g., JavaFX Application instance (110)). Further, the information may specify the version number, configuration, and network location of the JRE for a given computer configuration. For example, a JNLP file (e.g., JNLP file (1 14)) may provide information regarding separate versions, configurations, and network locations based on a computer's hardware specifications, software specifications, or rate of network communication. Those skilled in the art will appreciate that other information may be included in the JNLP file (114).
[0020] In one embodiment of the invention, the Web Start applet (106) uses a
JNLP file (e.g., JNLP file (114)) to determine the location and configuration of a FX Designer Runtime (e.g., FX Designer Runtime (108)). The Web Start applet (106) also may include functionality to request, from a content server (e.g., Content Server (104)), files associated with the FX Designer runtime (e.g., FX Designer Runtime files (1 16)). The FX Designer Runtime files (1 16) may be used by a Web Start applet (e.g., Web Start applet (106)) to instantiate a FX Designer Runtime instance (e.g., FX Designer Runtime instance (108)). Further, the Web Start applet (106) may include functionality to provide a FX Designer Runtime instance (e.g., FX Designer Runtime instance (108)) with a JNLP file (e.g., JNLP file (114)) provided by a user browser (e.g. , User Browser (100)).
[0021] In one embodiment of the invention, the FX Designer Runtime instance (108) is a JRE which includes functionality to use the contents of a JNLP file (e.g., JNLP file (114)) to retrieve and execute the Java application (e.g. , JavaFX Application instance (1 10)) associated with the JNLP file (e.g., JNLP file (1 14)). The JRE (or more specifically, instances of JREs (e.g. , FX Designer Runtime instance (108))) provides a layer of software between the operating system and the application running within the JRE instance. The JRE instance includes functionality to allow the application to be agnostic with regard to the underlying operating system and hardware of the host machine. Said another way, an application with the ability to execute within a JRE instance may be executed on any machine capable of executing a compatible JRE instance.
[0022] In one embodiment of the invention, the FX Designer Runtime instance (108) requests content files (e.g., JavaFX Application Content files (118)) from a content server (e.g., Content Server (104)). In one embodiment of the invention, the FX Designer Runtime instance (108) uses the content files (e.g., JavaFX Application Content files (1 18)) to launch the application instance (e.g., JavaFX Application instance (1 10)). In one embodiment of the invention, the JavaFX Application Content files (1 18) include all files necessary for instantiating an application instance (e.g., JavaFX Application instance (110)). The JavaFX Application Content files (118) may include, for example, program code (e.g., Java classes, Java Archives, etc.), graphic files, audio files, etc. In one embodiment of the invention, the JavaFX Application Content files (118) may be distributed across more than one Content Server (e.g., Content Server (104)). In one embodiment of the invention, some JavaFX Application Content files (118) may be retrieved only when they are required by the executing application instance (e.g., JavaFX Application instance (110)). [0023] In one embodiment of the invention, the Content Server (104) is a computing system which may include content management software (e.g., Mercurial, Concurrent Versions System (CVS)). In one embodiment of the invention, the Content Server (104) stores all files necessary to execute the application instance (e.g., JavaFX Application instance (1 10)), including the FX Designer Runtime files {e.g., FX Designer Runtime files (116)) and the content files {e.g., JavaFX Application Content files (118)). In addition, the Content Server (104) may also maintain a record of changes made to hosted filed (e.g., FX Designer Runtime files (116), JavaFX Application Content files (118)). In one embodiment of the invention, the Content Server (104) includes the functionality to generate a JNLP file (e.g., JNLP file (1 14)) associated with FX Designer Runtime files (e.g., FX Designer Runtime files (1 16)) and content files {e.g., JavaFX Application Content files (118)). In one embodiment of the invention, the Content Server (104) automatically generates an updated JNLP file {e.g. JNLP file (1 14)) when FX Designer Runtime files {e.g. , FX Designer Runtime files (116)) or the content files {e.g., JavaFX Application Content files (1 18)) are altered. In one embodiment of the invention, the Content Server (104) also includes functionality to transmit the updated JNLP file (e.g., JNLP file (114) to a webserver {e.g., Webserver (102)).
[0024] In one embodiment of the invention, the FX Designer Runtime instance (108) may receive a request to edit a JavaFX Application instance {e.g., JavaFX Application instance (110)). In one embodiment of the invention, the request is received via the instance of the application {e.g., JavaFX Application instance (1 10)). In one embodiment of the invention, the request is received via an FX Designer Runtime instance (e.g. , FX Designer Runtime instance (108)). In one embodiment of the invention, the request may be a combination of user inputs known only to the author of the application to allow only the author to edit the application {e.g., a text password, an ordered series of mouse clicks, etc.).
[0025] In one embodiment of the invention, the Content Server (104) responds to a request to edit an application by providing FX Designer Tool files (e.g. , FX Designer Tool files (120)) to the requesting FX Designer Runtime instance (e.g., FX Designer Runtime instance (108)). In one embodiment of the invention, the FX Designer Runtime instance (108) uses the FX Designer Tool files (e.g., FX Designer Tool files (120)) to create an FX Designer Tool instance (e.g., FX Designer Tool instance (112)). In one embodiment of the invention, the FX Designer Tool instance (1 12) includes functionality to alter the content files (e.g. , JavaFX Application Content files (118)). More specifically, the FX Designer Tool instance (112) may include the functionality to alter a copy of the content files (not shown) which exist on a user's computer system (e.g., the computer system executing User Browser (100)). In one embodiment of the invention, the FX Designer Tool instance (112) includes the functionality to alter a copy of the content files (e.g., JavaFX Application Content files (1 18)) contemporaneously with the execution of the application instance (e.g. , JavaFX Application instance (110)). In addition, changes made to the JavaFX Application Content files may be immediately incorporated into the application instance (e.g., JavaFX Application instance (110)) executing on the user's computer. Further, in one embodiment of the invention, the FX Designer Tool instance (112) includes the functionality to send the altered content files (e.g., JavaFX Application Content files (118)) to the content server (e.g., Content Server (104)). In one embodiment of the invention, the altered JavaFX Application Content files are only available on the author's computer (e.g., the computer executing the User Browser (100)) at least until the altered content files (e.g., JavaFX Application Content files (118)) are sent to the content server (e.g., Content Server (104)).
[0026] In one embodiment of the invention, more than one user may concurrently execute instances of the JavaFX Application (e.g., JavaFX Application instance (110)). Further, in one embodiment of the invention, a first user may request the content files (e.g. , JavaFX Application Content files (118)) from the content server (e.g., Content Server (104)) contemporarily while a second user alters the content files (e.g., JavaFX Application Content files (118)).
[0027] FIG. 2 shows a flow chart for launching an application in accordance with one or more embodiments of the invention. In one or more embodiments of the invention, one or more of the steps shown in FIG. 2 may be omitted, repeated, and/or performed in a different order than that shown in FIG. 2. Accordingly, the specific arrangement of steps shown in FIG. 2 should not be construed as limiting the scope of the invention.
[0028] In Step 210, the client requests an Application from the Webserver. In one embodiment of the invention, the client is a user browser under the control of a user. In one embodiment of the invention, the client sends a request to the Webserver for a JavaFX application without specifically requesting a JNLP file. In Step 212, the Webserver provides the JNLP file associated with the Application to the Client. In Step 214, the Client loads the JNLP file into the Web Start applet. In Step 216, the Web Start applet requests the FX Designer Runtime files associated with the JNLP file from the Content Server. In one embodiment of the invention, the FX Designer Runtime files are used to create a FX Designer Runtime instance. In Step 218, the Web Start applet requests the Application Content files from the Content Server. In one embodiment of the invention, the request is initiated by the FX Designer Runtime. In one embodiment of the invention, only files necessary to launch the program are requested. In one embodiment of the invention, the Application Content files include a Java Archive file. In Step 220, the FX Designer Runtime loads the Application Content files and launches the Application. In one embodiment of the invention, the Application Content files include one or more files which describe the behavior of the Application (e.g. , Java classes). In one emdoiment of the invention, the Application is launched using a subset of all Application Content files. In one embodiment of the invention, Application Content files are requested from the Content Server as needed by the Application instance.
[0029] FIG. 3 shows a flow chart for launching and editing an application in accordance with one or more embodiments of the invention. In one or more embodiments of the invention, one or more of the steps shown in FIG. 3 may be omitted, repeated, and/or performed in a different order than that shown in FIG. 3. Accordingly, the specific arrangement of steps shown in FIG. 3 should not be construed as limiting the scope of the invention.
[0030] In Step 310, the Client sends a request to the Webserver, via the Web
Start applet, to edit the Application. In one embodiment of the invention, Step 310 may be performed following the steps described with reference to FIG. 2. In one embodiment of the invention, the Content Server responds by sending, to the Web Start applet, the FX Designer Tool files. In Step 312, the Web Start applet loads the FX Designer Tools associated with the Application to create an FX Designer Tool instance. In Step 314, the Client alters the Application Content files using the FX Designer Tool instance. In one embodiment of the invention, altering the Application Content Files may include making changes to a graphic or audio file. In one embodiment of the invention, altering the Application Content files may include editing code, which dictates the behavior of the elements in the Application. In one embodiment of the invention, the Application Content files are edited using the FX Designer Tools. In Step 316, the Client sends a request to commit the changes to the Application Content files. In Step 318, the new Application Content files are saved on the Content Server. In Step 320, the Webserver updates the JNLP file with references to the new Application Content files. In one embodiment of the invention, a new JNLP file is generated with references to the altered Application Content files.
[0031] FIG. 4 shows an exemplary communication timeline in accordance with one embodiment of the invention. The exemplary timeline is not intended to limit the scope of the invention. Further, some elements unnecessary for the purposes of the exemplary figure may have been omitted.
[0032] As depicted in FIG. 4, the exemplary communication timeline includes requests and responses over a period of time between the Content Server (400), Client A (402), the Webserver (404), and Client B.
[0033] In Step 410, Client A (402) requests the Application from the
Webserver (404). In Step 412, the Webserver (404) responds to the request by providing the JNLP file associated with the Application. In Step 414, Client A (402) uses the JNLP file to locate the files necessary to execute the Application, and requests those files from the Content Server (400). In Step 416, the Content Server (400) provides the FX Designer Runtime files associated with the Application to Client A (402). In Step 418, Client A (402) requests the Application Content files associated with the Application. In Step 420, the Content Server (400) provides the Application Content files to Client A (402). In Step 422, Client A (402) executes the Application.
[0034] Continuing with the discussion of exemplary FIG. 4, in Step 424,
Client B (406) requests the Application from the Webserver (404). In Step 426, the Webserver (404) responds to the request by providing the JNLP file associated with the Application to Client B (406). In Step 428, Client B (406) uses the JNLP file to locate the files necessary to execute the Application, and requests those files from the Content Server (400). In Step 430, the Content Server (400) provides the FX Designer Runtime files and the Application Content files associated with the Application to Client B (406). In Step 432, Client B (406) executes the Application. At Step 432, both Client A (402) and Client B (406) are executing the same version of the Application.
[0035] In Step 434, Client A (402) sends a request to edit the Application to the Content Server (400). In Step 436, the Content Server (400) responds by providing, to Client A (402), the FX Designer Tool files. At Step 438, Client A (402) loads the FX Designer Tool, and edits the Application Content files. At Step 440, Client A (402) indicates to the Content Server (400) that the Application Content files have been altered, and the updated Application Content files are sent to the Content Server (400). Before Step 442, Client A (402) is executing a new version of the Application. Contemporaneously, Client B (406) is executing the original Application lacking the updates sent to the Content Server in Step 440. In Step 442, the Content Server (400) notifies the Webserver (404) that the Application has been updated. In one embodiment of the invention, a new JNLP is generated by the Content Server (400) and transmitted to the Webserver (404). In one embodiment of the invention, the Webserver (404) generates the new JNLP file using information provided by the Content Server (400).
[0036] Continuing with the discussion of exemplary FIG. 4, at Step 444,
Client B (406) terminates the instance of the Application instantiated in Step 432. In Step 446, Client B (406) requests the Application from the Webserver (404). In Step 448, the Webserver (404) responds to the request by providing, to Client B (406), the new JNLP file associated with the updated Application. In Step 450, Client B (406) uses the new JNLP file to locate the updated files necessary to execute the updated Application, and requests those files from the Content Server (400). In Step 452, the Content Server (400) provides the FX Designer Runtime files and the Application Content files associated with the updated Application to Client B (406). In Step 454, Client B (406) executes the updated Application. At Step 454, both Client A (402) and Client B (406) are executing the updated version of the Application.
[0037] An embodiment of the invention may be implemented on virtually any type of computer regardless of the platform being used. For example, as shown in FIG. 5, a networked computer system (500) includes a processor (502), associated memory (504), a storage device (506), and numerous other elements and functionalities typical of today's computers (not shown). The networked computer system (500) may also include input means, such as a keyboard (508) and a mouse (510), and output means, such as a monitor (512). The networked computer system (500) is connected to a local area network (LAN) or a wide area network via a network interface connection (not shown). Those skilled in the art will appreciate that these input and output means may take other forms. Further, those skilled in the art will appreciate that one or more elements of the aforementioned computer (500) may be remotely located and connected to the other elements over a network. Further, software instructions to perform embodiments of the invention may be stored on a computer readable medium such as a compact disc (CD), a diskette, a tape, or any other physical computer readable storage device.
[0038] While the invention has been described with respect to a limited number of embodiments, those skilled in the art, having benefit of this disclosure, will appreciate that other embodiments can be devised which do not depart from the scope of the invention as disclosed herein. Accordingly, the scope of the invention should be limited only by the attached claims.

Claims

CLAIMS What is claimed is:
1. A method comprising:
receiving, by a content server, a first request from a client for an application content file, wherein the application content file is associated with a first Java network launch protocol (JNLP) file;
providing, in response to the first request, the application content file;
receiving, from the client, a second request to edit the application content file; providing, in response to the second request, an application designer tool to the client;
receiving, from the client, an altered application content file generated using the application designer tool;
generating a second JNLP file associated with the altered application content file; and
providing, to a webserver, the second JNLP file.
2. The method of claim 1, wherein the method further comprises:
receiving, by the content server, a third request from a subsequent client, wherein the third request comprises at least a portion of the second JNLP file; and
providing, to the subsequent client, the altered application content file in response to the third request.
3. The method of claim 1 or 2, wherein the application content file is one of a plurality of application content files.
4. The method of any preceding claim, wherein the first JNLP file comprises a network location of the application content file.
5. The method of any preceding claim, wherein the client executes at least one file associated with the application content file in response to the content server providing the application content file.
6. The method of any preceding claim, wherein the application content file is a Java archive.
7. The method of any preceding claim, wherein the content server and the webserver are executing on a first computing system, and wherein the client is executing on a second computing system.
8. A method comprising:
sending, by a client, a first request to a webserver for an application content file, wherein the application content file is associated with a Java network launch protocol (JNLP) file;
receiving, from the webserver in response to the first request, the JNLP file; sending a second request to a content server, wherein the second request comprises at least a portion of the JNLP file;
receiving, from the content server in response to the second request, the application content file;
sending, to the content server, a second request to edit the application content file;
receiving, from the content server in response to the third request, an application designer tool to the client;
editing the application content file using the application designer tool to obtain an altered content file; and
sending, to the content server, a fourth request comprising the altered content file.
9. The method of claim 8, wherein the method further comprises:
sending, by the client, a fifth request to the webserver for the application content file;
receiving, from the webserver in response to the fifth request, a new JNLP file;
sending a sixth request to the content server, wherein the sixth request comprises at least a portion of the new JNLP file;
receiving, from the content server in response to the sixth request, the altered application content file;
10. The method of claim 8 or 9, wherein the application content file is one of a plurality of application content files.
11. The method of any of claims 8 to 10, wherein the JNLP file comprises a network location of the application content file.
12. The method of any of claims 8 to 11, wherein the client executes the application content file in response to the content server providing the application content file.
13. The method of any of claims 8 to 12, wherein the application content file is a Java archive.
14. The method of any of claims 8 to 13, wherein the content server and the webserver are executing on a first computing system, and wherein the client is executing on a second computing system.
15. A computer program comprising software instructions that when executed perform the method of any preceding claim.
16. A computer readable storage medium containing the computer program of claim 15.
17. A system comprising a content server having an application content file, wherein the content server is configured to:
receive a first request from a client for the application content file, wherein the application content file is associated with a first Java network launch protocol (JNLP) file;
provide, in response to the first request, the application content file;
receive, from the client, a second request to edit the application content file;
provide, in response to the second request, an application designer tool to the client;
receive, from the client, an altered application content file generated using the application designer tool; generate a second JNLP file associated with the altered application content file; and
provide, to a webserver, the second JNLP file.
18. The system of claim 17, wherein the content server is further configured to: receive a third request from a subsequent client, wherein the third request comprises at least a portion of the second JNLP file; and provide, to the subsequent client, the altered application content file in response to the third request.
19. The system of claim 17 or 18, wherein the application content file is one of a plurality of application content files.
20. The system of any of claims 17 to 19, wherein the first JNLP file comprises a network location of the application content file.
21. The system of any of claims 17 to 20, wherein the client executes at least one file associated with the application content file in response to the content server providing the application content file.
22. The system of any of claims 17 to 21, wherein the application content file is a Java archive.
A client system configured to implement the method of any of claims 8 to 14.
PCT/US2011/036469 2010-05-24 2011-05-13 Controlling a running application for live scene graph editing WO2011149687A1 (en)

Priority Applications (2)

Application Number Priority Date Filing Date Title
CN201180002458.5A CN102473103B (en) 2010-05-24 2011-05-13 The application program of controlling run is edited to carry out real-time scene figure
EP11722665.4A EP2435912B1 (en) 2010-05-24 2011-05-13 Controlling a running application for live scene graph editing

Applications Claiming Priority (2)

Application Number Priority Date Filing Date Title
US12/786,113 US9430222B2 (en) 2010-05-24 2010-05-24 Controlling a running application for live scene graph editing
US12/786,113 2010-05-24

Publications (1)

Publication Number Publication Date
WO2011149687A1 true WO2011149687A1 (en) 2011-12-01

Family

ID=44121247

Family Applications (1)

Application Number Title Priority Date Filing Date
PCT/US2011/036469 WO2011149687A1 (en) 2010-05-24 2011-05-13 Controlling a running application for live scene graph editing

Country Status (4)

Country Link
US (1) US9430222B2 (en)
EP (1) EP2435912B1 (en)
CN (1) CN102473103B (en)
WO (1) WO2011149687A1 (en)

Families Citing this family (6)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US8972543B1 (en) * 2012-04-11 2015-03-03 Spirent Communications, Inc. Managing clients utilizing reverse transactions
WO2015171549A2 (en) * 2014-05-05 2015-11-12 Citrix Systems, Inc. Facilitating communication between mobile applications
US10404783B2 (en) * 2017-08-16 2019-09-03 Vmware, Inc. Outside-of-network management of a component in a virtual data center
US11025453B2 (en) 2018-03-23 2021-06-01 Vmware, Inc. Outside-of-network management of a component in a virtual data center using a remote display on a host management server
CA3098864A1 (en) * 2018-05-04 2019-11-07 Benjamin William LAIBSON Emulation of cloud computing service regions
US11809839B2 (en) 2022-01-18 2023-11-07 Robert Lyden Computer language and code for application development and electronic and optical communication

Family Cites Families (26)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US5999972A (en) * 1996-07-01 1999-12-07 Sun Microsystems, Inc. System, method and article of manufacture for a distributed computer system framework
US6230309B1 (en) * 1997-04-25 2001-05-08 Sterling Software, Inc Method and system for assembling and utilizing components in component object systems
GB2329490B (en) * 1997-09-19 2002-06-05 Ibm Remote application design
US6973640B2 (en) * 2000-10-04 2005-12-06 Bea Systems, Inc. System and method for computer code generation
US8407125B2 (en) * 2001-07-31 2013-03-26 Ameriprise Financial, Inc. System and method for providing financial planning and advice
US7228353B1 (en) * 2002-03-28 2007-06-05 Emc Corporation Generating and launching remote method invocation servers for individual client applications
US7702636B1 (en) * 2002-07-31 2010-04-20 Cadence Design Systems, Inc. Federated system and methods and mechanisms of implementing and using such a system
US7523116B2 (en) * 2003-10-30 2009-04-21 International Business Machines Corporation Selection of optimal execution environment for software applications
US7117113B1 (en) * 2004-03-01 2006-10-03 Cisco Technology, Inc. Automated data collection and analysis
WO2005114381A2 (en) * 2004-05-14 2005-12-01 Gt Software, Inc. Systems and methods for web service function, definition implementation and/or execution
US7703024B2 (en) * 2004-08-31 2010-04-20 Sap Ag Obtaining a graphical user interface to access a remote computing system
US20060218228A1 (en) * 2005-03-24 2006-09-28 Security First Technologies Corp Client platform architecture
US7613789B2 (en) * 2005-04-18 2009-11-03 Research In Motion Limited Development tool and method for automating detection and construction of notification-based component applications
WO2007062018A2 (en) * 2005-11-18 2007-05-31 Bertorello, Inc. Information synchronization
JP2007179171A (en) * 2005-12-27 2007-07-12 Internatl Business Mach Corp <Ibm> Software development device for model for which privacy retention is required
US20080114641A1 (en) * 2006-11-15 2008-05-15 Christopher Keenum Process and apparatus for marketing data collection and analysis aggregation of funds
US20080208602A1 (en) * 2007-01-09 2008-08-28 Westernoff W Gary Method and apparatus for an on-line building registry and organizer
US20080209392A1 (en) * 2007-02-26 2008-08-28 Able Steve L Systems and Methods for Definition and Execution of Batch Processing Services
CN101387953A (en) * 2007-09-14 2009-03-18 环达电脑(上海)有限公司 Collaboration software development system and method
US8117601B2 (en) * 2007-11-14 2012-02-14 Microsoft Corporation Internal test and manipulation of an application
US20090128365A1 (en) * 2007-11-19 2009-05-21 Laskin Bruce Steven Methods and systems for delivering real-time traffic video to a handheld device
WO2009097350A1 (en) * 2008-01-29 2009-08-06 Palm, Inc. Secure application signing
JP5521284B2 (en) * 2008-05-14 2014-06-11 セイコーエプソン株式会社 Positioning method and positioning device
US8850409B2 (en) * 2008-05-21 2014-09-30 Optumsoft, Inc. Notification-based constraint set translation to imperative execution
US9703443B2 (en) * 2008-09-25 2017-07-11 Oracle America, Inc. Method and system for creating a free-form visual user interface element
US8214795B2 (en) * 2008-11-26 2012-07-03 Optumsoft, Inc. Efficient automated translation of procedures in constraint-based language

Non-Patent Citations (2)

* Cited by examiner, † Cited by third party
Title
EL RHALIBI A ET AL: "3D Java web-based games development and deployment", MULTIMEDIA COMPUTING AND SYSTEMS, 2009. ICMCS '09. INTERNATIONAL CONFERENCE ON, IEEE, PISCATAWAY, NJ, USA, 2 April 2009 (2009-04-02), pages 553 - 559, XP031530512, ISBN: 978-1-4244-3756-6 *
YANAGISAWA H ET AL: "Server Side C-DASH: Ubiquitous Hardware/Software Codesign Environment", MOBILE DATA MANAGEMENT, 2006. MDM 2006. 7TH INTERNATIONAL CONFERENCE O N NARA, JAPAN 10-12 MAY 2006, PISCATAWAY, NJ, USA,IEEE, 10 May 2006 (2006-05-10), pages 99 - 103, XP010917973, ISBN: 978-0-7695-2526-6, DOI: 10.1109/MDM.2006.142 *

Also Published As

Publication number Publication date
EP2435912A1 (en) 2012-04-04
EP2435912B1 (en) 2018-12-26
US9430222B2 (en) 2016-08-30
CN102473103A (en) 2012-05-23
US20110289192A1 (en) 2011-11-24
CN102473103B (en) 2015-11-25

Similar Documents

Publication Publication Date Title
JP6774499B2 (en) Providing access to hybrid applications offline
US9575739B2 (en) Performing unattended software installation
US8407693B2 (en) Managing package dependencies
US8364643B2 (en) Method and system thereof for restoring virtual desktops
US20180196665A1 (en) Managing, using, and updating application resources
US20170124103A1 (en) Method and Apparatus for Creating System Disk Snapshot of Virtual Machine
US20160110180A1 (en) Automatic recognition of web application
US20070220417A1 (en) System and method for editing online documents
US9430222B2 (en) Controlling a running application for live scene graph editing
US9870372B2 (en) Fast application streaming using on-demand staging
US9898471B1 (en) Computer implemented system and method, and computer program product, for generic source control for orchestration workflows
US8640121B2 (en) Facilitating multi-installer product installations
KR20070049166A (en) System and method for extraction and creation of application meta-information within a software application repository
JP2013524365A (en) Virtual application extension point
US9075678B2 (en) Client and server for installation of files embedded within a client profile
US20220188273A1 (en) Per-node metadata for custom node behaviors across platforms
US20130198156A1 (en) Methods and Systems for an Action-Based Interface for Files and Other Assets
TW201546627A (en) Conditional saving of input data
US20100318967A1 (en) Supplementary deployment actions
US7836449B2 (en) Extensible infrastructure for task display and launch
US10083052B1 (en) Streamlined remote application streaming technology configuration and usage
CN115336237A (en) Predictive provisioning of remotely stored files
US20120005162A1 (en) Managing Copies of Data Structures in File Systems
US8924963B2 (en) In-process intermediary to create virtual processes
US11424982B2 (en) Remediation of a system to new desired state using configuration dependency graph

Legal Events

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

Ref document number: 201180002458.5

Country of ref document: CN

WWE Wipo information: entry into national phase

Ref document number: 2011722665

Country of ref document: EP

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

Ref document number: 11722665

Country of ref document: EP

Kind code of ref document: A1

NENP Non-entry into the national phase

Ref country code: DE