This invention relates to upgrading documents so that the documents are compatible with a version of a document processing mechanism that is used to process the documents. In a more particular implementation, this invention relates to upgrading arbitrary markup language documents so that the documents match a version of a document processing mechanism used to display and edit the markup language documents. In this disclosure, the term “upgrading” has broad connotation, encompassing any kind of modification of a document.
A document created using a particular version of a document processing mechanism often cannot be satisfactorily processed by later versions of the document processing mechanism. For example, documents created using a particular version of a word processing application or a spreadsheet application (referred to as “original documents”) often cannot be adequately processed by later versions of these applications. For instance, the original documents may lack information that is needed to fully exploit enhanced functionality provided by the later developed versions of the applications. This can result in the suboptimal rendering of the original documents in the later developed versions of these applications, or in extreme cases, the inability to render any information gleaned from the original documents. And even if the original documents can be displayed, these documents may exhibit suboptimal behavior when processed by later versions of these applications.
Applications developed specifically to render and process markup language documents share the above shortcomings. A typical application includes an Extensible Stylesheet Language (XSL) processor that transforms a document expressed in the Extensible Markup Language (XML) to a document expressed in some presentation-oriented markup language, such as Hypertext Markup Language (HTML). The XSL processor uses a collection of XSL files in transforming XML into HTML, wherein these files effectively specify the appearance of the document as rendered using HTML. The XSL files might have been specifically developed to process particular kinds of XML documents characterized by a specified schema. Subsequently, a developer may have made significant changes in the XSL files to enable processing of new kinds of XML documents having new characteristics, possibly governed by a new schema. Due to these changes, the XSL processor might not be able to satisfactorily process the kinds of XML documents for which it was originally designed. The presentation of the original XML documents using the upgraded XSL files may produce errors, or may be completely proscribed.
In the scenario shown in
The above strategy has a number of drawbacks. The conversion logic 110 is specifically tailored to translate information produced by application version V1102 into information expected by application version V2. Hence, the characteristics of the conversion logic 110 are specifically predicated on a detailed comparison between application versions V1 and V2 (102, 104). As such, the conversion logic 110 might not be able to satisfactorily process documents produced by other sources, and it might not be able to process documents in conjunction with other versions of document processing mechanisms. For example, the conversion logic 110 might not be able to process a document produced by some other predecessor version of the application, such as an application version V0.5, etc. Further, the conversion logic 110 may no longer provide satisfactory results for documents 106 produced by application version V1102 when the application program is upgraded in the future to a later version—say, for example, version V3. In summary, the conversion logic 110 cannot, and was never intended to, handle documents having arbitrary form and content. In other words, the conversion logic 110 is narrowly tailored to the task of translating between applications V1102 and V2104. Markup language processors (e.g., browsers) often resort to a similar tactic to that shown in
In the traditional approach, a developer would address these problems by adding modules to the conversion logic 110 to address different permutations in document conversion scenarios. This has drawbacks, because it requires the developers to develop new code each time the processing environment changes.
Based on the foregoing, there is an exemplary need in the art for a more efficient and flexible technique for upgrading documents so that they are compatible with current versions of document processing mechanisms, such as markup language document processing mechanisms.
According to one exemplary implementation, a method is described for upgrading documents for processing by processing functionality. The method includes: (a) inputting a structured document having particular features associated therewith into a particular version of the processing functionality; (b) determining whether each of the particular features matches a set of expected features associated with the particular version of the processing functionality; and (c) modifying the particular features of the input structured document so that the particular features match the set of expected features to thereby provide a modified structured document. After the above-described modification, the method includes: (d) transforming the modified structured document into another document suitable for presentation; (e) displaying the other document suitable for presentation using the processing functionality to provide a displayed document; and (f) editing the displayed document.
The input structured document can be expressed in the extensible markup language (XML). The other document can be expressed in the hypertext markup language (HTML). In one implementation, the operation of modifying is implemented using an upgrade module that provides a transformation function using extensible stylesheet language (XSL).
The above-referenced determining of whether each of the particular features matches a set of expected features associated with the particular version of the processing functionality can include determining whether the input structured document contains each node expected by the particular version of the processing functionality. The above-referenced modifying of the particular features of the input structured document to produce the modified structured document can include: (c1) creating each node expected by the particular version of the processing functionality to provide created nodes; (c2) copying node content from the input structured document into corresponding created nodes in the modified structured document for those nodes in the input structured document that have counterpart nodes expected by the particular version of the processing functionality; and (c3) creating default node content in corresponding nodes in the modified structured document for those created nodes that do not have counterpart nodes in the input structured document.
In one case, the above-referenced “expected features” are specified by a schema associated with the particular version of the processing functionality. In another case, the above-referenced “expected features” are specified by some information other than the schema associated with the particular version of the processing functionality (such as aspects pertaining to the visual presentation of the document that are not dictated by the schema).
According to another exemplary implementation, a method is described for generating an upgrade module for upgrading documents for processing by processing functionality. The method includes: (a) determining whether a particular version of the processing functionality has been created that warrants generation of the upgrade module; and (b) generating the upgrade module if the creation of the particular version warrants the generation of the upgrade module.
Related apparatus and computer readable media are also described herein, as well as additional subject matter.
The same numbers are used throughout the disclosure and figures to reference like components and features. Series 100 numbers refer to features originally found in
This disclosure pertains to the visual rendering and editing of structured documents using a data processing application. To provide a concrete framework for discussion, this disclosure will specifically describe the transformation of hierarchically organized data expressed in a markup language into an electronic form that can be visually rendered and edited by an end user. Exemplary forms include a timesheet, work order, travel log, and so on. However, the concepts described herein also have application to other data processing applications besides electronic forms processing.
The terms “upgrade” and “version” have broad connotation as used in this disclosure. “Upgrading” a document refers generally to modifying the document in any manner to suit expectations of a current manifestation (e.g., version) of the document processing application. In one case, an upgrade refers to a scenario in which a user modifies a document produced by an earlier version of a document processing application to be compatible with a later developed, more enhanced, version of the data processing application. However, the term “upgrade” can also refer to modifying a document produced by a later version of the document processing application so that it is compatible with an earlier version of the document processing application. Accordingly, the term “upgrade” as used herein is value-neutral; it could refer to changes that are considered “better” and “worse” than an original version depending on one's particular data processing requirements and objectives. In still a broader interpretation, the term “upgrade” can refer to the modification of any kind of document produced by any kind of initial document processing application, where such initial document processing application is not considered a predecessor or successor to a current version of a document processing application. And indeed, the initial document need not even be “produced” per se; for instance, the functionality described herein can be used to convert a document that is completely blank or a document that contains completely random information into a format expected by a current version of a document processing application. Due to the liberal interpretation of the term “upgrade,” the term “version” should also be understood to have broad connotation as used herein. The term “version” generally refers to any class or kind of document.
The above-noted flexibility of the data processing application highlights one of its principal merits. The data processing application can transform an arbitrary structured document (e.g., a markup language document) so that it conforms to the processing requirements of a current version of a data processing application. In this sense, in one implementation, the data processing application uses a transformation mechanism that is stateless. It is stateless in the sense that it does not require prior knowledge or consideration of the kind of documents that are fed into it.
The above-described property and additional features of the data processing application will be explained in the following disclosure. This disclosure is organized as follows. Section A of this disclosure describes an exemplary design strategy used by a data processing application that includes upgrade functionality. Section B describes an exemplary implementation of the design strategy discussed in Section A. Section C describes an exemplary method of operation of the implementation described in Section B. And Section D describes an exemplary computing environment that can be used to provide the implementation described in Section B.
A. Exemplary Design Strategy
Overview of Exemplary Data Processing Application
By way of overview, the data processing application 200 processes structured data 202 expressed in a markup language, transforms this structured data 202 using a solution module 204 to produce transformed information, and presents a rendering of a visual surface 206 on an output device based on the transformed information. An editing user 208 interacts with the visual surface 206, as indicated by arrow 210, using, for instance keyboard 212, mouse device 214, or some other input device. The visual surface 206 can constitute the presentation of a form having data entry fields associated with the structured data 202. In this case, the editing user 208's interaction can involve filling information into the entry fields of the form, such as by entering information into various text boxes, check boxes, etc.
Each of the above-described principal features—structured data 202, solution module 204, and visual surface 206—will be described in greater detail below.
To begin with, the structured data 202 can be represented in the Extensible Markup Language (XML). XML is a subset of the Standard Generalized Markup Language (SGML) that enables developers to create customized tags that describe the meaning of data, as opposed to the presentation of data. An XML document is composed of XML elements, each of which includes a start tag (such as <author>), an end tag (such as </author>), and information between the two tags (which is referred to as the content of the elements). An element may include any number (including zero) of name-value pairs (referred to as attributes) related by an equal sign that modifies certain features of the element (such as MONTH=“May”). As shown in
The solution module 204 includes transformation functionality 218. The purpose of the transformation functionality 218 is to transform the structured data 202 into the visual surface 206. The transformation functionality 218 can perform this task using so-called style sheets, such as style sheets provided by Extensible Stylesheet Language Transformation (XSLT). XSLT transforms the XML data into a format appropriate for presentation, such as the Hypertext Markup Language (HTML), Extensible Hypertext Markup Language (XHTML), Dynamic HTML (DHTML), etc. In other words, documents expressed in XML include tags that are particularly tailored to convey the meaning of the data in the documents. The XSLT conversion converts the XML documents into another markup language in which the tags pertain to the visual presentation of the information contained in the documents. (To facilitate discussion, the following description assumes the use of HTML to render the documents; however, other presentation-oriented markup languages can be used to render the documents.) Because HTML is a markup language, it can be conceptualized as a view tree 220 that includes a hierarchical organization of nodes, as in the case of data tree 216. The reader is referred to the World Wide Web Consortium's (W3C) specifications for background information regarding XML and XSL.
Nodes in the view tree 220 can be mapped (i.e., associated) to corresponding nodes in the data tree 216. Further, nodes in the data tree 216 can be mapped to corresponding nodes in the view tree 220. The mapping of nodes in the view tree 220 to nodes in the data tree 216 allows the solution module 204 to correlate editing operations performed on the visual surface 206 to corresponding nodes in an XML document. This allows the solution module 204 to store information entered by the editing user 208 into the XML document during an editing session. Additional information regarding the mapping functionality of the data processing application 200 can be found in the commonly assigned U.S. patent application entitled, “Mapping Between Structured Data and a Visual Surface,” filed on the same day as the present application, which names Prakash Sikchi, Evgeny N. Veselov, and Stephen J. Mooney as inventors.
The visual surface 206 itself has an appearance that is determined by both the information contained in the structured data 202 as well as the effects of the XSLT transformation provided by the transformation functionality 218. Generally, in the case of electronic forms, the visual surface 206 typically includes a hierarchical structure which is related to the hierarchical structure in the structured data 202. For instance, an exemplary electronic form 222 includes multiple sections pertaining to different topics that reflect the topics in the structured data 202. (However, it is not necessary to have a one-to-one direct correspondence between the organization of the structured data 202 and the organization of the visual surface 206; in other words, the transformation of the structured data 202 to the visual surface 206 is generally considered non-isomorphic). Each section in the exemplary electronic form 222 can include one or more data entry fields for received input from the editing user 208, such as data entry field 224. The data entry fields are also referred to herein as “editing controls.” Different graphical components can be used to implement the editing controls, including text boxes, drop-down list boxes, lists boxes, option buttons (also referred to as radio buttons), check boxes, and so on.
The functionality of the solution module 204 is defined, in part, by a solution file, such as exemplary solution file 226 stored in storage 228. The solution file 226 essentially constitutes an electronic form template, providing all of the semantic information required to transform the structured data 202 into the visual surface 206. Different XML documents may have been created by, or otherwise refer to, different electronic form templates. Accordingly, different XML documents may have different solution files associated therewith. Various techniques can be used to retrieve a solution file that is associated with a particular XML document. For instance, an appropriate solution file can be retrieved based on URN (Uniform Resource Name) or URL (Uniform Resource Locator) information contained in the header of an input XML document. That header information links the input document to a corresponding solution file.
Jumping ahead briefly in the sequence of figures,
With the above introduction, the focus will now turn to the mechanism provided in the data processing application 200 for upgrading documents.
Overview of Upgrade Strategy
Returning to
An upgrade module 238 allows the solution module 204 to transform the XML-V1 structured data 202 into a format compatible with version V2 of the solution module By way of overview, the upgrade module 238 performs this task by modifying the XML-V1 structured data 202 so that it conforms to the expectations of the V2 solution module 204. Such “expectations” may pertain to schema-type expectations that are specified in the schema 304 of the solution module 204. Other “expectations” may pertain to aspects which are considered important to the visual appearance and/or behavior of the V2 version of the electronic form 222, but might not be dictated by the schema 304 of the solution module 204. The upgrade module 238 is shown as being encompassed by the transformation functionality 218 because it can be implemented as an XSL transformation file. Namely, the upgrade module 238 works by transforming the XML-V1 structured data 202 into another XML document that is compatible with the V2 version of the solution module 204.
An upgrade generation module 240 performs the task of generating the upgrade module 238. The upgrade generation module 240 can be triggered to perform this task when the designing user makes a significant change to the electronic form 222. This will prompt the design aspects of the data processing application 200 to generate an XSL file that will convert an input arbitrary XML document into an XML document that is compatible with the expectations of the new version of the solution module 204. In another implementation, the upgrade generation module 240 can generate the upgrade module 238 automatically in any editing circumstance, that is, regardless of the assessed significance of the change.
Finally, an optional “when-to-upgrade” module 242 determines when to apply the upgrade module 238. The when-to-upgrade module 242 may specify that the upgrade module 238 is to be applied to only documents applied to a range of versions, such as versions 2.0 to 3.3, etc. Information regarding the version of an input document can be gleaned from header information contained in the XML document. This module 242 is optional, however, in the sense that the solution module 204 has the capability of processing any structured document produced by any version of any application, and therefore does not require prior knowledge of the version of the input document.
Advancing to
To begin with, scenario 502 shows the case where the input document 508 represents a document produced by a first version of the solution module 204, and is therefore labeled XML-V1. XML-V1508 includes a series of nodes that reflect information contained in the document, including nodes R (i.e., signifying the root), B, C, and D. Schema 510 reflects the schema expectations of the version V2 of the solution module 204. The schema 510 corresponds to the nodes in XML-V1508, except that a new node A has been added. This new node may reflect a new data entry field added to the electronic form 222 by the designing user. In other words, the new node may reflect a new piece of information that is being collected by the electronic form 222. The upgrade module 238 comes into play by creating a new XML document 512 containing created nodes that reflect the expectations of version V2 of the solution module 204. In the new document 512, the contents of nodes R, B, C, and D are copied from the source document XML-V1508 into the new document 512. In addition, the upgrade module 238 creates new node A, and may assign a default value to this node.
Scenario 504 represents the case where the document XML-V1514 contains nodes R, A, B, C, and D, but the schema 516 of version V2 of the solution module 204 omits node A. This change may indicate that the designing user has subsequently modified the electronic form 222 to delete a data entry field. This change indicates that a piece of information is no longer being collection via the electronic form 222. In this situation, the upgrade module 238 comes into play by creating a new XML document 518 that contains nodes R, B, C, and D having content copied from the same-named nodes in document XML-V1514, but that fails to create node A (because this node is not specified in the schema 516), and thus effectively deletes node A from the input document XML-V1514.
Scenario 506 describes the case where the input document XML-V1520 again includes nodes R, A, B, C, and D. In this case, however, the designing user has renamed node A as node E, and this is reflected in the schema 522. This might correspond to the case where the designing user has renamed a data entry field in the electronic form 222. For example, the designing user might have changed the name of a text entry field from “automobile” to “car,” etc. The upgrade module 238 addresses this case by creating nodes R, B, C, and D having content copied from the same-named nodes in the document XML-V1520. This yields XML document 524. However, because it does not find node A in the schema 522, the upgrade module 238 does not create this node, and thus effectively deletes it. On the other hand, the upgrade module 238 sees the new node E in the schema 522, and thus adds node E to the transformed XML document 524. This is merely one way to handle the case where nodes are renamed.
In other cases, the upgrade module 204 can incorporate functionality having the necessary intelligence to detect that a node in the input XML document reflects an identical node in the schema which has been simply renamed (that is, without having to execute the above-described deleting/adding procedure). For example, the structure of an input document can be compared with the structure of a document expected by a current version of an application (e.g., as reflected by the schema associated with the current version). The comparison may reveal a close match between a collection of nodes in the input document and a collection of nodes in the expected structure. The comparison may further reveal a positional correspondence between unmatched nodes in the input document and unmatched nodes in the expected structure. In this circumstance, there is a significant probability that these positionally related unmatched nodes reflect nodes that have simply been renamed. A rule can therefore be fashioned to detect the above-noted pattern and interpret it as a node rename. More generally, other kinds of analysis strategies may be used to detect other commonly encountered conversion pattern scenarios. These strategies can generally rely on positional and inferential analysis of node structure and content, as well as a wide variety of other analysis techniques. Some strategies can be fashioned to reflect common patterns and rules found in particular document processing environments. In another implementation, it is also possible to modify the upgrade module 238 such that it is based on some knowledge of the schema of the input XSL-V1 document; however, this solution to the problem has the drawback of making the upgrade module 238 no longer stateless.
The scenarios (502, 504, 506) shown in
The upgrade module 238 can perform other kinds of transformations besides adding and deleting nodes. Some of these other transformations may reflect the dictates of the schema 304 associated with version V2 of the solution module 204. Other transformations may not reflect the dictates of the schema 304; for instance, these other transformations may pertain to visual or behavioral features of the electronic form 222 that the designing user would like duplicated in earlier versions (e.g., V1) of the form 222's documents.
For instance, version V1 of the electronic form 222 might have specified that a certain data entry field was optional. The schema corresponding to version V would therefore contain information indicating that a node corresponding to this data entry field was optional. As a result of this optional status, some XML documents produced by version V1 may contain this optional node, while others may not. A subsequent second version V2 of the electronic form 222 might have modified the electronic form 222 to make the optional data entry field mandatory. However, this change might not have been propagated to a corresponding change in the schema file 304. As such, the V2 version of the solution module 204 can still “legally” process documents produced by version V1 of the electronic form 222 that lack the optional node, as these documents still conform to the schema (where this node is indicated as optional). This, however, might result various problems with the visual presentation of the electronic form 222. To prevent this from happening, the upgrade module 238 can also modify an input XML document such that it is conformant with the optional status of various nodes specified in the V2 version of the solution module 204, but not necessarily dictated by the schema 304 of the V2 version of the solution module 204.
In another example, the V2 version of the solution module 204 can capture information regarding the minimum and/or maximum number of nodes of a particular kind that is expected by the V2 version. This numeric information is referred to as cardinality information. In this case, the upgrade module 238 can be used to enforce this expectation by modifying an input document so that it conforms to the cardinality expectations of the V2 version of the solution module 204.
In another example, the V2 version of the solution module 204 can capture information regarding default values associated with nodes that are expected by the V2 version. In this case, the upgrade module 238 can be used to supply or modify default values in an input document so that this document conforms to the default value expectations of the V2 version of the solution module 204.
In another example, the V2 version of the solution module 204 might specify that certain data entry fields must contain a value—namely, that these data entry field values are mandatory. In this case, the upgrade module 238 can be used to modify the mandatory status of values associated with nodes in the input document so that this document conforms with the mandatory status expectations of the V2 version of the solution module 204.
In another example, the V2 version of the solution module 204 might specify that certain formatting applies data entry fields, such as rich text formatting. Rich text formatting requires the capture of formatting information using a data structure. In this case, the upgrade module 238 can be used to modify the formatting of the input document so that it conforms with selected formatting expectations of the V2 version of the solution module 204. However, in general, changes in formatting are considered relatively minor. Hence, many formatting changes are not “enforced” by the upgrade module 238.
The above-identified expectations are merely illustrative. Different business environments may warrant the use of the upgrade module 238 to enforce a different collection of expectations.
B. Exemplary Apparatus for Implementing Upgrade Technique
In one exemplary implementation, the forms application 610 includes a design mode and an editing mode. The design mode presents design UI 622 on the display device 620 for interaction with a designing user 624. The editing mode presents editing UI 626 on the display device 620 for interaction with the editing user 208. In the design mode, the forms application 610 creates an electronic form 628, or modifies the structure of the electronic form 628 in a way that affects its basic schema. In other words, the design operation produces the solution module 614 that furnishes the electronic form 628. In the editing mode, the editing user 208 uses the electronic form 628 for its intended purpose—that is, by entering information into the electronic form 628 for a business-related purpose or other purpose.
In the design mode, the forms application 610 can be configured to depict the electronic form 628 under development using a split-screen display technique. More specifically, a forms view portion 630 of the design UI 622 is devoted to a depiction of the normal appearance of the electronic form 628. A data source view portion 632 of the visual surface is devoted to displaying a hierarchical tree 634 that conveys the organization of data fields in the electronic form 628.
The forms application 610 offers multiple techniques for creating the electronic form 702. According to one technique, the electronic form 702 can be created from scratch by building the electronic form 702 from successively selected editing controls. The exemplary electronic form 702 shown in
Once a form has been created, its design (and associated schema) can be further modified.
The changes illustrated in
In summary, form 702 shown in
More specifically, suppose that the editing user 208 makes a request to display and/or edit a particular XML-V1 document. In one implementation, this would prompt the forms application 610 to locate the solution module 204 corresponding to the version V2 of the solution module 204, as this is the most current version. More specifically, the XML-V1 document contains information that identifies a particular kind of form in its header. The forms application 610 can be configured to retrieve the most current version of the solution module 204 corresponding to the kind of form identified in the XML-V1 document's header.
Having retrieved the V2 solution module 204, the forms application 610 proceeds to transform the XML-V1 document into an XML document which conforms to the expectations of the V2 solution module 204. The following flow charts provide additional details regarding the operations performed in generating and applying the upgrade module 238.
C. Exemplary Method of Operation
Overview of Procedure
In step 906, the designing editing user 624 creates a version V2 of the electronic form, corresponding, in one example, to the electronic form 804 shown in
In step 910, the editing user 208 attempts to display the XML-V1 document. In step 912, the forms application 610 determines what technique to use to display the XML-V1 document. In one case, the forms application 610 retrieves the version V2 of the solution module 204 corresponding to form 802 shown in
Finally, in step 914, the forms application 610 displays the XML-V1 document using the technique determined in step 912.
Generation of the Upgrade Module
Selection of Document Processing Technique
In step 1102, the forms application 610 determines whether it should display the XML-V1 document using an upgrade module 238 associated with a later version of the electronic form, such as version V2 of the electronic form. More specifically, in one implementation, the XML-V1 document has header information that specifies a solution module 204 that should be used to render the document. In response to a user's request to render the XML-V1 document, the forms application 610 retrieves an appropriate solution module 204 based on the header information in the XML-V1 document. The retrieved solution module 204 contains an upgrade module 238 as well as the when-to-apply module 242. The when-to-apply module 242 determines whether to apply the upgrade module 238 to the input document, such as, in this case, the XML-V1 document. An exemplary excerpt of instructions provided by the when-to-apply module 242 is as follows:
<xsf:documentVersionUpgrade>
</xsf:documentversionUpgrade>
These instructions state that the upgrade module 238 is to be applied to versions within a specified range, i.e., between minVersionToUpgrade and maxVersionToUpgrade. In this case, the minVersionToUpgrade is identified as version 1.0, and the maxVersionToUpgrade is specified as version 1.9. Since the user is attempting to render a document (XML-V1) produced by version V1, then the forms application 610 will apply the upgrade module 238 to this version. Step 914 involves displaying the XML-V1 document using the upgrade module 238. Details of step 914 are presented in
In addition, the forms application 610 provides other techniques for processing the XML-V1 document. For instance, in step 1106, the forms application 610 determines whether the retrieved solution module 204 has been configured to apply a special script to convert the XML-V1 document into a format compatible with the retrieved solution module 204. Such a script can be created by a designing user and stored in the business logic 310 of the solution module 204. The forms application 610 can automatically access and apply the script in response to an editing user's request to edit the XML-V1 input document. Step 1108 represents the application of the custom script to the XML-V1 document.
In another case, as reflected in step 1110, the forms application 610 can apply a custom XSL upgrade module to the inputted document (XML-V1), rather than the upgrade module 238 that was automatically generated by the forms application 610 when the designing user 624 made a change in the electronic form. If this technique is activated, in step 1112, the forms application 610 applies the custom XSL module to the is input document.
In another case, as reflected in step 1114, the forms application 610 can process the XML-V1 document without first transforming this document using any upgrade module. In this case, as reflected in step 1116, the XML-V1 document is displayed as if it was a document created by a later version (e.g., version V2), which is not the case. This might result in one or more anomalies in the visual presentation of the electronic form, and one or more anomalies in the behavior of the thus displayed form.
Finally, step 1118 indicates that the forms application 610 can render the XML-V1 document using still additional techniques. Generally, as was assumed in the above discussion, the forms application 610 can be configured to automatically select any of the options shown in
The Operation of the Upgrade Module
More specifically, the procedure 914 focuses on an exemplary routine 1202 for processing a single leaf node that is expected by version V2 of the solution module 204. As indicated by loop 1204, the routine 1202 is repeated a plurality of times for individual nodes expected by version V2 of the solution module 204. That is, for instance, some of the nodes expected by version V2 include a collection of child nodes associated therewith. Also, these child nodes may have their own respective child nodes. Nodes that have a plurality of nodes associated therewith are referred to as container nodes. The loop 1204 generally indicates that the routine 1202 is repeated for individual nodes within a container.
Generally, routine 1202 processes an XML-V1 document by making reference to the expectations of version V2 of the solution module 204 to produce a modified document. For a single expected node, step 1206 of the routine 1202 creates a corresponding node in the modified document. That is, if the schema of the version V2 of the solution module 204 indicates that a node is expected, then the routine 1202 creates this node. A node that is present in the XML-V1 document that is not expected by the V2 schema is not created, and thus is effectively deleted.
Step 1208 determines whether the node created in step 1206 has a counterpart node in the XML-V1 document. If so, in step 1210, the routine 1202 copies the content of the counterpart XML-V1 node into the node created in step 1206. If step 1208 is answered in the negative, then a step 1212 can add default content to the node created in step 1206. In other words, assume that the XML-V1 document omits a node that is expected by the V2 version. In this case, the routine 1202 will add that node to the modified document in step 1206, and then assign a default value to that node in step 1212.
Once again, the loop 1204 indicates that the routine 1202 is repeated a plurality of times for additional nodes expected by version V2 of the solution module 204.
As a result of the above-described processing, an XML-V1 document can be successfully processed using the XSLT associated with version V2 of the solution module 204. In effect, the upgrade module 238 internally transforms the XML-V1 document into an XML-V2 document. The same procedure can be performed to transform any input document, such as, in one case, an input document that has a completely arbitrary form relative to the schema of the version V2.
In the exemplary context of
The procedure 914 shown in
D. Exemplary Computer Environment
Exemplary computer 602 includes one or more processors or processing units 604, a system memory 606, and a bus 1402. The bus 1402 connects various system components together. For instance, the bus 1402 connects the processor 604 to the system memory 606. The bus 1402 can be implemented using any kind of bus structure or combination of bus structures, including a memory bus or memory controller, a peripheral bus, an accelerated graphics port, and a processor or local bus using any of a variety of bus architectures. For example, such architectures can include an Industry Standard Architecture (ISA) bus, a Micro Channel Architecture (MCA) bus, an Enhanced ISA (EISA) bus, a Video Electronics Standards Association (VESA) local bus, and a Peripheral Component Interconnects (PCI) bus also known as a Mezzanine bus.
Computer 602 can also include a variety of computer readable media, including a variety of types of volatile and non-volatile media, each of which can be removable or non-removable. For example, system memory 606 includes computer readable media in the form of volatile memory, such as random access memory (RAM) 1404, and non-volatile memory, such as read only memory (ROM) 1406. ROM 1406 includes an input/output system (BIOS) 1408 that contains the basic routines that help to transfer information between elements within computer 602, such as during start-up. RAM 1404 typically contains data and/or program modules in a form that can be quickly accessed by processing unit 604.
Other kinds of computer storage media include a hard disk drive 1410 for reading from and writing to a non-removable, non-volatile magnetic media, a magnetic disk drive 1412 for reading from and writing to a removable, non-volatile magnetic disk 1414 (e.g., a “floppy disk”), and an optical disk drive 1416 for reading from and/or writing to a removable, non-volatile optical disk 1418 such as a CD-ROM, DVD-ROM, or other optical media. The hard disk drive 1410, magnetic disk drive 1412, and optical disk drive 1416 are each connected to the system bus 1402 by one or more data media interfaces 1420. Alternatively, the hard disk drive 1410, magnetic disk drive 1412, and optical disk drive 1416 can be connected to the system bus 1402 by a SCSI interface (not shown), or other coupling mechanism. Although not shown, the computer 602 can include other types of computer readable media, such as magnetic cassettes or other magnetic storage devices, flash memory cards, CD-ROM, digital versatile disks (DVD) or other optical storage, electrically erasable programmable read-only memory (EEPROM), etc.
Generally, the above-identified computer readable media provide non-volatile storage of computer readable instructions, data structures, program modules, and other data for use by computer 602. For instance, the readable media can store the operating system 608, one or more application programs 1422 (such as the forms application 610), other program modules 1424, and program data 1426.
The computer environment 1400 can include a variety of input devices. For instance, the computer environment 1400 includes the keyboard 212 and a pointing device 214 (e.g., a “mouse”) for entering commands and information into computer 602. The computer environment 1400 can include other input devices (not illustrated), such as a microphone, joystick, game pad, satellite dish, serial port, scanner, card reading devices, digital or video camera, etc. Input/output interfaces 1428 couple the input devices to the processing unit 604. More generally, input devices can be coupled to the computer 602 through any kind of interface and bus structures, such as a parallel port, serial port, game port, universal serial bus (USB) port, etc.
The computer environment 1400 also includes the display device 620. A video adapter 1430 couples the display device 620 to the bus 1402. In addition to the display device 620, the computer environment 1400 can include other output peripheral devices, such as speakers (not shown), a printer (not shown), etc.
Computer 602 can operate in a networked environment using logical connections to one or more remote computers, such as a remote computing device 1432. The remote computing device 1432 can comprise any kind of computer equipment, including a general purpose personal computer, portable computer, a server, a router, a network computer, a peer device or other common network node, etc. Remote computing device 1432 can include all of the features discussed above with respect to computer 602, or some subset thereof.
Any type of network can be used to couple the computer 602 with remote computing device 1432, such as a local area network (LAN) 1434, or a wide area network (WAN) 1436 (such as the Internet). When implemented in a LAN networking environment, the computer 602 connects to local network 1434 via a network interface or adapter 1438. When implemented in a WAN networking environment, the computer 602 can connect to the WAN 1436 via a modem 1440 or other connection strategy. The modem 1440 can be located internal or external to computer 602, and can be connected to the bus 1402 via serial I/O interfaces 1442 other appropriate coupling mechanism. Although not illustrated, the computing environment 1400 can provide wireless communication functionality for connecting computer 602 with remote computing device 1432 (e.g., via modulated radio signals, modulated infrared signals, etc.).
In a networked environment, the computer 602 can draw from program modules stored in a remote memory storage device 1444. Generally, the depiction of program modules as discrete blocks in
Wherever physically stored, one or more memory modules 606, 1414, 1418, 1444, etc. can be provided to store the forms application 610.
Although the invention has been described in language specific to structural features and/or methodological acts, it is to be understood that the invention defined in the appended claims is not necessarily limited to the specific features or acts described. Rather, the specific features and acts are disclosed as exemplary forms of implementing the claimed invention.
Number | Name | Date | Kind |
---|---|---|---|
4201978 | Nally | May 1980 | A |
4498147 | Agnew et al. | Feb 1985 | A |
4514800 | Gruner et al. | Apr 1985 | A |
4564752 | Lepic et al. | Jan 1986 | A |
4641274 | Swank | Feb 1987 | A |
4674040 | Barker et al. | Jun 1987 | A |
4739477 | Barker et al. | Apr 1988 | A |
4815029 | Barker et al. | Mar 1989 | A |
4847749 | Collins et al. | Jul 1989 | A |
4910663 | Bailey | Mar 1990 | A |
4933880 | Borgendale et al. | Jun 1990 | A |
4962475 | Hernandez et al. | Oct 1990 | A |
5025484 | Yamanari et al. | Jun 1991 | A |
5072412 | Henderson, Jr. et al. | Dec 1991 | A |
5179703 | Evans | Jan 1993 | A |
5187786 | Densmore et al. | Feb 1993 | A |
5191645 | Carlucci et al. | Mar 1993 | A |
5195183 | Miller et al. | Mar 1993 | A |
5204947 | Bernstein et al. | Apr 1993 | A |
5206951 | Khoyi et al. | Apr 1993 | A |
5218672 | Morgan et al. | Jun 1993 | A |
5222160 | Sakai et al. | Jun 1993 | A |
5228100 | Takeda et al. | Jul 1993 | A |
5237680 | Adams et al. | Aug 1993 | A |
5249275 | Srivastava | Sep 1993 | A |
5274803 | Dubin et al. | Dec 1993 | A |
5297249 | Bernstein et al. | Mar 1994 | A |
5297283 | Kelly, Jr. et al. | Mar 1994 | A |
5313631 | Kao | May 1994 | A |
5313646 | Hendricks et al. | May 1994 | A |
5317686 | Salas et al. | May 1994 | A |
5333317 | Dann | Jul 1994 | A |
5339423 | Beitel et al. | Aug 1994 | A |
5339424 | Fushimi | Aug 1994 | A |
5341478 | Travis, Jr. et al. | Aug 1994 | A |
5369766 | Nakano et al. | Nov 1994 | A |
5369778 | San Soucie et al. | Nov 1994 | A |
5371675 | Greif et al. | Dec 1994 | A |
5377323 | Vasudevan | Dec 1994 | A |
5379419 | Hefferman et al. | Jan 1995 | A |
5381547 | Flug et al. | Jan 1995 | A |
5390325 | Miller | Feb 1995 | A |
5408665 | Fitzgerald | Apr 1995 | A |
5410646 | Tondevold et al. | Apr 1995 | A |
5410688 | Williams et al. | Apr 1995 | A |
5412772 | Monson | May 1995 | A |
5434975 | Allen | Jul 1995 | A |
5436637 | Gayraud et al. | Jul 1995 | A |
5438659 | Notess et al. | Aug 1995 | A |
5440744 | Jacobson et al. | Aug 1995 | A |
5446842 | Schaeffer et al. | Aug 1995 | A |
5455875 | Chevion et al. | Oct 1995 | A |
5459865 | Heninger et al. | Oct 1995 | A |
5481722 | Skinner | Jan 1996 | A |
5497489 | Menne | Mar 1996 | A |
5504898 | Klein | Apr 1996 | A |
5517655 | Collins et al. | May 1996 | A |
5535389 | Elder et al. | Jul 1996 | A |
5542070 | LeBlanc et al. | Jul 1996 | A |
5550976 | Henderson et al. | Aug 1996 | A |
5551035 | Arnold et al. | Aug 1996 | A |
5555325 | Burger | Sep 1996 | A |
5566330 | Sheffield | Oct 1996 | A |
5572643 | Judson | Nov 1996 | A |
5572648 | Bibayan | Nov 1996 | A |
5577252 | Nelson et al. | Nov 1996 | A |
5581686 | Koppolu et al. | Dec 1996 | A |
5581760 | Atkinson et al. | Dec 1996 | A |
5600789 | Parker et al. | Feb 1997 | A |
5602996 | Powers, III et al. | Feb 1997 | A |
5608720 | Biegel et al. | Mar 1997 | A |
5625783 | Ezekiel et al. | Apr 1997 | A |
5627979 | Chang et al. | May 1997 | A |
5630126 | Redpath | May 1997 | A |
5634121 | Tracz et al. | May 1997 | A |
5634124 | Khoyi et al. | May 1997 | A |
5640544 | Onodera et al. | Jun 1997 | A |
5644738 | Goldman et al. | Jul 1997 | A |
5649099 | Theimer et al. | Jul 1997 | A |
5659729 | Nielsen | Aug 1997 | A |
5664178 | Sinofsky | Sep 1997 | A |
5668966 | Ono et al. | Sep 1997 | A |
5669005 | Curbow et al. | Sep 1997 | A |
5682536 | Atkinson et al. | Oct 1997 | A |
5689667 | Kurtenbach | Nov 1997 | A |
5689703 | Atkinson et al. | Nov 1997 | A |
5704029 | Wright, Jr. | Dec 1997 | A |
5706501 | Horikiri et al. | Jan 1998 | A |
5717939 | Bricklin et al. | Feb 1998 | A |
5721824 | Taylor | Feb 1998 | A |
5740439 | Atkinson et al. | Apr 1998 | A |
5742504 | Meyer et al. | Apr 1998 | A |
5745683 | Lee et al. | Apr 1998 | A |
5745712 | Turpin et al. | Apr 1998 | A |
5748807 | Lopresti et al. | May 1998 | A |
5758184 | Lucovsky et al. | May 1998 | A |
5758358 | Ebbo | May 1998 | A |
5761408 | Kolawa et al. | Jun 1998 | A |
5761683 | Logan et al. | Jun 1998 | A |
5764984 | Loucks | Jun 1998 | A |
5764985 | Smale | Jun 1998 | A |
5778372 | Cordell et al. | Jul 1998 | A |
5778402 | Gipson | Jul 1998 | A |
5784555 | Stone | Jul 1998 | A |
5790796 | Sadowsky | Aug 1998 | A |
5798757 | Smith | Aug 1998 | A |
5801701 | Koppolu et al. | Sep 1998 | A |
5802304 | Stone | Sep 1998 | A |
5806079 | Rivette et al. | Sep 1998 | A |
5815830 | Anthony | Sep 1998 | A |
5826265 | Van Huben et al. | Oct 1998 | A |
5835777 | Staelin | Nov 1998 | A |
5838906 | Doyle et al. | Nov 1998 | A |
5842018 | Atkinson et al. | Nov 1998 | A |
5845077 | Fawcett | Dec 1998 | A |
5845090 | Collins, III et al. | Dec 1998 | A |
5854630 | Nielsen | Dec 1998 | A |
5859973 | Carpenter et al. | Jan 1999 | A |
5862372 | Morris et al. | Jan 1999 | A |
5862379 | Rubin et al. | Jan 1999 | A |
5864819 | De Armas et al. | Jan 1999 | A |
5907704 | Gudmundson et al. | May 1999 | A |
5910895 | Proskauer et al. | Jun 1999 | A |
5911776 | Guck | Jun 1999 | A |
5915112 | Boutcher | Jun 1999 | A |
5922072 | Hutchinson et al. | Jul 1999 | A |
5928363 | Ruvolo | Jul 1999 | A |
5929858 | Shibata et al. | Jul 1999 | A |
5940075 | Mutschler, III et al. | Aug 1999 | A |
5950010 | Hesse et al. | Sep 1999 | A |
5956481 | Walsh et al. | Sep 1999 | A |
5963964 | Nielsen | Oct 1999 | A |
5973696 | Agranat et al. | Oct 1999 | A |
5974454 | Apfel et al. | Oct 1999 | A |
5982370 | Kamper | Nov 1999 | A |
5983348 | Ji | Nov 1999 | A |
5987480 | Donohue et al. | Nov 1999 | A |
5991710 | Papineni et al. | Nov 1999 | A |
5991731 | Colon et al. | Nov 1999 | A |
5991877 | Luckenbaugh | Nov 1999 | A |
5995103 | Ashe | Nov 1999 | A |
5999740 | Rowley | Dec 1999 | A |
6005570 | Gayraud et al. | Dec 1999 | A |
6014135 | Fernandes | Jan 2000 | A |
6016520 | Facq et al. | Jan 2000 | A |
6026379 | Haller et al. | Feb 2000 | A |
6026416 | Kanerva et al. | Feb 2000 | A |
6031989 | Cordell | Feb 2000 | A |
6035297 | Van Huben et al. | Mar 2000 | A |
6044205 | Reed et al. | Mar 2000 | A |
6052531 | Waldin et al. | Apr 2000 | A |
6052710 | Saliba et al. | Apr 2000 | A |
6054987 | Richardson | Apr 2000 | A |
6072870 | Nguyen et al. | Jun 2000 | A |
6078326 | Kilmer et al. | Jun 2000 | A |
6078327 | Liman et al. | Jun 2000 | A |
6078924 | Ainsbury et al. | Jun 2000 | A |
6081610 | Dwork et al. | Jun 2000 | A |
6084585 | Kraft et al. | Jul 2000 | A |
6088708 | Burch et al. | Jul 2000 | A |
6091417 | Lefkowitz | Jul 2000 | A |
6094657 | Hailpern et al. | Jul 2000 | A |
6097382 | Rosen et al. | Aug 2000 | A |
6098081 | Heidorn et al. | Aug 2000 | A |
6108637 | Blumenau | Aug 2000 | A |
6108783 | Krawczyk et al. | Aug 2000 | A |
6115646 | Fiszman et al. | Sep 2000 | A |
6121965 | Kenney et al. | Sep 2000 | A |
6122647 | Horowitz et al. | Sep 2000 | A |
6144969 | Inokuchi et al. | Nov 2000 | A |
6151624 | Teare et al. | Nov 2000 | A |
6154128 | Wookey et al. | Nov 2000 | A |
6163772 | Kramer et al. | Dec 2000 | A |
6167521 | Smith et al. | Dec 2000 | A |
6167523 | Strong | Dec 2000 | A |
6182094 | Humpleman et al. | Jan 2001 | B1 |
6182095 | Leymaster et al. | Jan 2001 | B1 |
6188401 | Peyer | Feb 2001 | B1 |
6191797 | Politis | Feb 2001 | B1 |
6192367 | Hawley et al. | Feb 2001 | B1 |
6195661 | Filepp et al. | Feb 2001 | B1 |
6199204 | Donohue | Mar 2001 | B1 |
6209128 | Gerard et al. | Mar 2001 | B1 |
6216152 | Wong et al. | Apr 2001 | B1 |
6219698 | Iannucci et al. | Apr 2001 | B1 |
6225996 | Gibb et al. | May 2001 | B1 |
6235027 | Herzon | May 2001 | B1 |
6253366 | Mutschler, III | Jun 2001 | B1 |
6253374 | Dresevic et al. | Jun 2001 | B1 |
6263313 | Milsted et al. | Jul 2001 | B1 |
6266810 | Tanaka et al. | Jul 2001 | B1 |
6268852 | Lindhorst et al. | Jul 2001 | B1 |
6272506 | Bell | Aug 2001 | B1 |
6275227 | DeStefano | Aug 2001 | B1 |
6275599 | Adler et al. | Aug 2001 | B1 |
6279042 | Ouchi | Aug 2001 | B1 |
6281896 | Alimpich et al. | Aug 2001 | B1 |
6282711 | Halpern et al. | Aug 2001 | B1 |
6286033 | Kishinsky et al. | Sep 2001 | B1 |
6292897 | Gennaro et al. | Sep 2001 | B1 |
6297819 | Furst | Oct 2001 | B1 |
6300948 | Geller et al. | Oct 2001 | B1 |
6307955 | Zank et al. | Oct 2001 | B1 |
6308179 | Petersen et al. | Oct 2001 | B1 |
6308273 | Goertzel et al. | Oct 2001 | B1 |
6311271 | Gennaro et al. | Oct 2001 | B1 |
6314415 | Mukherjee | Nov 2001 | B1 |
6321259 | Ouellette et al. | Nov 2001 | B1 |
6321334 | Jerger et al. | Nov 2001 | B1 |
6327628 | Anuff et al. | Dec 2001 | B1 |
6331864 | Coco et al. | Dec 2001 | B1 |
6342907 | Petty et al. | Jan 2002 | B1 |
6343149 | Motoiwa | Jan 2002 | B1 |
6343302 | Graham | Jan 2002 | B1 |
6345256 | Milsted et al. | Feb 2002 | B1 |
6345278 | Hitchcock et al. | Feb 2002 | B1 |
6345361 | Jerger et al. | Feb 2002 | B1 |
6347323 | Garber et al. | Feb 2002 | B1 |
6349408 | Smith | Feb 2002 | B1 |
6351574 | Yair et al. | Feb 2002 | B1 |
6353926 | Parthesarathy et al. | Mar 2002 | B1 |
6356906 | Lippert et al. | Mar 2002 | B1 |
6357038 | Scouten | Mar 2002 | B1 |
6366907 | Fanning et al. | Apr 2002 | B1 |
6366912 | Wallent et al. | Apr 2002 | B1 |
6367013 | Bisbee et al. | Apr 2002 | B1 |
6369840 | Barnett et al. | Apr 2002 | B1 |
6369841 | Salomon et al. | Apr 2002 | B1 |
6374402 | Schmeidler et al. | Apr 2002 | B1 |
6381742 | Forbes et al. | Apr 2002 | B2 |
6381743 | Mutschler, III | Apr 2002 | B1 |
6389434 | Rivette et al. | May 2002 | B1 |
6393456 | Ambler et al. | May 2002 | B1 |
6396488 | Simmons et al. | May 2002 | B1 |
6405221 | Levine et al. | Jun 2002 | B1 |
6408311 | Baisley et al. | Jun 2002 | B1 |
6414700 | Kurtenbach et al. | Jul 2002 | B1 |
6421070 | Ramos et al. | Jul 2002 | B1 |
6421656 | Cheng et al. | Jul 2002 | B1 |
6425125 | Fries et al. | Jul 2002 | B1 |
6429885 | Saib et al. | Aug 2002 | B1 |
6434563 | Pasquali et al. | Aug 2002 | B1 |
6434564 | Ebert | Aug 2002 | B2 |
6442563 | Bacon et al. | Aug 2002 | B1 |
6442755 | Lemmons et al. | Aug 2002 | B1 |
6446110 | Lection et al. | Sep 2002 | B1 |
6457009 | Bollay | Sep 2002 | B1 |
6460058 | Koppolu et al. | Oct 2002 | B2 |
6463419 | Kluss | Oct 2002 | B1 |
6470349 | Heninger et al. | Oct 2002 | B1 |
6473800 | Jerger et al. | Oct 2002 | B1 |
6476828 | Burkett et al. | Nov 2002 | B1 |
6476833 | Moshfeghi | Nov 2002 | B1 |
6477544 | Bolosky et al. | Nov 2002 | B1 |
6480860 | Monday | Nov 2002 | B1 |
6487566 | Sundaresan | Nov 2002 | B1 |
6490601 | Markus et al. | Dec 2002 | B1 |
6493702 | Adar et al. | Dec 2002 | B1 |
6501864 | Eguchi et al. | Dec 2002 | B1 |
6502101 | Verprauskus et al. | Dec 2002 | B1 |
6502103 | Frey et al. | Dec 2002 | B1 |
6505230 | Mohan et al. | Jan 2003 | B1 |
6505300 | Chan et al. | Jan 2003 | B2 |
6507856 | Chen et al. | Jan 2003 | B1 |
6516322 | Meredith | Feb 2003 | B1 |
6519617 | Wanderski et al. | Feb 2003 | B1 |
RE38070 | Spies et al. | Apr 2003 | E |
6546546 | Van Doorn | Apr 2003 | B1 |
6549221 | Brown et al. | Apr 2003 | B1 |
6549878 | Lowry et al. | Apr 2003 | B1 |
6549922 | Srivastava et al. | Apr 2003 | B1 |
6553402 | Makarios et al. | Apr 2003 | B1 |
6560616 | Garber | May 2003 | B1 |
6560620 | Ching | May 2003 | B1 |
6560640 | Smethers | May 2003 | B2 |
6563514 | Samar | May 2003 | B1 |
6571253 | Thompson et al. | May 2003 | B1 |
6578144 | Gennaro et al. | Jun 2003 | B1 |
6581061 | Graham | Jun 2003 | B2 |
6584469 | Chiang et al. | Jun 2003 | B1 |
6584548 | Bourne et al. | Jun 2003 | B1 |
6585778 | Hind et al. | Jul 2003 | B1 |
6589290 | Maxwell et al. | Jul 2003 | B1 |
6594686 | Edwards et al. | Jul 2003 | B1 |
6598219 | Lau | Jul 2003 | B1 |
6603489 | Edlund et al. | Aug 2003 | B1 |
6604099 | Chung et al. | Aug 2003 | B1 |
6606606 | Star | Aug 2003 | B2 |
6609200 | Anderson et al. | Aug 2003 | B2 |
6611822 | Beams et al. | Aug 2003 | B1 |
6611840 | Baer et al. | Aug 2003 | B1 |
6611843 | Jacobs | Aug 2003 | B1 |
6613098 | Sorge et al. | Sep 2003 | B1 |
6615276 | Mastrianni et al. | Sep 2003 | B1 |
6629109 | Koshisaka | Sep 2003 | B1 |
6631357 | Perkowski | Oct 2003 | B1 |
6631379 | Cox | Oct 2003 | B2 |
6631497 | Jamshidi et al. | Oct 2003 | B1 |
6631519 | Nicholson et al. | Oct 2003 | B1 |
6632251 | Rutten et al. | Oct 2003 | B1 |
6635089 | Burkett et al. | Oct 2003 | B1 |
6636845 | Chau et al. | Oct 2003 | B2 |
6643633 | Chau et al. | Nov 2003 | B2 |
6643652 | Helgeson et al. | Nov 2003 | B2 |
6643684 | Malkin et al. | Nov 2003 | B1 |
6651217 | Kennedy et al. | Nov 2003 | B1 |
6654737 | Nunez | Nov 2003 | B1 |
6654932 | Bahrs et al. | Nov 2003 | B1 |
6658417 | Stakutis et al. | Dec 2003 | B1 |
6658622 | Aiken et al. | Dec 2003 | B1 |
6661920 | Skinner | Dec 2003 | B1 |
6668369 | Krebs et al. | Dec 2003 | B1 |
6671805 | Brown et al. | Dec 2003 | B1 |
6675202 | Perttunen | Jan 2004 | B1 |
6678717 | Schneider | Jan 2004 | B1 |
6681370 | Gournares et al. | Jan 2004 | B2 |
6691230 | Bardon | Feb 2004 | B1 |
6691281 | Sorge et al. | Feb 2004 | B1 |
6697944 | Jones et al. | Feb 2004 | B1 |
6701434 | Rohatgi | Mar 2004 | B1 |
6701486 | Weber et al. | Mar 2004 | B1 |
6704906 | Yankovich et al. | Mar 2004 | B1 |
6711679 | Guski et al. | Mar 2004 | B1 |
6720985 | Silverbrook et al. | Apr 2004 | B1 |
6725426 | Pavlov | Apr 2004 | B1 |
6728755 | de Ment | Apr 2004 | B1 |
6745367 | Bates et al. | Jun 2004 | B1 |
6748385 | Rodkin et al. | Jun 2004 | B1 |
6751777 | Bates et al. | Jun 2004 | B2 |
6754874 | Richman | Jun 2004 | B1 |
6757826 | Paltenghe | Jun 2004 | B1 |
6757868 | Glaser et al. | Jun 2004 | B1 |
6760723 | Oshinsky et al. | Jul 2004 | B2 |
6763343 | Brooke et al. | Jul 2004 | B1 |
6772139 | Smith, III | Aug 2004 | B1 |
6772165 | O'Carroll | Aug 2004 | B2 |
6774926 | Ellis et al. | Aug 2004 | B1 |
6779154 | Nussbaum et al. | Aug 2004 | B1 |
6781609 | Barker et al. | Aug 2004 | B1 |
6782144 | Bellavita et al. | Aug 2004 | B2 |
6799299 | Li et al. | Sep 2004 | B1 |
6801929 | Donoho et al. | Oct 2004 | B1 |
6816849 | Halt, Jr. | Nov 2004 | B1 |
6845380 | Su et al. | Jan 2005 | B2 |
6845499 | Srivastava et al. | Jan 2005 | B2 |
6847387 | Roth | Jan 2005 | B2 |
6848078 | Birsan et al. | Jan 2005 | B1 |
6871220 | Rajan et al. | Mar 2005 | B1 |
6874130 | Baweja et al. | Mar 2005 | B1 |
6876996 | Czajkowski et al. | Apr 2005 | B2 |
6889359 | Conner et al. | May 2005 | B1 |
6901403 | Bata et al. | May 2005 | B1 |
6915454 | Moore et al. | Jul 2005 | B1 |
6931532 | Davis et al. | Aug 2005 | B1 |
6941510 | Ozzie et al. | Sep 2005 | B1 |
6941511 | Hind et al. | Sep 2005 | B1 |
6941521 | Lin et al. | Sep 2005 | B2 |
6948133 | Haley | Sep 2005 | B2 |
6948135 | Ruthfield et al. | Sep 2005 | B1 |
6950980 | Malcolm | Sep 2005 | B1 |
6961897 | Peel, Jr. et al. | Nov 2005 | B1 |
6963875 | Moore et al. | Nov 2005 | B2 |
6968503 | Chang et al. | Nov 2005 | B1 |
6968505 | Stoll et al. | Nov 2005 | B2 |
6993714 | Kaler et al. | Jan 2006 | B2 |
6996776 | Makely et al. | Feb 2006 | B1 |
6996781 | Myers et al. | Feb 2006 | B1 |
7000179 | Yankovich et al. | Feb 2006 | B2 |
7002560 | Graham | Feb 2006 | B2 |
7003722 | Rothchiller et al. | Feb 2006 | B2 |
7010580 | Fu et al. | Mar 2006 | B1 |
7020869 | Abrari et al. | Mar 2006 | B2 |
7024417 | Russakovsky et al. | Apr 2006 | B1 |
7032170 | Poulose | Apr 2006 | B2 |
7036072 | Sulistio et al. | Apr 2006 | B1 |
7039875 | Khalfay et al. | May 2006 | B2 |
7051273 | Holt et al. | May 2006 | B1 |
7058663 | Johnston et al. | Jun 2006 | B2 |
7062764 | Cohen et al. | Jun 2006 | B2 |
7065493 | Homsi | Jun 2006 | B1 |
7080083 | Kim et al. | Jul 2006 | B2 |
7080325 | Treibach-Heck et al. | Jul 2006 | B2 |
7086009 | Resnick et al. | Aug 2006 | B2 |
7086042 | Abe et al. | Aug 2006 | B2 |
7088374 | David et al. | Aug 2006 | B2 |
7100147 | Miller et al. | Aug 2006 | B2 |
7103611 | Murthy et al. | Sep 2006 | B2 |
7106888 | Silverbrook et al. | Sep 2006 | B1 |
7107282 | Yalamanchi | Sep 2006 | B1 |
7107521 | Santos | Sep 2006 | B2 |
7146564 | Kim et al. | Dec 2006 | B2 |
7152205 | Day et al. | Dec 2006 | B2 |
7168035 | Bell et al. | Jan 2007 | B1 |
7178166 | Taylor et al. | Feb 2007 | B1 |
7190376 | Tonisson | Mar 2007 | B1 |
7191394 | Ardeleanu et al. | Mar 2007 | B1 |
7213200 | Abe et al. | May 2007 | B2 |
7236982 | Zlatanov et al. | Jun 2007 | B2 |
7272789 | O'Brien | Sep 2007 | B2 |
7281018 | Begun et al. | Oct 2007 | B1 |
7296017 | Larcheveque et al. | Nov 2007 | B2 |
7313757 | Bradley et al. | Dec 2007 | B2 |
7313758 | Kozlov | Dec 2007 | B2 |
7316003 | Dulepet et al. | Jan 2008 | B1 |
7318237 | Moriconi et al. | Jan 2008 | B2 |
7334178 | Stanciu et al. | Feb 2008 | B1 |
7346610 | Ruthfield et al. | Mar 2008 | B2 |
7350141 | Kotler et al. | Mar 2008 | B2 |
20010007109 | Lange | Jul 2001 | A1 |
20010022592 | Alimpich et al. | Sep 2001 | A1 |
20010024195 | Hayakawa | Sep 2001 | A1 |
20010037345 | Kiernan et al. | Nov 2001 | A1 |
20010054004 | Powers | Dec 2001 | A1 |
20010056429 | Moore et al. | Dec 2001 | A1 |
20010056460 | Sahota et al. | Dec 2001 | A1 |
20020010700 | Wotring | Jan 2002 | A1 |
20020010743 | Ryan et al. | Jan 2002 | A1 |
20020010746 | Jilk, Jr. et al. | Jan 2002 | A1 |
20020013788 | Pennell et al. | Jan 2002 | A1 |
20020019941 | Chan et al. | Feb 2002 | A1 |
20020023113 | Hsing et al. | Feb 2002 | A1 |
20020026441 | Kutay et al. | Feb 2002 | A1 |
20020026461 | Kutay et al. | Feb 2002 | A1 |
20020032590 | Anand et al. | Mar 2002 | A1 |
20020032692 | Suzuki et al. | Mar 2002 | A1 |
20020032706 | Perla et al. | Mar 2002 | A1 |
20020032768 | Voskuil | Mar 2002 | A1 |
20020035579 | Wang et al. | Mar 2002 | A1 |
20020035581 | Reynar et al. | Mar 2002 | A1 |
20020040469 | Pramberger | Apr 2002 | A1 |
20020054126 | Gamon | May 2002 | A1 |
20020054128 | Lau et al. | May 2002 | A1 |
20020057297 | Grimes et al. | May 2002 | A1 |
20020065798 | Bostleman et al. | May 2002 | A1 |
20020065847 | Furukawa et al. | May 2002 | A1 |
20020070973 | Croley | Jun 2002 | A1 |
20020078074 | Cho et al. | Jun 2002 | A1 |
20020078103 | Gorman et al. | Jun 2002 | A1 |
20020083318 | Larose | Jun 2002 | A1 |
20020099952 | Lambert et al. | Jul 2002 | A1 |
20020100027 | Binding et al. | Jul 2002 | A1 |
20020112224 | Cox | Aug 2002 | A1 |
20020129056 | Conant | Sep 2002 | A1 |
20020133484 | Chau et al. | Sep 2002 | A1 |
20020152222 | Holbrook | Oct 2002 | A1 |
20020152244 | Dean et al. | Oct 2002 | A1 |
20020156772 | Chau et al. | Oct 2002 | A1 |
20020156846 | Rawat et al. | Oct 2002 | A1 |
20020156929 | Hekmatpour | Oct 2002 | A1 |
20020169752 | Kusama et al. | Nov 2002 | A1 |
20020169789 | Kutay et al. | Nov 2002 | A1 |
20020174147 | Wang et al. | Nov 2002 | A1 |
20020174417 | Sijacic et al. | Nov 2002 | A1 |
20020178380 | Wolf et al. | Nov 2002 | A1 |
20020184219 | Preisig et al. | Dec 2002 | A1 |
20020188597 | Kern et al. | Dec 2002 | A1 |
20020188613 | Chakraborty et al. | Dec 2002 | A1 |
20020194219 | Bradley et al. | Dec 2002 | A1 |
20020196281 | Audleman et al. | Dec 2002 | A1 |
20020196288 | Emrani | Dec 2002 | A1 |
20020198891 | Li et al. | Dec 2002 | A1 |
20020198935 | Crandall et al. | Dec 2002 | A1 |
20030004951 | Chokshi | Jan 2003 | A1 |
20030007000 | Carlson et al. | Jan 2003 | A1 |
20030014397 | Chau et al. | Jan 2003 | A1 |
20030018668 | Britton et al. | Jan 2003 | A1 |
20030020746 | Chen et al. | Jan 2003 | A1 |
20030023641 | Gorman et al. | Jan 2003 | A1 |
20030025732 | Prichard | Feb 2003 | A1 |
20030026507 | Zlotnick | Feb 2003 | A1 |
20030028550 | Lee et al. | Feb 2003 | A1 |
20030033037 | Yuen et al. | Feb 2003 | A1 |
20030037303 | Bodlaender et al. | Feb 2003 | A1 |
20030043986 | Creamer et al. | Mar 2003 | A1 |
20030046665 | Ilin | Mar 2003 | A1 |
20030048301 | Menninger | Mar 2003 | A1 |
20030051243 | Lemmons et al. | Mar 2003 | A1 |
20030055811 | Stork et al. | Mar 2003 | A1 |
20030055828 | Koch et al. | Mar 2003 | A1 |
20030056198 | Al-Azzawe et al. | Mar 2003 | A1 |
20030061386 | Brown et al. | Mar 2003 | A1 |
20030061567 | Brown et al. | Mar 2003 | A1 |
20030084424 | Reddy et al. | May 2003 | A1 |
20030093755 | O'Carroll | May 2003 | A1 |
20030110443 | Yankovich et al. | Jun 2003 | A1 |
20030120578 | Newman | Jun 2003 | A1 |
20030120651 | Bernstein et al. | Jun 2003 | A1 |
20030120659 | Sridhar | Jun 2003 | A1 |
20030120671 | Kim et al. | Jun 2003 | A1 |
20030120686 | Kim et al. | Jun 2003 | A1 |
20030126555 | Aggarwal et al. | Jul 2003 | A1 |
20030128196 | Lapstun et al. | Jul 2003 | A1 |
20030135825 | Gertner et al. | Jul 2003 | A1 |
20030140132 | Champagne et al. | Jul 2003 | A1 |
20030158897 | Ben-Natan et al. | Aug 2003 | A1 |
20030163285 | Nakamura et al. | Aug 2003 | A1 |
20030167277 | Hejlsberg et al. | Sep 2003 | A1 |
20030182268 | Lal | Sep 2003 | A1 |
20030182327 | Ramanujam et al. | Sep 2003 | A1 |
20030187756 | Klivington et al. | Oct 2003 | A1 |
20030187930 | Ghaffar et al. | Oct 2003 | A1 |
20030188260 | Jensen et al. | Oct 2003 | A1 |
20030189593 | Yarvin | Oct 2003 | A1 |
20030192008 | Lee | Oct 2003 | A1 |
20030200506 | Abe et al. | Oct 2003 | A1 |
20030204511 | Brundage et al. | Oct 2003 | A1 |
20030204814 | Elo et al. | Oct 2003 | A1 |
20030205615 | Marappan | Nov 2003 | A1 |
20030212664 | Breining et al. | Nov 2003 | A1 |
20030212902 | van der Made | Nov 2003 | A1 |
20030217053 | Bachman et al. | Nov 2003 | A1 |
20030220930 | Milleker et al. | Nov 2003 | A1 |
20030225469 | DeRemer et al. | Dec 2003 | A1 |
20030225768 | Chaudhuri et al. | Dec 2003 | A1 |
20030225829 | Pena et al. | Dec 2003 | A1 |
20030226132 | Tondreau et al. | Dec 2003 | A1 |
20030233374 | Spinola et al. | Dec 2003 | A1 |
20030233644 | Cohen et al. | Dec 2003 | A1 |
20030236859 | Vaschillo et al. | Dec 2003 | A1 |
20030236903 | Piotrowski | Dec 2003 | A1 |
20030237046 | Parker et al. | Dec 2003 | A1 |
20030237047 | Borson | Dec 2003 | A1 |
20040002939 | Arora et al. | Jan 2004 | A1 |
20040003031 | Brown et al. | Jan 2004 | A1 |
20040003353 | Rivera et al. | Jan 2004 | A1 |
20040003389 | Reynar et al. | Jan 2004 | A1 |
20040010752 | Chan et al. | Jan 2004 | A1 |
20040024842 | Witt | Feb 2004 | A1 |
20040030991 | Hepworth et al. | Feb 2004 | A1 |
20040039990 | Bakar et al. | Feb 2004 | A1 |
20040039993 | Kougiouris et al. | Feb 2004 | A1 |
20040044961 | Pesenson | Mar 2004 | A1 |
20040044965 | Toyama et al. | Mar 2004 | A1 |
20040054966 | Busch et al. | Mar 2004 | A1 |
20040059754 | Barghout et al. | Mar 2004 | A1 |
20040073565 | Kaufman et al. | Apr 2004 | A1 |
20040073868 | Easter et al. | Apr 2004 | A1 |
20040078756 | Napper et al. | Apr 2004 | A1 |
20040083426 | Sahu | Apr 2004 | A1 |
20040088647 | Miller et al. | May 2004 | A1 |
20040088652 | Abe et al. | May 2004 | A1 |
20040093596 | Koyano | May 2004 | A1 |
20040107367 | Kisters | Jun 2004 | A1 |
20040117769 | Lauzon et al. | Jun 2004 | A1 |
20040123277 | Schrader et al. | Jun 2004 | A1 |
20040146199 | Berkner et al. | Jul 2004 | A1 |
20040163041 | Engel | Aug 2004 | A1 |
20040172442 | Ripley | Sep 2004 | A1 |
20040181711 | Johnson et al. | Sep 2004 | A1 |
20040186762 | Beaven et al. | Sep 2004 | A1 |
20040189716 | Paoli et al. | Sep 2004 | A1 |
20040194035 | Chakraborty | Sep 2004 | A1 |
20040205473 | Fisher et al. | Oct 2004 | A1 |
20040205525 | Murren et al. | Oct 2004 | A1 |
20040205534 | Koelle | Oct 2004 | A1 |
20040205571 | Adler et al. | Oct 2004 | A1 |
20040205592 | Huang | Oct 2004 | A1 |
20040205605 | Adler et al. | Oct 2004 | A1 |
20040205653 | Hadfield et al. | Oct 2004 | A1 |
20040205671 | Sukehiro et al. | Oct 2004 | A1 |
20040210599 | Friedman et al. | Oct 2004 | A1 |
20040221238 | Cifra et al. | Nov 2004 | A1 |
20040221245 | Chickles et al. | Nov 2004 | A1 |
20040237030 | Malkin | Nov 2004 | A1 |
20040261019 | Imamura et al. | Dec 2004 | A1 |
20040268229 | Paoli et al. | Dec 2004 | A1 |
20050004893 | Sangroniz | Jan 2005 | A1 |
20050005248 | Rockey et al. | Jan 2005 | A1 |
20050015279 | Rucker | Jan 2005 | A1 |
20050015732 | Vedula et al. | Jan 2005 | A1 |
20050022115 | Baumgartner et al. | Jan 2005 | A1 |
20050027757 | Kiessig et al. | Feb 2005 | A1 |
20050033728 | James | Feb 2005 | A1 |
20050038711 | Marlelo | Feb 2005 | A1 |
20050055627 | Lloyd et al. | Mar 2005 | A1 |
20050060324 | Johnson et al. | Mar 2005 | A1 |
20050060721 | Choudhary et al. | Mar 2005 | A1 |
20050065933 | Goering | Mar 2005 | A1 |
20050065936 | Goering | Mar 2005 | A1 |
20050066287 | Tattrie et al. | Mar 2005 | A1 |
20050071752 | Marlatt | Mar 2005 | A1 |
20050076049 | Qubti et al. | Apr 2005 | A1 |
20050091285 | Krishnan et al. | Apr 2005 | A1 |
20050091305 | Lange et al. | Apr 2005 | A1 |
20050102370 | Lin et al. | May 2005 | A1 |
20050102612 | Allan et al. | May 2005 | A1 |
20050108104 | Woo | May 2005 | A1 |
20050108624 | Carrier | May 2005 | A1 |
20050114757 | Sahota et al. | May 2005 | A1 |
20050132196 | Dietl | Jun 2005 | A1 |
20050138086 | Pecht-Seibert | Jun 2005 | A1 |
20050171746 | Thalhammer-Reyero | Aug 2005 | A1 |
20050198086 | Moore et al. | Sep 2005 | A1 |
20050198125 | Beck et al. | Sep 2005 | A1 |
20050198247 | Perry et al. | Sep 2005 | A1 |
20050223063 | Chang et al. | Oct 2005 | A1 |
20050223320 | Brintzenhofe et al. | Oct 2005 | A1 |
20050240876 | Myers et al. | Oct 2005 | A1 |
20050246304 | Knight et al. | Nov 2005 | A1 |
20050268222 | Cheng | Dec 2005 | A1 |
20060020586 | Prompt et al. | Jan 2006 | A1 |
20060026534 | Ruthfield et al. | Feb 2006 | A1 |
20060031757 | Vincent | Feb 2006 | A9 |
20060036995 | Chickles et al. | Feb 2006 | A1 |
20060041838 | Khan | Feb 2006 | A1 |
20060059434 | Boss et al. | Mar 2006 | A1 |
20060069605 | Hatoun | Mar 2006 | A1 |
20060069985 | Friedman et al. | Mar 2006 | A1 |
20060080657 | Goodman | Apr 2006 | A1 |
20060085409 | Rys et al. | Apr 2006 | A1 |
20060101037 | Brill et al. | May 2006 | A1 |
20060101051 | Carr et al. | May 2006 | A1 |
20060129978 | Abrari et al. | Jun 2006 | A1 |
20060143220 | Spencer | Jun 2006 | A1 |
20060161559 | Bordawekar et al. | Jul 2006 | A1 |
20070036433 | Teutsch et al. | Feb 2007 | A1 |
20070050719 | Lui et al. | Mar 2007 | A1 |
20070061467 | Essey | Mar 2007 | A1 |
20070061706 | Cupala | Mar 2007 | A1 |
20070074106 | Ardeleanu | Mar 2007 | A1 |
20070094589 | Paoli | Apr 2007 | A1 |
20070100877 | Paoli | May 2007 | A1 |
20070101280 | Paoli | May 2007 | A1 |
20070118803 | Walker et al. | May 2007 | A1 |
20070130504 | Betancourt et al. | Jun 2007 | A1 |
20070208606 | MacKay et al. | Sep 2007 | A1 |
20070208769 | Boehm et al. | Sep 2007 | A1 |
20080028340 | Davis | Jan 2008 | A1 |
Number | Date | Country |
---|---|---|
0 841 615 | May 1998 | EP |
0 961 197 | Dec 1999 | EP |
1 076 290 | Feb 2001 | EP |
1221661 | Jul 2002 | EP |
401173140 | Jul 1989 | JP |
3191429 | Aug 1991 | JP |
4225466 | Aug 1992 | JP |
5314152 | Nov 1993 | JP |
406014105 | Jan 1994 | JP |
6139241 | May 1994 | JP |
6180697 | Jun 1994 | JP |
6180698 | Jun 1994 | JP |
63085960 | Apr 1998 | JP |
2000132436 | May 2000 | JP |
2002183652 | Jun 2002 | JP |
2003173288 | Jun 2003 | JP |
WO 9924945 | May 1999 | WO |
WO 9956207 | Nov 1999 | WO |
WO 0144934 | Jun 2001 | WO |
WO0157720 | Aug 2001 | WO |
WO0157720 | Sep 2006 | WO |