1. Field of the Invention
The present invention generally relates to an image forming apparatus, an application execution method, and a storage medium containing program code for performing the application execution method.
2. Description of the Related Art
Nowadays, an image forming apparatus, although with limited memory, normally has a configuration similar to that of a general purpose computer where functions are implemented by a CPU and applications. Such image forming apparatuses include a printer, a copier, a scanner, a fax machine, and a multifunction copier having functions of these apparatuses.
Patent document 1 discloses an image forming apparatus where common functions used by multiple applications are provided as a platform and applications can be implemented using application programming interfaces (APIs) provided by the platform. Having common functions as a platform in turn eliminates the need to develop those functions for each application and therefore improves efficiency of application development.
[Patent document 1] Japanese Patent No. 3679349
One difficulty in providing common functions or APIs as a platform in an image forming apparatus is to appropriately design the granularity of the functions or APIs in the platform. If the granularity is not designed properly, improvement in application development efficiency may not be expected.
For example, too fine granularity makes it necessary to call many APIs even from a simple application and therefore complicates source code of the application.
On the other hand, too coarse granularity increases the chance of having to modify an API in a platform or add a new API to the platform when developing an application and therefore reduces development efficiency. Especially, when the dependency between modules or APIs in the platform is high, modifying or adding an API may make it necessary to also modify dependent APIs.
Also, with the technology disclosed in patent document 1, it is not possible to implement a new application by calling an existing application that is partly different (for example, in its image input process) from the new application. In other words, it is necessary to write source code from the scratch even when developing an application similar to an existing application.
Embodiments of the present invention provide an image forming apparatus, an application execution method, and a storage medium containing program code for performing the application execution method that solve or reduce one or more problems caused by the limitations and disadvantages of the related art.
An embodiment of the present invention provides an image forming apparatus that includes a storage unit storing a linkage application and processing applications, each of the processing applications being implemented by a combination of software components for inputting, processing, and outputting image data; wherein the linkage application is configured to execute a combination of the processing applications in sequence.
Another embodiment of the present invention provides a method of executing applications in an image forming apparatus where each of the applications is implemented by a combination of software components for inputting, processing, and outputting image data. The method includes a linkage step of executing a combination of the applications in sequence.
Still another embodiment of the present invention provides a storage medium storing program code for causing an image forming apparatus to execute applications each of which is implemented by a combination of software components for inputting, processing, and outputting image data. The program code includes a linkage code unit configured to execute a combination of the applications in sequence.
Preferred embodiments of the present invention are described below with reference to the accompanying drawings.
As shown in
The user interface layer 10 includes interfaces that receive execution requests to execute functions such as copying, printing, scanning, and fax transmission. For example, the user interface layer 10 includes a communication server unit 11 and a local user interface (UI) unit 12. The communication server unit 11 receives requests via a network from a client PC (not shown). The local UI unit 12 receives requests input from an operations panel (not shown). Requests received by the user interface layer 10 are forwarded to the control layer 20.
The control layer 20 controls execution processes of requested functions and includes a plug-in management unit 21 and a request management unit 22. The plug-in management unit 21 controls initialization processes (plug-in processes) for making activities 31 and filters in the application logic layer 30 ready for use. The request management unit 22 controls execution processes of functions of the multifunction copier 1 according to requests received by the user interface layer 10. In this embodiment, a “function” of the multifunction copier 1 indicates a service (a sequence of processes from input of a request to output of the result) provided by the multifunction copier 1 for the user or an application executed by the multifunction copier 1 to provide the service.
The application logic layer 30 includes software components that constitute functions provided by the multifunction copier 1. In other words, in the multifunction copier 1, a function is implemented by a combination of software components in the application logic layer 30. In a software architecture called “pipes-and-filters” of the multifunction copier 1 of this embodiment, those software components are called “filters”.
In other words, in the multifunction copier 1 of this embodiment, a function is a series of processes performed by filters on a document (or data). In a sense, each function of the multifunction copier 1 can be generalized as a combination of input, processing, and output processes. Each of the input, processing, and output processes is implemented by a software component, i.e., a filter. An “input filter” inputs data from a device, a “processing filter” performs processing (e.g., image processing) on the input data, and an “output filter” outputs the processed data to a device. Filters are basically independent from each other, i.e., there is substantially no dependency between filters. Therefore, filters can be added (installed) and deleted (uninstalled) without taking into account their dependency.
Referring back to
The scanning filter 301 controls the process of scanning an image by a scanner and outputs the scanned image data. The stored document retrieving filter 302 retrieves document data (image data) stored in a storage unit of the multifunction copier 1 and outputs the retrieved document data. The email reception filter 303 receives an email message and outputs data in the received email message. The fax reception filter 304 receives a fax message and outputs data of the received fax message. The PC document reception filter 305 receives print data from a client PC (not shown) and outputs the received print data. The report filter 306 retrieves setting information and history information of the multifunction copier 1 and outputs the information, for example, in a tabular format.
As processing filters, the application logic layer 30 includes a document processing filter 311 and a document conversion filter 312. The document processing filter 311 performs image processing such as N-up processing or resizing (enlargement or reduction) on input data and outputs the processed data. The document conversion filter 312 converts (or renders) input PostScript data into bitmap data and outputs the bitmap data.
As output filters, the application logic layer 30 includes a printing filter 321, a document storage filter 322, an email transmission filter 323, a fax transmission filter 324, a PC document transmission filter 325, and a preview filter 326.
The printing filter 321 prints (outputs) input data on a plotter. The document storage filter 322 stores input data in a hard disk of the multifunction copier 1. The email transmission filter 323 attaches input data to an email message and sends the email message. The fax transmission filter 324 sends input data as a fax message. The PC document transmission filter 325 sends input data to a client PC. The preview filter 326 displays a preview image of input data on the operations panel of the multifunction copier 1.
Functions of the multifunction copier 1 are implemented by combinations of filters.
For example, a copy function comprises the scanning filter 301 and the printing filter 321. When the copy function is executed, the scanning filter 301 scans a document to obtain image data and the printing filter 321 prints the obtained image data. If image processing such as N-up processing, enlargement, or reduction is requested for the copy function, the document processing filter 311 is inserted between the scanning filter 301 and the printing filter 321.
A print function (for printing print data sent from a client PC) comprises the PC document reception filter 305, the document conversion filter 312, and the printing filter 321. A scanning-and-email function (for scanning an image and sending the scanned image as an email message) comprises the scanning filter 301 and the email transmission filter 323. A fax transmission function comprises the scanning filter 301 and the fax transmission filter 324. A fax reception function comprises the fax reception filter 304 and the printing filter 321. A scanning-and-storing function (for scanning an image and storing the scanned image in the multifunction copier 1) comprises the scanning filter 301 and the document storage filter 322. A retrieving-and-printing function (for retrieving document data in the multifunction copier 1 and printing the document data) comprises the stored document retrieving filter 302 and the printing filter 321.
Note that the scanning filter 301 is used in five functions in
With the multifunction copier 1, the user can easily create a new function. Take, for example, a case of creating a function 1 for printing print data that are sent from a client PC and described in a page description language (PDL) not supported by the multifunction copier 1 (hereafter the PDL is called unsupported PDL). The function 1 may be created based on the print function shown in
Take, for another example, a case of developing a function 2 for collecting information from a Web site and printing the collected information. The function 2 can be implemented by creating a new input filter (Web-information collecting filter) for collecting information from a Web site and by interfacing the Web-information collecting filter and the printing filter 321. To interface the Web-information collecting filter and the printing filter 321, it is necessary to convert collected Web information into bitmap data that the printing filter 321 can receive. Because incorporating a rendering capability in the Web-information collecting filter requires a heavy workload, it is preferable to use the document conversion filter 312 to render collected Web information into bitmap data. The Web-information collecting filter and the document conversion filter 312 can be connected by just modifying the Web-information collecting filter to be able to output collected Web information in the PostScript format. Thus, the function 2 can be implemented by connecting the Web-information collecting filter, the document conversion filter 312, and the printing filter 321.
As described above, functions of the multifunction copier 1 are implemented by combinations of filters, and this architecture makes it easier to customize and add functions Also, because there is substantially no functional dependency between filters, it is possible to easily develop a new function (or an application) by adding a new filter or changing the combination of filters. In other words, with the multifunction copier 1 of this embodiment, it is possible to create a new application by just developing a filter that performs a process unique to the new application. This in turn reduces the chance of having to modify software components in the layers above and below the application logic layer 30 when creating a new application and thereby makes it possible to provide a stable platform.
The application logic layer 30 includes activities 31 in addition to the filters. An “activity” indicates a piece of software or an application that implements a function (or a service) of the multifunction copier 1 by a combination of filters.
The multifunction copier 1 allows the user to dynamically create a function (an application) by combining independent filters. For example, the multifunction copier 1 may be configured to request the user to select filters and to specify the execution sequence and conditions of the filters via an operations panel each time execution of a function is requested by the user.
However, it is bothersome for the user to select filters each time to execute a frequently used function such as a copy function. This problem can be solved by using “activities”. In this embodiment, combinations of filters can be defined as the activities 31, and the user can execute a function by selecting one of the activities 31. When one of the activities 31 is selected, the multifunction copier 1 automatically executes a combination of filters defined in the selected activity 31. Thus, the activities 31 allow the user to perform tasks as simply as with a conventional image forming apparatus where functions are provided as separate applications.
In
The ScanToStorage activity 31a implements a function to scan and store a document by a combination of the scanning filter 301, the document processing filter 311, and the document storage filter 322.
The StorageToEmail activity 31b implements a function to send a stored document as an email message by a combination of the stored document retrieving filter 302, the document processing filter 311, and the email transmission filter 323.
The ScanToEmail activity 31c links (or combines) the ScanToStorage activity 31a and the StorageToEmail activity 31b and executes the two activities 31 in sequence. Thus, an activity may also comprise a combination of activities.
In this embodiment, an activity like the ScanToEmail activity 31c comprising multiple activities is called a “linkage activity” or a “linkage application”. In contrast to linkage activities, activities like the ScanToStorage activity 31a and the StorageToEmail activity 31b comprising filters are called “document processing activities”. When the distinction is not important, they may be just called the activities 31.
The activities 31 other than linkage activities are basically independent from each other, i.e., there is substantially no dependency between the activities 31. In other words, the activities 31 can be added (installed) and deleted (uninstalled) without taking into account their dependency. The user can freely create and install new activities 31 by combining filters.
The device service layer 40 includes an image pipe 41 and a data management unit 42 that are low-level functions shared by the activities 31 and the filters of the application logic layer 30. The image pipe 41 functions as a pipe described above. The image pipe 41 passes data output from a preceding filter to a subsequent filter. The data management unit 42 represents various databases such as a user information database and a document (or image) database.
The device control layer 50 includes program modules called drivers for controlling hardware devices. For example, the device control layer 50 includes a scanner control unit 51, a plotter control unit 52, a memory control unit 53, a telephone line control unit 54, and a network control unit 55 for controlling respective devices indicated by their names.
Filters and the activities 31 are described below in more detail.
The filter UI is a program for displaying a screen for setting execution conditions of the filter, for example, on an operations panel. For example, the filter UI of the scanning filter 301 displays a screen for setting a resolution, a density, and an image type. The filter UI may be implemented as hypertext markup language (HTML) data or scripting language data to be displayed on the operations panel.
The filter logic program performs the task of a filter or defines a process to be performed by the filter. The filter logic program performs the task of a filter by using a filter-specific low-level service of the filter, a low-level function in the device service layer 40, and/or a driver in the device control layer 50 according to execution conditions specified via the filter UI. For example, the filter logic program of the scanning filter 301 controls the process of scanning an image by a scanner.
The filter-specific low-level service is a library used by the filter logic program. The filter-specific low-level service provides a filter-specific function that is used only by a filter. Otherwise, the filter-specific low-level service is similar to a low-level function in the device service layer 40 or a driver in the device control layer 50. In other words, if a filter can perform its task using a shared low-level function or driver, the filter-specific low-level service may be omitted. For example, the scanning filter 301 can perform its task using the scanner control unit 51 in the device control layer 50 and therefore does not require a filter-specific low-level service.
The permanently stored information is a schema, such as default setting information (e.g., default execution conditions), of a filter and is stored in a non-volatile memory. A schema of a filter is registered in the data management unit 42 when the filter is installed.
The activity UI is a program or data for displaying a screen for setting execution conditions of the activity 31, for example, on an operations panel.
The activity logic program performs the task of the activity 31 or defines a process to be performed by the activity 31. Normally, the activity logic program defines a combination of filters, the execution sequence of the filters, execution conditions common to multiple filters, filter connection rules, an error-handling process, etc. In the case of a linkage activity, the activity logic program defines information necessary to execute and link multiple activities 31.
The permanently stored information is a schema, such as default setting information (e.g., default execution conditions), of the activity 31 and is stored in a non-volatile memory. A schema of the activity 31 is registered in the data management unit 42 when the activity 31 is installed.
The activities 31 and filters are treated as objects in an application. Objects are described in a class structure.
In
The linkage activity class 340 and the document processing activity class 350 inherit the application class 330. Therefore, a linkage activity and a document processing activity can be handled using an interface defined in the application class 330 without taking into account their differences.
The linkage activity class 340 has relationships r1 and r2 (indicating logical connections) with (document processing activity objects 350A of) the document processing activity class 350. The relationship r1 shows a connection with a first document processing activity object 350A corresponding to a preceding one (that is to be executed first) of two document processing activities to be linked by the linkage activity. The first document processing activity object 350A is identified by a role name “preceding job”. The relationship r2 shows a connection with a second document processing activity object 350A corresponding to a subsequent one (that is to be executed next) of the two document processing activities to be linked by the linkage activity. The second document processing activity object 350A is identified by a role name “subsequent job”.
The document processing activity class 350 “aggregates” multiple filter classes 360. This indicates that each document processing activity comprises multiple filters.
Exemplary processes in the multifunction copier 1 are described below.
The plug-in management unit 21 sends initialization requests to the activities 31 installed in the multifunction copier 1 (S101). A list of the activities 31 installed is stored in a storage unit of the multifunction copier 1. The plug-in management unit 21 obtains the list of the activities 31 and sends initialization requests to the activities 31 based on the list.
When receiving the initialization requests, the activities 31 generate the corresponding document processing activity objects 350A or the corresponding linkage activity objects 340A, and register the generated objects with the request management unit 22 (S102). The request management unit 22 handles the activities 31 using the registered objects.
When the user selects the ScanToStorage activity 31a to be executed on the operations panel of the multifunction copier 1, the local UI unit 12 sends a search request with the name “ScanToStorage” of the ScanToStorage activity 31a to the request management unit 22 (S201). The request management unit 22 requests the objects (the document processing activity objects 350A and the linkage activity objects 340A) registered as shown in
Then, the request management unit 22 searches the names returned from the objects for the name “ScanToStorage” specified in the search request from the local UI 12 to determine whether the ScanToStorage activity 31a exists (S203). If the ScanToStorage activity 31a exists, the request management unit 22 returns the ScanToStorage object 351 of the ScanToStorage activity 31a to the local UI unit 12 (S204).
Next, the local UI unit 12 requests the ScanToStorage object 351 to generate execution conditions (S205). The ScanToStorage object 351 generates the scanning filter object 361, the document processing filter object 362, and the document storage filter object 363 of the corresponding filters constituting the ScanToStorage activity 31a (S206, S207, and S208), and sets default execution conditions of the ScanToStorage activity 31a and the constituent filters. The default execution conditions are, for example, included in the permanently stored information (see
The local UI unit 12 calls the activity UI (see
Execution conditions specified in the filter setting screens are set in the filter logic programs (see
Thus, in this embodiment, a user interface for setting execution conditions is implemented in each filter and can be called from any activity 31 using the filter. This architecture eliminates the need to develop user interfaces for each application (the activity 31) and thereby makes it possible to improve development efficiency.
Referring back to
There are various types of pipes that are used depending on the filters to be connected. Therefore, it is necessary to determine the type of a pipe to be used to connect a certain pair of filters. The types of pipes may be defined in the activity logic program of the activity 31 or may be defined as a table in a storage unit of the multifunction copier 1.
Referring back to
In the example shown in
The filter objects 361, 362, and 363 send completion reports to the ScanToStorage object 351 when their respective processes are completed (S216, S217, and S218). After receiving the completion reports from all of the filter objects 361, 362, and 363, the ScanToStorage object 351 sends a job completion report to the local UI unit 12 (S219).
An execution process of a linkage activity is described below.
When the user selects the ScanToEmail activity 31c to be executed on the operations panel of the multifunction copier 1, the local UI unit 12 sends a search request with the name “ScanToEmail” of the ScanToEmail activity 31c to the request management unit 22 (S301). The request management unit 22 requests the objects (the document processing activity objects 350A and the linkage activity objects 340A) registered as shown in
Then, the request management unit 22 searches the names returned from the objects for the name “ScanToEmail” specified in the search request from the local UI 12 to determine whether the ScanToEmail activity 31c exists (S305). In this step, if the activity 31 to be searched for is a linkage activity, the request management unit 22 identifies document processing activities to be linked by the linkage activity based on linkage definition information associated with the linkage activity, and determines whether the identified document processing activities also exist. The linkage definition information is, for example, stored in a storage unit of the multifunction copier 1.
Referring back to
Next, the local UI unit 12 requests the ScanToEmail object 353 to generate execution conditions (S307). The ScanToEmail object 353 sets default execution conditions of the ScanToEmail activity 31c, and requests the ScanToStorage object 351 of the ScanToStorage activity 31a and the StorageToEmail object 352 of the StorageToEmail activity 31b to generate their execution conditions (S308 and S312). In this step, the ScanToEmail object 353 identifies the ScanToStorage activity 31a and the StorageToEmail activity 31b constituting the ScanToEmail activity 31c based on the structure information 410.
The ScanToStorage object 351 and the StorageToEmail object 352 set default execution conditions of the corresponding activities 31 and their constituent filters. In
Then, the local UI unit 12 calls the activity UI of the ScanToEmail activity 31c to obtain screen information of the ScanToStorage activity 31c, and displays a ScanToEmail setting screen on the operations panel based on the screen information.
When the ScanToStorage button 613a is selected (or touched) on the ScanToEmail setting screen 613, the local UI unit 12 calls the activity UI of the ScanToStorage activity 31a to obtain screen information of the ScanToStorage activity 31a, and displays the ScanToStorage setting screen 611 based on the screen information.
When the StorageToEmail button 613b is selected, the local UI unit 12 calls the activity UI of the StorageToEmail activity 31b to obtain screen information of the StorageToEmail activity 31b, and displays a StorageToEmail setting screen 612 based on the screen information. Similar to the ScanToStorage activity setting screen 611, the StorageToEmail activity setting screen 612 includes a stored document retrieving filter setting screen 612a, a document processing filter setting screen 612b, and an email transmission filter setting screen 612c of the corresponding filters constituting the StorageToEmail activity 31b.
Execution conditions specified in the filter setting screens are set in the filter logic programs (see
When the StorageToEmail activity 31b is executed alone, the stored document retrieving filter setting screen 612a of the StorageToEmail activity setting screen 612 requests the user to select document data (image data) stored in a storage unit of the multifunction copier 1. However, in the ScanToEmail activity 31c, document data are input to the StorageToEmail activity 31b from the ScanToStorage activity 31a. Therefore, there is no need to request the user to select document data, and there is no need to display the stored document retrieving filter setting screen 612a. Alternatively, the stored document retrieving filter setting screen 612a may be displayed with a menu for selecting document data disabled. In this case, the ScanToEmail activity 31c may be configured to disable the menu for selecting document data on the stored document retrieving filter setting screen 612a.
Referring back to
The request management unit 22 schedules the job put in the job queue (S315). When the turn of the ScanToEmail activity 31c comes, the request management unit 22 sends an execution request to the ScanToEmail object 353 (S316). The ScanToEmail object 353 sends an execution request to the ScanToStorage object 351 corresponding to the preceding activity name in the structure information 410 (S317). Then, the ScanToStorage activity 31a is executed in steps S318 through S323 in a manner similar to steps S213 through S218 of
The ScanToEmail object 353 determines whether to start a subsequent job (the job of the StorageToEmail activity 31b) based on the subsequent-job starting information 430. As shown in
Based on the information source and the information type in the subsequent-job starting information 430, the ScanToEmail object 353 obtains the execution result of the ScanToStorage activity 31a from the ScanToStorage object 351 (S326) and compares the execution result with the subsequent-job start condition.
If the execution result is a failure (if the subsequent-job start condition is not satisfied), the ScanToEmail object 353 does not execute the StorageToEmail activity 31b. If the execution result is a success (if the subsequent-job start condition is satisfied), the ScanToEmail object 353 obtains handover information based on handover setting information 420 of the linkage definition information and sets the handover information as an execution condition of the StorageToEmail activity 31b (S327).
“Handover information” indicates information to be handed over to a subsequent activity 31 from a preceding activity 31. As shown in
Based on the handover setting information 420 shown in
Next, the ScanToEmail object 353 sends an execution request to the StorageToEmail object 352 (S328). In response to the execution request, the StorageToEmail activity 31b (or the StorageToEmail object 352) sends the image data corresponding to the document ID as an email message. The execution process of the StorageToEmail activity 31b is similar to that of the ScanToStorage activity 31a and is therefore omitted in
When a completion report is sent from the StorageToEmail object 352, the ScanToEmail object 353 sends a job completion report of the ScanToEmail activity 31c to the local UI unit 12 (S329). Thus, the ScanToEmail activity 31c executes the ScanToStorage activity 31a and the StorageToEmail activity 31b in sequence and thereby performs a process of scanning an image and sending the scanned image data as an email message.
In the above descriptions, an execution process of a linkage activity is exemplified using the ScanToEmail activity 31c. Next, an execution process of a linkage activity is described in a more general manner using a flowchart.
First, a preceding activity 31 is executed based on the preceding activity name in the structure information 410 (S401). Step 401 corresponds to step S317 in
Next, decision information is obtained based on the information source and the information type in the subsequent-job starting information 430 (S402). Then, based on the decision information, it is determined whether the subsequent-job start condition in the subsequent-job starting information 430 is satisfied (S403). If the subsequent-job start condition is not satisfied (NO in S403), the subsequent activity 31 is not executed.
If the subsequent-job start condition is satisfied (YES in S403), whether it is necessary to obtain handover information is determined based on the handover setting information 420 (S404). More specifically, it is determined whether the handover setting information 420 is provided for the linkage activity. If obtaining handover information is necessary (if the handover setting information 420 is provided for the linkage activity) (YES in S404), the handover information is obtained from the information source based on the handover setting information 420 (S405), and the obtained handover information is set as an execution condition of the information recipient (S406). If obtaining handover information is not necessary (if the handover setting information 420 is not provided for the linkage activity) (NO in S404), the handover information is not obtained.
Next, the subsequent activity 31 is executed based on the subsequent activity name in the structure information 410 (S407).
A second embodiment of the present invention is described below.
In
Thus, in this embodiment, a linkage activity itself can be linked with another activity. A linkage activity linking a combination of linkage and document processing activities executes the linked activities in sequence.
Take, for example, a case where one of the two document processing activity objects 350A (the ScanToStorage object 351 and the StorageToEmail object 352) in the sequence chart of
A third embodiment of the present invention is described below.
In the class structure of
The activity link class 370 has relationships r5 and r6 with the document processing activity class 350. The relationship r5 shows a connection with a first document processing activity object 350A corresponding to a preceding one (that is to be executed first) of two document processing activities to be linked. The first document processing activity object 350A is identified by a role name “preceding job”. The relationship r6 shows a connection with a second document processing activity object 350A corresponding to a subsequent one (that is to be executed next) of the two document processing activities to be linked. The second document processing activity object 350A is identified by a role name “subsequent job”.
The linkage activity class 340 has a one-to-many (1 . . . *) relationship with the activity link class 370.
Meanwhile, in the structure information 420 shown in
The third and subsequent activities in a linkage activity according to the third embodiment can be executed by repeating the steps of executing the subsequent activity (StorageToEmail activity 31b) as shown in
A fourth embodiment of the present invention is described below.
In
Thus, in this embodiment, a linkage activity itself can be linked with another activity via the activity link object 370A. In other words, the fourth embodiment is a combination of the second and third embodiments and makes it possible to link three or more linkage and document processing activities by one linkage activity.
A linkage activity of the fourth embodiment can be executed by modifying a process shown in
As described above, the multifunction copier 1 according to embodiments of the present invention makes it possible to link multiple activities each comprising independent filters, and thereby makes it possible to flexibly and efficiently develop applications.
An embodiment of the present invention makes it possible to determine whether to execute a subsequent activity based on a status such as the execution result of a preceding activity and thereby makes it possible to flexibly execute linked activities.
An embodiment of the present invention makes it possible to define an activity that performs a common process required by multiple activities and thereby makes it possible to efficiently develop applications.
For example, each activity requires an abnormal termination process, such as displaying an error message, which is to be performed if the activity ends abnormally. Incorporating such an abnormal termination process as a routine in each activity reduces application development efficiency and increases the maintenance workload. This problem can be solved by defining an abnormal termination activity for performing the abnormal termination process and linking the abnormal termination activity as a subsequent activity with other activities. In this case, the subsequent-job start condition for the abnormal termination activity is specified such that the abnormal termination activity is executed if the execution result of a preceding activity is a failure. Also, an error code may be used as the handover information.
Thus, embodiments of the present invention provide an image forming apparatus, an application execution method, and a storage medium containing program code for performing the application execution method that allow the user to easily customize or add functions of the image forming apparatus.
The present invention is not limited to the specifically disclosed embodiments, and variations and modifications may be made without departing from the scope of the present invention.
The present application is based on Japanese Priority Application No. 2007-149386, filed on Jun. 5, 2007, the entire contents of which are hereby incorporated herein by reference.
Number | Date | Country | Kind |
---|---|---|---|
2007-149386 | Jun 2007 | JP | national |