1. Field of the Invention
This invention relates generally to mobile devices, and more particularly to systems and methods for optimizing start-up time of optional applications being installed on mobile devices.
2. Description of the Related Art
Today, embedded mobile devices are being increasingly used by consumers all around the world which has lead to an ever-increasing demand for additional services. For instance, embedded mobile device users were initially limited to using closed system mobile devices. That is, the users could only implement applications pre-installed on the embedded mobile device.
As consumer demands have increased and new technologies have developed, in addition to the pre-installed applications, consumers are able to access and use applications that are being executed on the severs connected to the mobile devices. The trade off, however, is that mobile devices must be connected to a server continuously while a consumer is running the application on the mobile device. Of course, one of ordinary skill in the art appreciates that maintaining continuous connection with the server for an extended period of time can be costly and will restrict free movement of the users.
As an alternative, applications can be downloaded from a server application bank into the embedded mobile device, allowing the downloaded application to run on the mobile device. In such situations, the embedded mobile device is only in communication with the server while the application is being downloaded to the device. In this manner, the connection time is shortened, thus reducing the connection costs and increasing user mobility.
While the connection costs are reduced, per use, the downloading and execution of the application must be performed every single time the user chooses to utilize the application. Furthermore, execution of applications from servers involves additional complex issues. Primarily, applications downloaded from the server cannot be launched in the same way as a pre-installed application. At times, it may take an application between 10 seconds and 2 minutes or longer to be loaded. As can be appreciated, such delay in loading applications is aggravating to consumers, which can leave consumers less than satisfied.
Furthermore, different embedded mobile devices implement diverse platforms. Thus, applications stored to a server application bank, generally, do not have a generic format making them platform specific. For such applications to be downloaded and executed on embedded mobile devices, the devices must first provide the server information regarding the type of the device platform, version, etc. Only then, the server can send the device the application in the format matching that of the embedded mobile device platform. Once the application is downloaded, the device then has to process the application so that the application can be executed, which depending on the device and application can take more time than the average user is willing to spend.
In view of the foregoing, a need therefore exists in the art for a method and system capable of optimizing start-up time of applications that can be optionally downloaded and installed on mobile devices.
Broadly speaking, the present invention fills this need by providing a method and a system for optimizing the start-up time of downloadable applications installed on a mobile device. In one embodiment, downloadable applications are downloaded from a server to a device and are pre-processed in the device. It should be appreciated that the present invention can be implemented in numerous ways, including as a process, an apparatus, a system, a device, or a method. Several inventive embodiments of the present invention are described below.
In one embodiment, a method for installing an application on a mobile device is provided. The method includes obtaining the application over a network following by storing the application on the mobile device. The method further includes processing the application on the mobile device to generate a processed application. Also include in the method is storing the processed application on the mobile device and requesting access to the application. The method also includes mapping the request to access the application to the processed application and launching the processed application on the mobile device.
In another embodiment, a method for accessing an application on a mobile device is provided. The method includes obtaining the application over a network and storing the application on the mobile device. Also included is processing the application on the mobile device to generate a processed application. The method further includes storing the processed application on the mobile device and requesting access to the application after installing the application on the mobile device. The request is mapped to the processed application and the processed application is launched.
In still another embodiment, a method for improving start-up time of a downloadable application on a device is provided. The method includes downloading an entry of the downloadable application to the device and pre-processing the entry on the device. Also included is generating a pre-processed entry and executing the downloadable application on the device using the pre-processed entry.
In yet another embodiment, a method for improving start-up time of a downloadable application on a device is provided. The method includes downloading an entry of the downloadable application to the device and decompressing the entry on the device generating a decompressed entry. Also included in the method is converting the decompressed entry into a native format of the device generating a pre-processed entry. The method also includes generating a cache file configured to include a mapping of the entry to the pre-processed entry. Further included in the method is executing the downloadable application on the device using the pre-processed entry.
In still another embodiment, a method for uninstalling a downloadable application installed on a device is provided. The method includes deleting an entry of the downloadable application previously installed on the device. The method further includes deleting the pre-processed entry corresponding to the entry and deleting a cache file.
Other aspects and advantages of the invention will become apparent from the following detailed description, taken in conjunction with the accompanying drawings, illustrating by way of example the principles of the invention.
The present invention will be readily understood by the following detailed description in conjunction with the accompanying drawings, and like reference numerals designate like structural elements.
Inventions for optimizing the start-up time of downloadable applications installed on a mobile device are provided. Several exemplary embodiments of the invention will now be described in detail with reference to the accompanying drawings.
The embodiments of the present invention provide methods and system for optimizing the start-up time of downloadable applications installed on a mobile device. In one embodiment, during the installation of an application on the device, the application is downloaded from a server application repository to the device in which the application is subsequently pre-processed. In one example, the server is a Java™ 2 Enterprise Edition (J2EE)™ server serving Java applications specially designed for mobile devices. Of course, the server-device communication interface can take on many forms, and can be a product developed by any company, so long as the claimed functions can be executed thereon.
In one example, upon receiving a request from a device, a server provides a list of downloadable entries suitable to be downloaded to the device. “Downloadable applications” or “downloadable MIDlets” are herein defined as applications or MIDlets that can be downloaded, and executed on a device in the same manner as a pre-installed application or MIDlet. Upon selecting a downloadable entry, a Java Application Descriptor (JAD) file of the selected entry is dispatched to the embedded mobile device. In one example, the JAD file includes the text description of the application or MIDlet. If the embedded mobile device can accommodate the requirements of the selected entry, the Java Archive (JAR) file of the selected entry is dispatched to the embedded mobile device. In one embodiment, the JAR file contains the class files of the application or MIDlet as well as all extra auxiliary resources associated with the application or MIDlet.
At this point, the JAD file and the JAR file of the selected entry are pre-processed and mapped to a corresponding mapped entry using a sharable computer code stored to a cache file. In one embodiment, the pre-processing of an entry includes decompressing of the files thereon and translating of the decompressed files into the device hardware native format.
In the following description, numerous specific details are set forth in order to provide a thorough understanding of the present invention. It will be understood, however, to one skilled in the art, that the present invention may be practiced without some or all of these specific details. In other instances, well known process operations have not been described in detail in order not to unnecessarily obscure the present invention.
I. Environment Description
As embodiments of the present invention can implement the J2EE, J2ME, or Enterprise JavaBeans (EJB) application, a brief introduction to J2ME, J2EE, and EJB architectures are provided below. The Java 2, Micro Edition (J2ME) platform is a Java platform for consumer and embedded devices such as mobile phones, Personal Digital Assistants (PDAs), TV set-top boxes, in-vehicle telematics systems, and a broad range of embedded devices. Similar to the enterprise (J2EE), desktop (J2SE™) and smart card (Java Card™) counterparts, the J2ME platform is a set of standard Java application program interfaces (APIs) defined through the Java Community ProcessSM program by expert groups that include leading device manufacturers, software vendors and service providers.
The J2ME platform delivers the power and benefits of Java technology tailored for consumer and embedded devices. The J2ME provides a flexible user interface, robust security model, broad range of built-in network protocols, and support for networked and disconnected applications. J2ME applications are written for a wide range of devices. As such, the J2ME applications can be downloaded dynamically and leverage each native capability of each device. The J2ME platform can be deployed on millions of devices (e.g., mobile phones, PDAs, automotive devices, etc.) supported by leading Java technology tools vendors and used by companies worldwide. Briefly stated, J2ME is the preferable platform for consumer and embedded devices.
The SDK provides software programmers with the speed, security and functionality to create cross-platform, mission critical applications. The JRE provides the execution environment needed to run Java platform-based applets and applications.
The J2ME architecture defines configurations, profiles and optional packages as elements for building complete Java runtime environments that meet the requirements for a broad range of devices and target markets. Each combination is optimized for the memory, processing power, and I/O capabilities of a related category of devices. The result is a common Java platform that fully leverages each type of device to deliver a rich user experience.
Configurations
Configurations are composed of a virtual machine and a minimal set of class libraries. The configurations provide the base functionality for a particular range of devices that share similar characteristics (e.g., network connectivity, memory footprint, etc.). Currently, there are two J2ME configurations: the Connected Limited Device Configuration (CLDC), and the Connected Device Configuration (CDC):
CLDC
CLDC is the smaller of the two configurations, and by way of example, is designed for devices with intermittent network connections, slow processors, and limited memory (e.g., mobile phones, two-way pagers, PDAs, etc.). By way of example, the devices may have either 16- or 32-bit CPUs, and a minimum of 128 KB to 512 KB of memory available for the Java platform implementation and the associated applications.
CDC
CDC is designed for devices having more memory, faster processors, and greater network bandwidth (e.g., TV set-top boxes, residential gateways, in-vehicle telematics systems, high-end PDAs, etc.). CDC includes a full-featured Java virtual machine, and a much larger subset of the J2SE platform than CLDC. As a result, most CDC-targeted devices have 32-bit CPUs and a minimum of 2 MB of memory available for the Java platform and associated applications.
Profiles
In order to provide a complete runtime environment targeted at specific device categories, configurations can be combined with a set of higher level APIs or profiles that further define the application life cycle model, the user interface, and access to device specific properties.
Mobile Information Device Profile
The Mobile Information Device Profile (MIDP) is designed for mobile phones and entry-level PDAs. Broadly speaking, MIDP can be used on any computing device that needs to take advantage of MIDP's functions. MIDP is a set of Java APIs which, together with CLDC, provides a complete J2ME application runtime environment targeted at mobile information devices, such as mobile phones and entry level PDAs. In this manner, MIDP offers the core application functionality required by mobile applications (e.g., the user interface, network connectivity, local data storage, and application management, etc.). Combined with CLDC, MIDP provides a substantially complete Java runtime environment that leverages the capabilities of handheld devices and minimizes both memory and power consumption.
Currently, CLDC, combined with the MIDP is the Java runtime environment for mobile information devices (MIDs) (e.g., phones, entry level PDAs, etc.). MIDP provides the core application functionality required by mobile applications (e.g., the user interface, network connectivity, local data storage, and application lifecycle management packaged as a standardized Java runtime environment and set of Java APIs, etc.).
Foundation Profile
CDC profiles are layered so that profiles can be added as needed to provide application functionality for different types of devices. The Foundation Profile (FP) is the lowest level profile for CDC and provides a network-capable implementation of CDC that can be used for deeply embedded implementations without a user interface. FP can also be combined with Personal Basis Profile and Personal Profile for devices that require a graphical user interface (GUI).
Personal Profile
The Personal Profile (PP) is the CDC profile aimed at devices requiring full GUI or Internet applet support (e.g., high-end PDAs, communicator-type devices, game consoles, etc.). PP includes the full Java Abstract Window Toolkit (AWT) libraries and offers Web fidelity capable of easily running Web-based applets designed for use in a desktop environment. PP replaces PersonalJava™ technology and provides PersonalJava applications a clear migration path to the J2ME platform.
Personal Basis Profile
The Personal Basis Profile (PBP), is a subset of PP. PBP provides an application environment for network connected devices that support a basic level of graphical presentation or require the use of specialized graphical toolkits for specific applications.Devices (e.g., TV set-top boxes, in-vehicle telematics systems, information kiosks, etc.) Both PP and PBP are layered on top of CDC and FP.
Optional Packages
The J2ME platform can be further extended by combining various optional packages with CLDC, CDC, and their corresponding profiles. In this manner, specific market requirements can be addressed. Furthermore, optional packages can offer standard APIs for using both existing and emerging technologies (e.g., Bluetooth, Web services, wireless messaging, multimedia, database connectivity, etc.). As optional packages are modular, device manufacturers can include the optional packages, as needed, to fully leverage the features of each device.
By way of example, J2ME™ Mobile Media API Reference Implementation Version 1.0 (MMAPI) extends the functionality of the J2ME platform by providing audio, video and other time-based multimedia support to resource-constrained devices. MMAPI allows Java developers to gain access native multimedia services available on a given device.
The reference implementation for MMAPI runs on the CLDC/MIDP profile running on Windows 2000. By way of example, the reference implementation for MMAPI has support for simple tone generation, tone sequencing, audio/video file playback and streaming, interactive MIDI, and audio/video capture. The J2ME MMAPI reference implementation is a source code product provided for porting to various platforms. The MMAPI specification has been developed through the Java Community ProcessSM (i.e., JSR-135) by an expert group composed of companies representing device manufacturers, wireless operators and software vendors.
As the embodiments of the present invention can also involve using Enterprise Java Beans (EJB)™ in J2EE platform, below are brief descriptions to the J2EE platform and EJBs. The Java™ 2 Enterprise Edition (J2EE™), developed by Sun Microsystems, Inc., is the development and deployment environment for enterprise software applications capable of running on a variety of desktop computers, servers, and other computing devices. J2EE provides architecture for developing, deploying, and executing applications in a distributed-object environment. In one embodiment, the J2EE platform comprises the Java 2 Software Development Kit, Standard Edition (SDK), and Java Runtime Environment (JRE).
J2EE facilitates building Web-based applications. Broadly speaking, J2EE services are performed in the middle tier between the user browser and the databases and legacy information systems. J2EE comprises a specification, reference implementation and a set of testing suites. J2EE further comprises Enterprise JavaBeans (EJB), JavaServer Pages (JSP), Java servlets, and a plurality of interfaces for linking to information resources in the platform.
The J2EE specifications define how applications should be written for the J2EE environment. Thus the specifications provide the contract between the applications and the J2EE platform. However, there exist a class of JAVA applications that require customization of the J2EE platform. These applications generally utilize application specific strategies created by a particular vendor to accomplish specific tasks that are not provided by the general JAVA platform on which the application executes. Examples of this class of JAVA applications include telecommunications applications and services that are deployed within a particular service provider's environment. This class of applications typically requires continuous availability, which means the environment in which the applications operate requires the applications to be available most of the time.
Summarily, EJB architecture promotes the creation of re-usable server-side behaviors or instructions in the Java language, connectors to enable access to existing enterprise systems, and easy-to-deploy program modules. The EJB architecture creates a collaborative architecture to provide services virtually anywhere, and for a wide range of customers and devices, including mobile devices.
The EJB architecture defines a model for the development and deployment of reusable Java server components called EJB components (i.e., EJB beans). As designed, the EJB component is a non-visible server component having methods that provide business logic in a distributed application. In one example, the EJB architecture includes the EJB client and the EJB server. The EJB client is configured to provide the user-interface logic on a client machine and to make calls to remote EJB components on a server. For instance, the EJB client is provided the information as to how to find the EJB server and how to interact with the EJB components.
In one example, the EJB client does not communicate directly with the EJB component. In one aspect, the EJB container provides the client proxy objects that implement the home and remote interfaces of the component. In another instance, the remote interface is configured to define the business methods that can be called by the client. In another embodiment, the client is configured to invoke the methods resulting in the updating of the database. Thus, the EJB beans are reusable components that can be accessed by client programs. The application programmer codes the business logic into the EJBs and deploys them into a J2EE compliant server. In one example, the server complying with the J2EE specification provides the required system-level services, thus allowing the application programmer to concentrate on business logic.
The EJB server (i.e., the EJB application) includes an EJB container, which in one example provides the services required by the EJB component. For instance, the EJB container may be configured to include one of an EJB home interface or EJB Remote interface and EJB beans. In one embodiment, the EJB home interface and the EJB remote interface are defined in the same Java virtual machine. In a different embodiment, the EJB home interface and the EJB remote interface may be defined on different Java virtual machines or separate physical computers.
In one example, the EJB specification defines a container as the environment in which one or more EJB components can be executed. In accordance to one example, the EJB container provides the infrastructure required to run distributed components thus allowing the clients and component developers to focus on programming business logic. Simply stated, the container manages the low-level communications between the clients and the EJB beans. In one example, once an EJB bean is created by a client, the client invokes methods on the EJB bean as if the EJB bean were running in the same virtual machine as the client.
Furthermore, the clients are unaware of activities on the EJB bean, since the container is configured to sit between the clients and the EJB beans. For instance, if an EJB bean is passivated, its remote reference on the client remains intact. Thus, when the client later invokes a method on the remote reference, the container activates the EJB bean to service the request.
The EJB container encapsulates:
In one example, three types of EJB components can be enumerated.
Each EJB component further has a transaction attribute configured to determine the manner the instances of the component participate in transactions. As designed, the EJB container provides services which can include transaction and persistence support to the EJB components. As to the transaction support, the EJB container is configured to support transactions. In one example, when the bean is deployed, the EJB container provides the necessary transaction support. In regard to the persistence support, the EJB container is configured to provide support for persistence of the EJB components, which in one embodiment, is defined as the capability of the EJB component to save and retrieve its state. In this manner, the EJB component does not have to be re-created with each use.
In one example, the EJB architecture is a three-tiered architecture in which the clients reside on the first tier, the application server and the components (i.e., EJB beans) reside on the second tier, and the databases reside on the same host as the EJB server. In accordance to one implementation, the EJB server executes methods on a component from the client or another component, retrieves data from databases, and performs other communications. The EJB server further handles the details of transactions, threads, security, database connections, and network communication. Summarily, the EJB clients request business-logic services from EJB beans running on the second-tier. The EJB beans then use the system services provided by the second-tier server to access data from existing systems in the third tier. The EJB beans apply the business rules to the data, and return the results to the clients in the first-tier.
In one example, the client contains the user interface. The business logic is configured to be separate from both the clients and the databases and resides in the same tier (i.e., second tier) as components that analyze data, perform computations, or retrieve information from data sources and processes.
As J2ME, J2EE, and EJBs use the Java™ (hereinafter “Java”) programming language, in a like manner, an overview of Java is provided below. In operation, a user of a typical Java based system interacts with an application layer of a system generally written by a third party developer. The application layer generally provides the user interface for the system. A Java module is used to process commands received by the application layer. A Java virtual machine is used as an interpreter to provide portability to Java applications. In general, developers design Java applications as hardware independent software modules, which are executed Java virtual machines. The Java virtual machine layer is developed to operate in conjunction with the native operating system of a particular hardware, which represents the physical hardware on which the system operates or runs. In this manner, Java applications can be ported from one hardware device to another without requiring updating of the application code.
Unlike most programming languages, in which a program is compiled into machine-dependent, executable program code, Java classes are compiled into machine independent byte code class files which are executed by a machine-dependent virtual machine. The virtual machine provides a level of abstraction between the machine independence of the byte code classes and the machine-dependent instruction set of the underlying computer hardware. A class loader is responsible for loading the byte code class files as needed, and an interpreter or just-in-time compiler provides for the transformation of byte codes into machine code.
More specifically, Java is a programming language designed to generate applications that can run on all hardware platforms, small, medium and large, without modification. Developed by Sun, Java has been promoted and geared heavily for the Web, both for public Web sites and Intranets. Generally, Java programs can be called from within HTML documents or launched standalone. When a Java program runs from a Web page, it is called a “Java applet,” and when run on a Web server, the application is called a “serviet.”
Java is an interpreted language. The source code of a Java program is compiled into an intermediate language called “byte code”. The byte code is then converted (interpreted) into machine code at runtime. Upon finding a Java applet, the Web browser invokes a Java interpreter (Java Virtual Machine), which translates the byte code into machine code and runs it. Thus, Java programs are not dependent on any specific hardware and will run in any computer with the Java Virtual Machine software. On the server side, Java programs can also be compiled into machine language for faster performance. However a compiled Java program loses hardware independence as a result.
II. Optimized Start-up of Downloaded Mobile Device Applications
Keeping the overviews to J2EE, J2ME, EJBs, and Java in mind, reference is made to
The illustrated embedded mobile device 102 includes a storage 104. As shown, the storage 104 includes a MIDP 112 that runs on top of a virtual machine (VM) 110. The storage 104 further includes a plurality of downloadable MIDlets 114a and 114b that have already been downloaded from the application repository 108 to the storage 104 of the mobile device 102. The storage 104 is shown to further include a browser application 116 and a plurality of pre-installed applications 118a-118d.
As can be seen, the MIDlets 114a and 114b run on top of the MIDP 112 and VM 110. In one embodiment, the VM 110 interoperates using byte code format, a middle level machine instruction that can be translated into native CPU instructions. The VM 110 is configured to execute the byte codes and convert the byte codes into platform dependent machine code.
In one embodiment, the device 102 can browse through the server 106 and the application repository 108 of MIDlets via Internet 110. Initially, the device 102 uses the browser application 116 to dispatch a browse request to the server 106 so as to request a list of all the MIDlets stored to the application repository 108 available to the device 102. At this point, a list 120 of all the MIDlets available to the device 102 stored in the application repository 108 is provided to the device 102. As can be seen, the MIDlet list 120 includes all the MIDlets available to be downloaded to the device 102, which in this example are MIDlet 1, MIDlet 2, MIDlet 3, and MIDlet 4.
In one example, the browser application 116 can be a fixed application configured to discover applications in the server application repository 108. In another instance, the device 102 displays the list 120 using a graphical user interface. In yet another example, the device 102 may receive the list 120 using Wireless Markup Language (WML), HyperText Markup Language (HTML) language, etc. Of course, it must be noted that any suitable communication process will work, so long as the connection and communication is established.
In accordance with the embodiments of the present invention, once downloaded, MIDlets 1-4 can be executed as if MIDlets 1-4 are pre-installed MIDlets (e.g., MIDlets 114a, 114b, etc.). The process for enabling the downloaded MIDlets to behave similar to faster start-up pre-installed applications will be described in detail below. MIDlets 1 through 4, herein referred to as “downloadable applications” or “downloadable MIDlets” are configured to be executed on the device 102 as if MIDlets 1 through 4 are pre-installed applications. By way of example, the user of the device 102 can select to download and install the downloadable MIDlet 1 from the list 120. Additional information with respect to downloading and execution of downloadable MIDlets are provided below.
The embodiment of
In accordance with one embodiment of the process, the device 102 needs to be connected to server 106 via the Internet 110 while the downloadable application is being downloaded from the server 106 to the device 102. Thus, the user pays for the air fee associated with the download time (i.e., period of time during which the application is being downloaded from the application repository 108 to the device 102). Furthermore, in the present invention, the downloadable MIDlets or applications can be downloaded to any appropriate device data storage (e.g., memory, random access memory (RAM), flash memory, hot disc, mini hot disc, etc.).
Referring to
The JAD file 126a, as used herein, is defined to include the text description of the application or the MIDlet suite 121. In one example, the JAR file 126b, however, the JAR file 126b is configured to contain the class files of the application or MIDlet as well as all extra auxiliary resources associated with the application or MIDlet (e.g., resource files needed by the application or MIDlet, graphics, audio data, et.). In one embodiment, the JAR files are a file format that is used to package most of the components required by MIDP and VM. Because most of the components of the MIDlets (e.g., class files, images, sounds, etc.) can be packaged into a single file, JAR files are configured to simplify the downloading of applets. Additionally, JAR files support data compression designed to decrease download time and security signing.
During the installation stage, copies of a JAD file 132a and a JAR file 132b of the MIDlet 1121 are shown to be stored to the storage 104 of the device 102. In one example, after the device 102 issues the browse request and starts browsing the application repository 108, the server 106 sends a response to the device 102 with a list 120 of all the applications or MIDlets available to the device 102. Then, the device 102 dispatches a request to the server 106, requesting installation of the downloadable MIDlet or application 121. At this point, the server 106 sends the JAD file 126a of the MIDlet 121 to the device 102. The device 102 inspects the JAD file 132a so as to configure and calculate the storage size needed for installing the MIDlet 121, whether such storage size is available, whether the JAD file 132a is permitted to be copied, whether the device 102 has been granted security clearance to access the MIDlet 121, etc.
Assuming that all the requirements of the JAD file 132a can be accommodated by the device 102, the device 102 dispatches a request to the server 106, requesting the context of the downloadable MIDlet 121, which in this embodiment, is stored to the JAR file 126b. In one example, the JAR file 126b is a generic and cross-platform file and thus is not specific to the device 102. As can be appreciated, the JAR file 126b has been downloaded to the storage 104 of the device 102 as the JAR file JAR-1132b.
One of ordinary skill in the art must appreciate that although in the embodiment of
Continuing to
Also included in the storage 104 of the embodiment shown in
As illustrated, the storage 104 also includes the user interface 142 and real time operating system 146. Also shown are the network connections 144. The device storage 104 maybe defined inside a flash ROM, a hard drive, or some type of storage.
Proceeding to
It must be noted that in the embodiment shown in
One of ordinary skill in the art must appreciate that once the original files 105 have been processed using the cache file system 134, the original files 105, including the original JAR and JAD files 132a and 132b will not be functionally used. However, the original JAR and JAD files 132a and 132b that define the MIDlet application will still be referenced by the VM when a user desires access to the application. As discussed below, the request for the original MIDlet will mapped to the contents of the pre-processed files 136. Consequently, the device 102 will not have to process the files again and will simply use the pre-processed version.
Continuing to
Shifting to
Mapping of entries between the original files 105 and the pre-processed files 136 can be understood further with respect to the simplified diagram shown in
In this manner, when the VM dispatches a request for a file, for instance, the file 10192, the look-up engine can return the mapped entry, file f 166. This is achieved by the look up engine using the input file 10192 and the contents of the cache file (e.g., the mapping data), thus returning the corresponding mapped and pre-processed entry. In this manner, locating the pre-processed file is substantially easier. It must be appreciated that, in contrast to the original files wherein the JAR file is in the compressed image form, the mapped file (e.g., the pre-processed file) is pre-processed. Specifically, the original file has been decompressed and translated to the local native format of the particular device. In this manner, the need to download the MIDlet to the device every time the consumer wishes to execute the MIDlet is eliminated. Rather, in accordance with the embodiment of the present invention, the downloadable applications are downloaded, decompressed, and translated to the native format of the device, once. As a result, the downloaded MIDlets can behave similar to fast start-up pre-installed applications existing on the device. One must appreciate that, depending on the embodiment, the pre-processing may defer. For example, in one embodiment, the pre-processing is configured to involve decompressing the original file and converting same into the native format of the particular device. However, in another embodiment, any appropriate pre-processing can be implemented so long as the start-up time of applications is optimized.
In one example, the cache file is created along with the pre-processed files. For instance, the original java file is pre-processed according to the rules of the specific device and is defined in the format desired for the specific device, which for instance, may be the native format. In this manner, every time an original file is pre-processed, the cache file can be updated, allowing the cache file to be created and processed almost at the same time as the pre-processed file. Thus, each time an original file is pre-processed, the cache file is updated approximately at the same time, ensuring that the cache file and the pre-processed files are substantially current.
For instance, in one example, the rule may be uncompressing all PNG files and converting same to the device hardware dependent format, as follows:
jar(5.A. png)−→C-A.BMP (native format).
In this manner, the entries for each of the downloadable files is decompressed and converted into the device native format. That is, as the original files are being pre-processed in accordance with the rules for the specific device, the cache file stores the mapped data representing the entry previously pre-processed as opposed to the data that is being requested. In one example, each MIDlet suite or application is configured to have a corresponding cache file system.
Table 1 below shows an exemplary simple C-like pseudo-code for the installation phase of a downloaded application.
One of ordinary skill in the art should appreciate that in one embodiment, the limitation of the device, as used in the pseudo code, are the device rules. Furthermore, in one example, the device rules are set by the manufacturer. Additionally, one must note that the JAR file and the JAD file may not need to be downloaded if the JAR file and the JAD file have already been downloaded to the device.
Reference is made to
The method next continues to operation 704 in which the entry is pre-processed on the device, generating a preprocessed entry. By way of example, where the downloadable application is a J2ME MIDlet, the entries are JAD files and JAR files. Proceeding to operation 706, the downloadable application is executed on the device using the pre-processed entry.
In this manner, the execution of downloadable-applications is highly optimized because it is not necessary to have knowledge of the device rules and formats prior to the downloading operation. Furthermore, in addition to the raw execution speed, the start-up time of the downloadable applications is substantially lowered thus allowing the end users to utilize downloadable applications with almost instantaneous action and feedback.
Next, in operation 804, the server dispatches a list of applications available to be downloaded by the mobile device. The method thereafter continues to operation 806 in which the device selects an application to be downloaded followed by operation 808 in which the device dispatches a request for the selected application. Proceeding to operation 810, the JAD file of the selected application is dispatched to the device. Using the text in the JAD file, the device determines whether the device can accommodate the size and requirements of the selected applications as defined in the JAD file. Proceeding to operation 812, the device dispatches a request to the server requesting the JAR file of the selected application. As discussed in greater detail above, the JAR file includes the context of the application.
Next, in operation 814, the JAD file and the JAR file are pre-processed on the device in accordance with the rules of the device so as to generate a pre-processed file. In operation 816, the selected application is executed on the device using the pre-processed file.
Proceeding to
The advantages of the present invention are numerous. Most importantly, the start-up time associated with the downloadable applications improves substantially. In this manner, the responsiveness of the downloadable applications is comparable to that of pre-installed applications. Another advantage of the presents invention is that the device rules can be updated dynamically during the pre-processing, thus limiting the mapping performed between the original entries and the pre-processed entries. Yet another advantage of the present invention is that a limited amount of data in the entries can be selected to be pre-processed or decompressed. This is specifically beneficial when decompressing of the files may occupy too much space.
Still another advantage is that merely a portion of the application can be converted to the device hardware native format. For instance, the application may be processed partially and be interrupted, concluding the processing. In this manner, the original entries, such as the original JAR and JAD files, still exist and can be processed later on, if necessary. In such a scenario, the cache file is marked to reveal that a certain entry or a certain portion of an entry has not been changed, enabling reverting back to the original JAR file. Yet another advantage of the present invention is that memory consumption is reduced as the need to uncompress the data of the downloadable application while the downloadable application is being run on the device no longer exists. Still other advantages of the present invention is saving the future resources, CPU time, and processing power. Lastly, the installation time of the downloadable application can be slightly longer due to the pre-processing of the application. However, such delay is due to a one-time process as the downloadable application is pre-processed once on the device and not every time the downloadable application is launched.
Although specific reference is made to terminology defined by Sun Microsystems, Inc., it should be understood that any name can be used for such terms, so long as the desired functionality is achieved. For instance, reference is made to JAR and JAD files, but in a broad sense, these terms simply define computer code and data. The same applies to the underlying environment for the device 102. Device 102 can be any mobile device, and the device can run any operating system. The operating system can support any communication protocol, including protocols for downloading application files. The application files, once downloaded are pre-processed as defined above, and then stored on the device 102. In subsequent use of the downloaded and pre-processed application, the device 102 will simply access the pre-processed version of the application. Accordingly, any reference to a particular standard should be viewed only as exemplary and focus should be placed on the claimed functional operation.
With the above embodiments in mind, it should be understood that, the invention may be practiced with other computer system configurations including hand-held devices, microprocessor systems, microprocessor-based or programmable consumer electronics, minicomputers, mainframe computers and the like. Furthermore, the invention may employ various computer-implemented operations involving data stored in computer systems. These operations are those requiring physical manipulation of physical quantities. Usually, though not necessarily, these quantities take the form of electrical or magnetic signals capable of being stored, transferred, combined, compared, and otherwise manipulated. Further, the manipulations performed are often referred to in terms, such as producing, identifying, determining, or comparing.
Any of the operations described herein that form part of the invention are useful machine operations. The invention also relates to a device or an apparatus for performing these operations. The apparatus may be specially constructed for the required purposes, or it may be a general-purpose computer selectively activated or configured by a computer program stored in the computer. In particular, various general-purpose machines may be used with computer programs written in accordance with the teachings herein, or it may be more convenient to construct a more specialized apparatus to perform the required operations.
The invention can also be embodied as computer readable code on a computer readable medium. The computer readable medium is any data storage device that can store data which thereafter be read by a computer system. Examples of the computer readable medium include hard drives, network attached storage (NAS), read-only memory, random-access memory, CD-ROMs, CD-Rs, CD-RWs, magnetic tapes, and other optical and non-optical data storage devices. The computer readable medium can also be distributed over a network coupled computer systems so that the computer readable code is stored and executed in a distributed fashion. Furthermore, although the present invention implements Java programming language, other programming languages may be used to implement the embodiments of the present invention (e.g., C, C++, any object oriented programming language, etc.).
Although the foregoing invention has been described in some detail for purposes of clarity of understanding, it will be apparent that certain changes and modifications may be practiced within the scope of the appended claims. Accordingly, the present embodiments are to be considered as illustrative and not restrictive, and the invention is not to be limited to the details given herein, but may be modified within the scope and equivalents of the appended claims.