US 7243301 B2
A Common Annotation Framework includes, in an embodiment, an annotation having a context anchor that identifies a resource and a position in the resource that the annotation pertains to, and a content anchor that identifies data that is annotating the resource. The annotation can also be extended with client application-defined data and/or functionality, and the framework can be extended with one or more of application-defined objects, methods, and annotation stores.
1. A system comprising:
a client application layer implemented in a computing device including one or more client applications;
a storage layer including an annotation store;
a common annotation layer, situated between the client application layer and the storage layer, including an annotation manager; and
wherein the annotation manager operates to allow the one ore more client applications to store annotations to and retrieve annotations from the annotation store, and wherein the annotation manager further operates to create new property types for the annotations the new property types being identified by the one or more client applications and in addition to existing property types in the client application, so that each of the annotations to be stored in the annotation store can have a property value associated with each of the created new property types.
2. A system as recited in
3. A system as recited in
4. A system as recited in
5. A system as recited in
6. A system as recited in
7. A system as recited in
8. A method implemented in a computing device, comprising:
receiving, from a client application, a request to create an annotation;
generating the annotation; and
allowing the client application to,
add context anchor data to the annotation, wherein the context anchor data identifies a resource and a position in the resource that the annotation pertains to,
add content anchor data to the annotation, wherein the content anchor data identifies data that is annotating the resource, and
extend the types of data that can be stored in the annotation by creating one or more additional new property types to the annotation so that the annotation can have a property value associated with each of the created new property types, wherein the one or more additional new property types are in addition to the existing property types in the client application.
9. A method as recited in
10. A method as recited in
11. A method as recited in
12. A method as recited in
13. A method as recited in
14. A method as recited in
15. A method as recited in
16. One or more computer readable media having stored thereon a plurality of instructions that, when executed by one or more processors, causes the one or more processors to:
receive, from a client application, a request to create an annotation;
generate the annotation; and
allow the client application to,
add context anchor data to the annotation, wherein the context anchor data identifies a resource and a position in the resource that the annotation pertains to,
add content anchor data to the annotation, wherein the content anchor data identifies a second resource, wherein the second resource annotates the first resource, and
extend the types of data that can be stored in the annotation by creating one or more additional new property types to the annotation so that the annotation can have a property value associated with each of the created new property types, wherein the one or more additional new property types are in addition to the existing property types in the client application.
17. One or more computer readable media having stored thereon a plurality of instructions that, when executed by one or more processors, causes the one or more processors to:
receive a request to retrieve an annotation;
identify an extended property in the annotation, wherein the extended property is a created new property type identified by one or more client applications, wherein the created new property types is in addition to existing property types in the client application;
identify a codebase corresponding to the extended property, wherein the codebase identifies a location where information can be obtained that describes how to process the contents of the extended property; and
process the contents of the extended property in accordance with the information.
18. One or more computer readable media as recited in
19. One or more computer readable media as recited in
20. One or more computer readable media as recited in
21. One or more computer readable media as recited in
22. One or more computer readable media as recited in
23. One or more computer readable media as recited in
24. One or more computer readable media as recited in
25. One or more computer readable media as recited in
26. A system implemented in a computing device implementing a Common Annotation Framework comprising:
a plurality of annotation objects, each configured to store data regarding a resource being annotated and data annotating the resource; and
an object manager configured to allow a client application to access he plurality of annotation objects, and further configured to allow the client application to create new property types of the plurality of annotation objects with client application-defined data and in addition to existing property types in the client application, so that the annotation objects can have a property value associated with each of the created new property types.
27. A system as recited in
28. A system as recited in
29. A system as recited in
30. A system as recited in
31. A system as recited in
32. A system as recited in
33. A system as recited in
34. A system as recited in
35. A system as recited in
36. A system as recited in
37. A system as recited in
38. A system as recited in
39. A system as recited in
40. A system as recited in
41. A system as recited in
42. A method implemented in a computing device comprising:
receiving a request to retrieve, from an annotation store, one or more annotation objects; and
implementing one or more of a plurality of handlers as needed to respond to the request, the plurality of handlers including an extended property handler, extended object handler, and an extended storage handler, wherein the extended property handler is configured to create new property types identified by a client application to the one or more annotation objects so that annotation objects can have a property value associated with each of the created new property types, wherein the one or more additional new property types are in addition to the existing property types in the client application.
43. A method as recited in
44. A method as recited in
45. A method as recited in
This invention relates to annotating content, and particularly to a Common Annotation Framework.
A wide variety of content is currently available in digital form via computers, such as articles, papers, and other publications, images, video, audio, combinations thereof, etc. One problem with such content in digital form, however, is that it is difficult to add annotations or notes to the content. For example, a reader of a traditional paper-copy of an article is able to use a pen or pencil to jot down notes in the margins, underline or circle sections of the article, use a highlighter to highlight portions of the article, and so forth.
Some systems have been devised to allow digital content to be annotated. However, such systems are typically tied to, and are specialized for, one particular application. This results in users being required to learn different annotations systems for different applications, which reduces overall user-friendliness of the annotation systems. Thus, it would be beneficial to provide a system which allows users to annotate different types of content and maintain a more consistent user experience.
A Common Annotation Framework is described herein.
In accordance with one aspect of the framework, an annotation includes a context anchor that identifies both a resource and a position in the resource that the annotation pertains to, and a content anchor that identifies data that is annotating the resource. The annotation can also be extended with client application-defined data in a variety of ways.
The same numbers are used throughout the document to reference like components and/or features.
The Common Annotation Framework described herein provides a basic framework for allowing annotations to be created for a variety of different content types and by a variety of different applications. The framework allows applications to support annotations and further extend the basic framework by adding new properties, objects, methods, etc. as they desire.
Author field 104 contains an identifier of the author of annotation 100, and creation date field 106 contains an indication of the date (and optionally time) of when the annotation was created. The author may be the author's name or some other identifier of the author (e.g., a user id that is used by the user to log into the computer from which the annotation is created).
Content anchor 108 contains a resource 112 and an optional position 113, and context anchor 110 contains a resource 114 and an optional position 116. As used herein, a “resource” refers to anything that can be annotated or that can serve to annotate something else. A resource may refer to something a user wishes to annotate (e.g., an article he or she is reading), or may refer to the content the user intends to use as part of an annotation (e.g., a comment he or she wants to make regarding the article being read). A resource may be any of a wide variety of content (e.g., alphanumeric text, audio, video, graphics, symbols, etc.) and may be only a portion of a larger piece of content (e.g., a block of text from a larger article, one or two frames of a video or audio/video presentation, etc.). Examples of resources include a simple block of ASCII text, a complex word processing document, an audio/video presentation, a web page, an electronic calendar item, digital ink data (e.g., generated based on the ink API (Application Programming Interface) available from Microsoft Corp. of Redmond, Wash.) or other handwriting recognition process data, and so forth.
In annotation 100, the item being annotated is represented by context anchor 110 and the content doing the annotating is represented by content anchor 108. Annotation 100 is a self-contained representation of the annotation, identifying the content doing the annotating as well as the resource being annotated. Annotation 100 thus serves to define the relationship between two or more resources (the content being annotated and the content that is annotating). Furthermore, by being self-contained, an annotation can be stored separate from the content that is being annotated (and also separate from the content doing the annotating), although an annotation may be stored along with such content (e.g., the content being annotated) if desired for convenience (e.g., portability). Additionally, by having the annotation self-contained, it can readily annotate read-only content (such as publicly-available web pages, streaming video, etc).
Each anchor 108, 110 contains information pertaining to a single resource. The anchor 108, 110 can be “by-reference”, in which case the anchor references a resource (e.g., by URL (Uniform Resource Locator) or some other pointer or identifier), or the anchor can be “by-value” and contain a resource literally (e.g., the actual content of the reference).
Context anchor 110 typically includes a position field 116 that contains information about a position in the resource that the anchor 110 pertains to or is associated with. The exact manner in which the position information is included can vary, depending on the client application creating the annotation and the nature of the resource to which the anchor 110 pertains. However, there should typically be sufficient information in the position field to accurately identify (as accurately as the client application desires), where the data doing the annotating is situated. For example, if the resource to which the anchor 110 pertains is text, position field 116 may include a paragraph number for the portion of a text article, a page number and x,y-coordinate location on the page for the resource to which the anchor pertains, etc. Additionally, position field 116 may identify a single location (e.g., a single point on a page) or a range of locations (e.g., a circle or ellipse or other shape, a range of words or symbols, etc.). Position field 116 can also include a codebase identifier so that code can be downloaded by a client application to handle any special processing on the position data itself, for instance in situations where the position data is very complex. Additionally, when a resource is identified “by-reference”, the pointer or identifier of the resource can have position information embedded therein (e.g., a URL may include position information). Position field 113, when included in content anchor 108, contains information about a position in the resource that the anchor 108 pertains to or is associated with, analogous to position field 116.
Each of the resource elements 112 and 114 can include a format attribute and a codebase attribute. The format attribute of a resource element identifies the internal structure of the resource, serving as a type identifier for applications. In effect, an application can ask the resource element what kind of data is stored in the resource before the application attempts to parse the data. If the application recognizes the value of the format attribute, then the application can parse the data. If, however, the application does not recognize the format, the application can use the codebase identifier to go out and download code that does understand the resource data. For example, if the resource element were storing digital ink “by value” (e.g. the data is literally stored within the resource element, and is not stored somewhere else), the format attribute could be a value something like “digital ink”. By way of another example, if the resource element were storing a resource “by reference” rather than “by value”, the resource element's format attribute could be a value something like “text/url” to indicate that the data stored therein is a url that references a resource stored somewhere else. It should be noted that the resource may use some application-defined, or as yet-undefined, addressing scheme, so the format and codebase attributes can be used to allow those addressing schemes to be identified too.
Each of the position fields 113 and 116 can also include a format attribute and a codebase attribute. The format attribute of the position element identifies the internal structure of the position data stored inside the element, and just like with a resource, an application can use the format attribute of the position element to figure out whether the application can understand the position data. For example, if the position data is a literal character offset into a document, such as the integer value 118, then the format attribute of the position element could be a value of something like “characterOffset,” which tells the application to interpret the otherwise inscrutable value 118 as a character offset. If the application does not know what to do with “characterOffset”, it can use the codebase attribute of the position element to download code that does.
Multiple content anchors 108 can be included in annotation 100, each of which contains information pertaining to a different resource. For example, multiple foreign-language translations of a user's comment can be included in an annotation by having a different content anchor 108 for each translation. Additionally, multiple context anchors 110 can also be included in annotation 100, each of which contains information about a different resource and/or different positions within the same resource. For example, a single annotation may be anchored to different locations in the same document, or to different documents, by including a different context anchor 110 for each resource and/or intra-resource position. Thus, each annotation can be associated with multiple resources, including multiple resources being annotated (as identified in context anchors) and multiple resources doing the annotating (as identified by multiple content anchors).
It should be noted that an annotation 100 can itself be a resource, and thus can be identified as the resource of an anchor (context and/or content) of another annotation.
It should also be noted that additional properties can be added to annotation 100 and/or any of the anchors 108, 110 in order to extend or expand the annotation 100 and/or anchors 108, 110. The ability to add such properties is supported by the Common Annotation Framework but the actual properties themselves (e.g., what type of data they store, what they represent, the structure of data within the properties, etc.) are not defined by the Common Annotation Framework. These additional properties may be defined at design time (e.g., a system designer or g programmer implementing the Common Annotation Framework may choose to add one or more such properties), or may be application-defined (e.g., created by client applications when accessing an implemented Common Annotation Framework). These additional properties can be virtually anything the system designer/programmer or client application desires, such as additional types of data, additional methods for operating on the data, etc.
Each additional property also typically includes a codebase that identifies a location where information on how to process the additional property can be obtained. This information may be descriptive in nature (e.g., laying out a set of steps to be performed by a client application in order to process the additional property), or may include code (e.g., software instructions) that can be copied and invoked by the client application to process the additional property.
In certain implementations, multiple annotations 100 may be grouped together into a single set. A particular set can include multiple annotations 100, and optionally may include additional annotation sets. These sets can be defined by client applications, thereby optionally allowing the user of a client application to define sets.
The various layers 132, 136, and 140 may be implemented on the same computing device or alternatively on different computing devices. Similarly, client applications 130 may exist on the same computing device or alternatively multiple different computing devices. A single annotation manager 134 may interact with multiple client applications (which in turn may be situated on the same computing device as the applications or on a different computing device than one or more of the client applications). Alternatively, a different annotation manager 134 may be implemented for each client application 130.
Annotation store 142 of storage layer 140 is associated with annotation manager 134 and includes one or more logical stores (e.g., documents, file caches, SQL databases, etc.), which are implemented to store data on one or more storage devices 138. Storage devices 138 may be situated on the same computing device or alternatively multiple different computing devices. Each storage device 138 may be any of a wide variety of storage devices, and typically is a nonvolatile memory device but may alternatively be a volatile memory device. Examples of such storage devices include magnetic disks, optical disks, Flash memory, and so forth.
By implementing multiple layers as illustrated in
The Common Annotation Framework can be implemented in a variety of different manners. In one implementation, the Common Annotation Framework is implemented as a schema having annotation elements that represent annotations and anchor sub-elements to represent anchors. The annotation element governs the relationship among the anchor sub-elements it contains, and anchor sub-elements hold literal or by-reference resource content (optionally with position data).
Annotation element 160 includes an id field 172 that contains data identifying the annotation element 160 (as discussed above, this may be a globally or locally unique identifier), an author field 174 that contains data identifying the author or creator of annotation element 160, and a create date field 176 that contains data identifying the creation date of the annotation. Annotation element 160 also includes an anchor sub-element 162, and a property sub-element 164.
Each property sub-element 164 includes a name field 178, a format field 180, a property data field 182, and a codebase field 184. Name field 178 contains data identifying the name of the property represented by property sub-element 164, property data field 182 contains the client application-defined data for the property sub-element 164, and format field 180 contains data identifying the format of the data contained in property data field 182. Property sub-elements 164 are extensions to the Common Annotation Framework and can be defined by the client applications that desire the additional properties. The name of the property, as well as the client application-defined data and the format of that data are determined by the client application and thus can be any of a wide variety of values. For example, in one embodiment of the invention, the format field may store an XML Schema “user-defined type” that precisely specifies the nature and structure of the data stored in the property 164 (see XML Schema 1.0, W3C recommendation 2 May 2001, http://www.w3.org/XML/Schema).
Codebase field 184 identifies a location(s) for information or instructions (e.g., a software code module(s)) that, when executed, can interpret the contents of property data field 182 based on format field 180. Codebase field 184 may be, for example, a URL of such a code module(s). During operation, if a client application retrieves an annotation element 160 including a property sub-element 164 having a format (as identified in format field 180) that the application does not understand, the client application can obtain the code module(s) identified in codebase field 184 and execute the obtained code module(s), thereby allowing the data in property data field 182 to be interpreted by the client application. Thus, annotations can be readily extended to include additional property elements; any application that is unable to interpret such additional property elements is able to access instructions (e.g., code modules) that allow it to interpret the additional property elements.
Anchor element 162 includes an id field 186 that contains an identifier that uniquely identifies the anchor locally (e.g., within annotation 160) or globally (e.g., as a GUID). Anchor element 162 also includes an optional property field 164 that contains a property sub-element. Both annotation element 160 and anchor element 162 can contain a property sub-element 164. Thus, annotations can be extended by adding annotation-related properties to the annotation element or anchor-related properties to the anchor element(s).
Anchor element 162 also includes a label sub-element 166, a position sub-element 168, and a resource sub-element 170.
Label sub-element 166 contains a content/context field 188 that contains an identifier of whether the anchor element is a content anchor or a context anchor. For example, in one implementation content/context field 188 may have one of two values, either a value of “content” to identify an anchor as a content anchor or the value of “context” to identify an anchor as a context anchor.
Position sub-element 168 includes a position data field 190, a format field 192, and a codebase field 194. Position data field 190 contains data that identifies a position for the anchor, while format field 192 contains data that identifies the format that the data in position data field 190 is in. Codebase field 194, analogous to codebase field 184 of property sub-element 164, identifies a location(s) for a code module(s) that, when executed, can interpret the contents of position data field 190 based on format field 192. Thus, a client application that retrieves an annotation with an anchor having positioning data that the client application does not know how to interpret, can obtain instructions identifying how to interpret the positioning data.
Resource sub-element 170 includes a content/address data field 196, a format field 198, and a codebase field 200. Content/address data field 196 contains literal resource data (it stores the resource “by value”) or the address (or other identifier) of a resource (it stores the resource “by reference”). Format field 198 contains data that identifies the format that the data in content/address data field 196 is in. Codebase field 200, analogous to codebase field 184 of property sub-element 164, identifies a location(s) for a code module(s) that, when executed, 8 can interpret the data in content/address data field 196 based on format field 198. Thus, a client application that retrieves an annotation with an anchor having resource content/address data (literal or by-reference) that the client application does not know how to interpret, can obtain instructions identifying how to interpret the content data.
In alternate embodiments, the Common Annotation Framework may be designed to include one or more additional elements or fields. These additional elements or fields can be incorporated into the Common Annotation Framework structure by the designer/implementer of the Common Annotation Framework structure, or alternatively by a client application(s). In one implementation, two such additional elements or fields are composite anchors and sets.
A composite anchor allows more structure to be specified in an annotation relationship than is typically available with only the context and content anchors. A composite anchor can be used, for example, to group redundant context anchors (e.g., where each context anchor supports a different method for positioning the annotation in the same resource), or to group multiple content anchors together (e.g., each of which represents a different human language translation of a user's comment).
Order field 222 includes data specifying how the anchor elements stored within a composite anchor (whether they are content anchors, context anchors, composite anchors, or combinations thereof) are to be used. Order field 222 is a sub-element that includes a value field 230 that allows for identification of “all”, “any”, or “sequential”. An indication of “all” in value field 230 indicates that all of the anchors stored in the composite anchor must be used, a value of “any” indicates that the client application can choose any one of the anchors stored in the composite anchor, and a value of “sequential” indicates that the client application must use each anchor stored in the composite anchor in the order they are listed. Alternatively, order field 222 may be any other string value a client application (or Common Annotation Framework designer/implementer) wishes to define.
Role field 228 includes data describing the reason the anchors contained within the composite anchor 220 have been grouped together. Role field 228 is a sub-element that includes a value field 232 that allows for the identification of “span”, “robust”, or “equal”. A value of “span” indicates that multiple anchors are used to define an annotation context which spans multiple elements of a document. A value of “robust” indicates that multiple context anchors are stored for robustness (e.g., each context anchor encodes a different type of information about the same location in a document). A value of “equal” indicates that different versions of the same content are stored in multiple anchors in the same annotation (e.g., multiple versions of the same comment, such as one in plain text, one spoken, one web page, etc.). Alternatively, role field 228 may be any other string value a client application (or Common Annotation Framework designer/implementer) wishes to define.
A set element allows annotations to be grouped together, such as for organization purposes, access control purposes, etc.
Parents field 256 is a sub-element that includes an ID field 264. ID field 264 contains data identifying another set that the current set is part of by the ID of that other set. Children field 258 is a sub-element that includes an ID field 266. ID field 266 contains data identifying either another set or an annotation by the ID of that other set or annotation, the identified other set or annotation being included in the current set.
Property field 262 is a sub-element that allows client applications to extend the functionality of the set by defining their own set properties. Analogous to property sub-element 164 of
The schema defining the Common Annotation Framework can be implemented in any of a variety of manners. Tables I through XIII below illustrate one example. The schema described below with reference to Tables I through XIII (and extensions in Tables XIV and XV) is implemented using XML Schema language Version 1.0, a W3C Recommendation (May 2, 2001). The schema is based on the XML Linking Language (XLink), a W3C Recommendation (the current version is Version 1.0 (Jun. 27, 2001)). Additional information regarding XLink is available from the World Wide Web Consortium (W3C). However, the schema may alternatively be implemented based on other current, proposed, or future versions of XLink, or not based on the XLink recommendation. For example, the schema may be based on other standards or recommendations, or alternatively may be implemented in a proprietary manner (e.g., not based on any public standards or recommendations).
Table I below includes the code defining the Common Annotation Framework name and inheriting the appropriate previously defined and well-known schemas. The ellipses indicate the inclusion of additional elements, identified in Tables II through XIII below.
Table II below includes the code defining an annotation element of the Common Annotation Framework (e.g., element 160 of
Table III below includes the code defining an arc element of an annotation element of Table II. Alternatively, in some embodiments (e.g., those that are not based on Xlink) arc elements may not be used, in which case the code of Table III would not be used.
Table IV below includes the code defining an anchor element of the Common Annotation Framework (e.g., element 162 of
Table V below includes the code defining a property element of the Common Annotation Framework (e.g., element 164 of
Table VI below includes the code defining a date element of the Common Annotation Framework (e.g., element 176 of
Table VII below includes the code defining an author element of the Common Annotation Framework (e.g., element 174 of
Table VIII below includes the code defining a format element of the Common Annotation Framework (e.g., elements 180, 192, or 198 of
Table IX below includes the code defining a codebase element of the Common Annotation Framework (e.g., elements 184, 194, or 200 of
Table X below includes the code defining a name element of the Common Annotation Framework (e.g., element 178 of
Table XI below includes the code defining an ID element of the Common Annotation Framework (e.g., elements 172 or 186 of
Table XII below includes the code defining an anchor id element type that is locally unique within an instance of the annotation element of the Common Annotation Framework.
Table XIII below includes the code defining an annotation id element type that is a globally unique element of the Common Annotation Framework.
Table XIV below includes the code for expanding the schema structure defined in Tables I through XIII above to include a composite element (e.g.,
Table XV below includes the code for expanding the schema structure defined in Tables I through XIII above to include sets (e.g., a set element 250 of
The core schema described above may also be expanded by a client application by adding in one or more ancillary schemas. An ancillary schema identifies a particular data type and also a codebase that identifies how to process the data type. The data type may be a proprietary type, or alternatively may be public-based (e.g., based on XML). In one implementation, if an ancillary schema is based on XML, the format attribute of the element containing the data described by the schema contains the MIME (Multipurpose Internet Mail Extensions) type string “text/xml”, which indicates to client applications that the contents of the element are in the XML format and can be parsed and optionally validated. If the client application understands the data type (e.g., knows how to process the data type) it can do so; otherwise, it can obtain instructions (e.g., software code) from the location identified by the codebase that indicate how the client application is to process the data type (e.g., obtained software code may be executed to process the code).
Object model 300 includes an object manager object 302, an annotation object 304, an OMDocument object 305, a set object 306, a Common Annotation Framework (CAF) event object 308, an anchor object 310, a property object 312, a position object 314, a resource object 316, a content object 318, a resource ID object 320, a codebase object 322, an authority object 324, a date object 326, and an arc object 328. In the illustrated example each of these objects 302-328 is implemented as a component object model (COM) object. Alternatively, other implementations may implement the objects using different standards The operation of these objects is discussed in additional detail below. It is to be appreciated that although only one of each type of object is illustrated in model 300, when implemented numerous objects of the same type (e.g., numerous annotation objects) can, and typically will, be used.
Object manager object 302 provides interfaces to allow client applications to create objects, save objects to the annotation store, remove objects from the annotation store, and retrieve objects from the annotation store. In one implementation, object 302 implements the functionality of annotation manager 134 of
Table XVIII below includes exemplary idl (interface definition language) code that specifies the ICAFExtendedStorageHandler interface exposed by object Go manager object 302. Table XIX below includes exemplary idl code that specifies the ICAFObjectMgr interface exposed by object manager object 302.
The object manager's retrieve( ) method takes two arguments. The first is a string containing the query criteria by which objects are to be retrieved from an annotation store; and the second argument supports returning data directly (when retrieve( ) is called synchronously), or returning a method call ID (when retrieve( ) is called asynchronously). The first string query criteria argument can be expressed in any of a number of standard query languages—including SQL, XPath, XMLQuery, and others—or in an application-defined query language. The particular query language used is determined by what language or languages the calling application can express, and what language or languages the Extended Storage Handler handling the retrieve( ) call can parse.
The object manager's retrieve( ) method returns an OMDocument object 305 (which exposes an ICAFOMDocument interface) for a particular query The OMDocument object 305 is a collection of the objects that are returned by the query. For example, if a client application retrieves a collection of annotations, it will get back an OMDocument 305 full of annotation objects, whereas if it retrieves a collection of annotation sets, it will get an OMDocument 305 containing set objects. This way, the client application can make multiple different queries and get back separate collections which it can manage independently. Table XX below contains an overview of the methods in the ICAFOMDocument interface.
Table XXI below includes exemplary idl code which specifies the ICAFOMDocument interface exposed by OMDocument object 305.
Returning to object manager object 302, the ICAFObjectMgr interface can operate synchronously or asynchronously. When operating synchronously, the calling client application is blocked until execution of the invoked method completes. When a method completes, a status code pertaining to the entire method execution is returned to the caller, along with data resulting from the call (if there is any). The object manager may also optionally issue a DCAFObjectMgrEvents::cmdComplete( ) event (discussed in more detail below). This event is not needed by the calling client application, but may be used by other agents or components listening in on the activity of the object manager.
When operating asynchronously, the invoked methods (e.g., retrieve) do not return data directly, and the order in which methods are called in the interface has no bearing on the order in which they may complete. Data and error state pertaining to the method executed are returned to the calling client application via the DCAFObjectMgrEvents interface, which includes methods for notifying an application of the progress, completion, and error status of outstanding asynchronous calls into the ICAFObjectMgr interface. By implementing DCAFObjectMgrEvents, a client application can receive these notifications, and can receive result data in the form of annotation event objects (which expose the ICAFEventInfo interface). Client applications can match asynchronous call launches to callbacks in the DCAFObjectMgrEvents interface by caching the CallID value returned from each method (when ICAFObjectMgr is in asynchronous mode) and comparing it to the value of ICAFEventInfor::get_CallId( ) on the annotation event object for the callback.
Table XXII below contains an overview of the methods in the DCAFObjectMgrEvents interface exposed by a client application.
CAF event object 308 is used to communicate information about asynchronous calls to the client application via the DCAFObjectMgrEvents interface of the client application. During an asynchronous call execution, when one of the DCAFObjectMgrEvents interface methods is called by object manager 302, object manager 302 passes in a CAF event object 308 containing information about which call the event corresponds to and what the status of the call is. The client application receiving the CAF event object 308 can obtain this information through the ICAFEventInfo interface of the event object 308.
Table XXIII below contains an overview of the methods in the ICAFEventInfo interface of CAF event object 308. It should be noted that the arguments property of the ICAFEventInfo interface is optional.
Table XXIV below includes exemplary idl code which specifies the DCAFObjectMgrEvents interface exposed by object manager object 302.
Table XXV below includes exemplary idl code which specifies the ICAFEventInfo interface exposed by CAF event object 308.
Each of the remaining objects 304, 306, and 310-328 each expose one interface which is named to reflect the purpose of the object. The following set of additional interfaces is also exposed by each object 304, 306, and 310-328 (with exceptions for property object 312 discussed below): an IPropertyBag interface, an IPropertyBag2 interface, an IXMLDOMNode interface, and an IPersistXML interface. However, property object 312 does not expose the IPropertyBag or the IPropertyBag2 interface (alternatively, property object 312 could expose these two properties, thereby allowing arbitrary properties to be assigned to arbitrary properties).
The interface of each object that is to be extensible encapsulates access to properties allowing the extensibility. Alternatively, rather than having the properties added directly into the object interfaces to which they apply, a separate interface may be exposed that encapsulates access to properties that are common to each of the extensible objects in the Common Annotation Framework. Table IXXVI below contains an overview of the methods in the ICAFExtensibleObject interface of an object.
The IPropertyBag and IPropertyBag2 interfaces are well-known interfaces that allow a client application to assign, discover, and retrieve arbitrary additional properties on an object. The IXMLDOMNode interface is a well-known interface that includes the methods needed to manipulate an object as part of an XML parse tree. The IPersistXML interface is a well-known interface for persisting XML.
Annotation object 304 allow client applications to access the data representing individual annotations, including both context and content anchors. Annotation object 304 represents annotation element 160 of
Set object 306 exposes the ICAFSet interface and allows access to the properties of an individual set, including access to the list of sets to which the set belongs. Set object 306 represents set element 250 of
Anchor object 310 represents anchor element 162 of
During runtime, an anchor object may also have associated therewith (e.g., via a registry) a set of one or more position input modules and one or more position output modules. The position input modules are configured (e.g., pre-programmed) to be able to translate data from a given application-specific point or range selection (e.g., highlighted text in a text document) into position data and format information for storage in the anchor object. The position output modules are configured (e.g., pre-programmed) to be able to translate position data and format information from an anchor object into a particular application-specific point or range selection (e.g., highlighted text). The exact nature of these position input and output modules will vary, based on the manner in which selections are made, the type of media in which a selection is made (e.g. text, video, images, audio, etc), and the application mediating the selection (e.g. Microsoft®) Word and Microsoft® Internet Explorer represent a text selection in a web page differently), among other factors.
In one implementation where multiple position input modules are associated with an anchor object, each module is queried to determine if it can translate the given selection from the application-specific selection representation to persistable position data. For instance, Microsoft Internet Explorer represents text selections in a web page as objects which implement the IHTMLTxtRange interface. The appropriate position input module is one that can translate the IHTMLTxtRange object to a data representation that can be persisted in the annotation's context anchor, and also sets values for the position's format and codebase fields that can be used later on. So an input module that can perform these steps is chosen from among all the input modules registered.
Similarly, where multiple position output modules are associated with an anchor object, the position format in combination with the codebase and the requested interface are used to determine one of the multiple position output modules to be used to translate the position data and format information back into the appropriate application-specific selection representation.
Position object 314 represents position element 168 of
Resource object 316 represents content element 170 of
The URI (ResourceID) object 320, in conjunction with resource object 316, represents content element 170 of
Content object 318, in conjunction with resource object 316, represents content element 170 of
Codebase object 322 encapsulates properties and methods which apply to a single codebase specification. Codebase object 322 represents a codebase element (e.g., elements 184, 194, or 200 of
Authority object 324 encapsulates information about annotation owners, authors, users, etc. Authority object 324 represents the 174 Author of
Date object 326 encapsulates information about dates. Date object 326 represents a creation date element (e.g., element 176 of
Arc object 328 encapsulates information about how anchors relate to one another. Arc object 328 represents an arc element of annotation element 160 of
Property object 312 represents property element 164 of
In one implementation, one or more of the objects in object model 300 includes a “required” flag or property that, when set, indicates that the object's value must be processed completely or not at all. For example, suppose a client application encounters an anchor (or any other object with the “format” and “codebase” properties) and that the client application does not understand the value of the “format” property. The client application therefore needs to go to the location identified in the “codebase” property to obtain code to process the object's contents. However, further suppose that the URL specified by the “codebase” property is unavailable (e.g., the client executing the client application is currently offline). If the “required” flag were set, then the flag would indicate to the client application that it is not to process the anchor unless the anchor can be processed completely, so any other portions of the anchor are not to be processed (e.g., displayed to the user). On the other hand, if the “required” flag were not set, then the flag would indicate to the client application that it can partially process the anchor (e.g., display to the user those parts of the anchor that it knows how to process without the code from the “codebase” location).
The object model 300 of
The object model 300 of
The adding of new objects and methods to the object model by a client application is discussed in more detail below with reference to the Common Annotation Framework (CAF) runtime application programming interface (API).
The CAF runtime API provides runtime support for registering, unregistering, and loading handlers for extended properties, objects, and methods. The CAF runtime API can be implemented in a variety of different manners, such as a dynamically linked library (DLL), encapsulated in a Java class, etc.
The CAF runtime API includes methods for registering, unregistering, and loading extended property handlers (EPHs), which operate on properties within objects. An extended property handler has the following form:
The registerHandler( ) method registers an Extended Property Handler (EPH) with the Common Annotation Framework. Its arguments include objectName and objectNamespace, which identify the type and version of the object for which the EPH is registered (that is, the object that will host the property which the EPH is designed to process); propName, the name of the property to be processed by the EPH; commandName and commandNamespace, which identify the name and version of the command (e.g., createObject, retrieve, save, remove, or some application-defined extended method) during which the EPH should be invoked; invokeBefore, which if TRUE tells the EPH to process the property before the command code is executed (for instance, before an annotation object is saved to a store), and after otherwise (for instance, after an annotation object has been retrieved from a store); modulePath, which identifies the specific code module that implements the EPH being registered; and handlerName, which identifies the specific entry point in the EPH module that implements the EPH.
The unregisterHandler( ) method reverses the action of the registerHandler( ) method, and unregisters any EPHs that meet the criteria specified by the input arguments.
The loadHandler( ) method is used by the CAF Object Manager to load the appropriate EPH based on the name and type of object at hand (for instance, for an annotation object defined in the CAF core namespace, objectName would be “annotation”, and objectNamespace would be “aml-core”), and the name and version of the command being invoked (commandName and commandNamespace). The Object Manager is returned an instruction telling it whether to invoke the EPH before or after the command is executed, along with pointers to the module and specific entry point that implement the EPH.
The execPropHandlers( ) method loads and executes all EPHs on a given object's properties before or after a given command. The caller (usually the CAF Object Manager) passes-in a pointer to an object, plus the name and version of the command being invoked, and a flag indicating whether the command has been executed yet or not. The execPropHandlers( ) method queries all the properties on the specified object, then loads and executes all appropriately registered EPHs.
The CAF runtime API also includes methods for registering, unregistering, and loading extended object handlers, which are used to instantiate extended objects. Table LII below illustrates the methods in the CAF runtime API for support of extended object handlers.
The registerCAFObject( ) method registers a new extended object, for instance a new kind of annotation object, with the Common Annotation Framework. It does this by establishing a mapping between the extended object's COM class id, or CLSID, and the object's CAF name and version (objectName and objectNamespace).
The unregisterCAFObject( ) method reverses the effect of registerCAFObject( ), and unregisters the specified extended object from the Common Annotation Framework.
The getCAFObjectCLSID( ) method returns the COM CLSID corresponding to the specified CAF objectName and objectNamespace.
The getCAFObjectProgID( ) method returns the COM “ProgID” string corresponding to the specified CAF objectName and objectNamespace. The COM ProgID string is mapped by COM to the COM CLSID elsewhere, thus the ProgID can be inferred from the objectName and objectNamespace without having to explicitly include it among the input arguments of registerCAFObject( ).
The createCAFObject( ) method returns a new instance of the extended object specified by the objectNamespace and objectName input arguments.
The getCAFClassObject( ) method returns a new instance of the specified extended object's COM “class factory,” which can be used to create new instances of the actual extended object.
The CAF runtime API also includes methods for registering, unregistering, and loading Extended Storage Handlers (ESHs), which are custom code that operate on objects. An extended storage handler is an object which implements an ICAFExtendedStorageHandler interface for a particular object type. Table LIII below illustrates the methods in the CAF runtime API for support of extended storage handlers.
The CAF runtime API also includes methods for registering, unregistering, and loading Invoke methods, which are custom code that operate on objects. Invoke methods differ from extended storage handlers in that Invoke methods typically perform arbitrary processing on core and/or extended objects, while extended storage handlers typically replace basic storage processing on core and/or extended objects. Table LIV below illustrates the methods in the CAF runtime API for support of Invoke methods.
The registerInvokeMethod( ) method registers a new custom method with the Common Annotation Framework. The registration arguments include the name and version of the command (commandName and commandNamespace, where commandName also identifies the logical entry point in the implementation module); a list of the number, names, and types of arguments that the new invoke method takes (“arguments”); and the full path to the module that implements the new invoke method.
The unregisterInvokeMethod( ) method unregisters a specified invoke method.
The loadInvokeMethod( ) method loads the module that implements the specified invoke method, and returns a pointer to the module and the appropriate entry point in the module. The CAF Object Manager uses this method to load the appropriate invoke method when it is invoked by a client application via ICAFObjectMgr::invoke( ).
Computer environment 500 includes a general-purpose computing device in the form of a computer 502. Computer 502 can implement, for example, a client application 130 of
The system bus 508 represents one or more of any of several types 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. By way of 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 502 typically includes a variety of computer readable media. Such media can be any available media that is accessible by computer 502 and includes both volatile and non-volatile media, removable and non-removable media.
The system memory 506 includes computer readable media in the form of volatile memory, such as random access memory (RAM) 510, and/or non-volatile memory, such as read only memory (ROM) 512. A basic input/output system (BIOS) 514, containing the basic routines that help to transfer information between elements within computer 502, such as during start-up, is stored in ROM 512. RAM 510 typically contains data and/or program modules that are immediately accessible to and/or presently operated on by the processing unit 504.
Computer 502 may also include other removable/non-removable, volatile/non-volatile computer storage media. By way of example,
The disk drives and their associated computer-readable media provide non-volatile storage of computer readable instructions, data structures, program modules, and other data for computer 502. Although the example illustrates a hard disk 516, a removable magnetic disk 520, and a removable optical disk 524, it is to be appreciated that other types of computer readable media which can store data that is accessible by a computer, such as magnetic cassettes or other magnetic storage devices, flash memory cards, CD-ROM, digital versatile disks (DVD) or other optical storage, random access memories (RAM), read only memories (ROM), electrically erasable programmable read-only memory (EEPROM), and the like, can also be utilized to implement the exemplary computing system and environment.
Any number of program modules can be stored on the hard disk 516, magnetic disk 520, optical disk 524, ROM 512, and/or RAM 510, including by way of example, an operating system 526, one or more application programs 528, other program modules 530, and program data 532. Each of such operating system 526, one or more application programs 528, other program modules 530, and program data 532 (or some combination thereof) may implement all or part of the resident components that support the distributed file system.
A user can enter commands and information into computer 502 via input devices such as a keyboard 534 and a pointing device 536 (e.g., a “mouse”). Other input devices 538 (not shown specifically) may include a microphone, joystick, game pad, satellite dish, serial port, scanner, and/or the like. These and other input devices are connected to the processing unit 504 via input/output interfaces 540 that are coupled to the system bus 508, but may be connected by other interface and bus structures, such as a parallel port, game port, or a universal serial bus (USB).
A monitor 542 or other type of display device can also be connected to the system bus 508 via an interface, such as a video adapter 544. In addition to the monitor 542, other output peripheral devices can include components such as speakers (not shown) and a printer 546 which can be connected to computer 502 via the input/output interfaces 540.
Computer 502 can operate in a networked environment using logical connections to one or more remote computers, such as a remote computing device 548. By way of example, the remote computing device 548 can be a personal computer, portable computer, a server, a router, a network computer, a peer device or other common network node, and the like. The remote computing device 548 is illustrated as a portable computer that can include many or all of the elements and features described herein relative to computer 502.
Logical connections between computer 502 and the remote computer 548 are depicted as a local area network (LAN) 550 and a general wide area network (WAN) 552. Such networking environments are commonplace in offices, enterprise-wide computer networks, intranets, and the Internet.
When implemented in a LAN networking environment, the computer 502 is connected to a local network 550 via a network interface or adapter 554. When implemented in a WAN networking environment, the computer 502 typically includes a modem 556 or other means for establishing communications over the wide network 552. The modem 556, which can be internal or external to computer 502, can be connected to the system bus 508 via the input/output interfaces 540 or other appropriate mechanisms. It is to be appreciated that the illustrated network connections are exemplary and that other means of establishing communication link(s) between the computers 502 and 548 can be employed.
In a networked environment, such as that illustrated with computing environment 500, program modules depicted relative to the computer 502, or portions thereof, may be stored in a remote memory storage device. By way of example, remote application programs 558 reside on a memory device of remote computer 548. For purposes of illustration, application programs and other executable program components such as the operating system are illustrated herein as discrete blocks, although it is recognized that such programs and components reside at various times in different storage components of the computing device 502, and are executed by the data processor(s) of the computer.
Various modules and techniques may be described herein in the general context of computer-executable instructions, such as program modules, executed by one or more computers or other devices. Generally, program modules include routines, programs, objects, components, data structures, etc. that perform particular tasks or implement particular abstract data types. Typically, the functionality of the program modules may be combined or distributed as desired in various embodiments.
An implementation of these modules and techniques may be stored on or transmitted across some form of computer readable media. Computer readable media can be any available media that can be accessed by a computer. By way of example, and not limitation, computer readable media may comprise “computer storage media” and “communications media.”
“Computer storage media” includes volatile and non-volatile, removable and non-removable media implemented in any method or technology for storage of information such as computer readable instructions, data structures, program modules, or other data. Computer storage media includes, but is not limited to, RAM, ROM, EEPROM, flash memory or other memory technology, CD-ROM, digital versatile disks (DVD) or other optical storage, magnetic cassettes, magnetic tape, magnetic disk storage or other magnetic storage devices, or any other medium which can be used to store the desired information and which can be accessed by a computer.
“Communication media” typically embodies computer readable instructions, data structures, program modules, or other data in a modulated data signal, such as carrier wave or other transport mechanism. Communication media also includes any information delivery media. The term “modulated data signal” means a signal that has one or more of its characteristics set or changed in such a manner as to encode information in the signal. By way of example, and not limitation, communication media includes wired media such as a wired network or direct-wired connection, and wireless media such as acoustic, RF, infrared, and other wireless media. Combinations of any of the above are also included within the scope of computer readable media.
Although the description above uses language that is specific to structural features and/or methodological acts, it is to be understood that the invention defined in the appended claims is not limited to the specific features or acts described. Rather, the specific features and acts are disclosed as exemplary forms of implementing the invention.