A portion of the disclosure of this patent document contains material which is subject to copyright protection. The copyright owner has no objection to the facsimile reproduction by anyone of the patent document or the patent disclosure, as it appears in the Patent and Trademark Office patent file or records, but otherwise reserves all copyright rights whatsoever.
The ability to efficiently work with bibliographic information in conjunction with text-based applications is becoming increasingly important. This is particularly true as the number of sources cited within a given document increases and as the number of different types of available sources grows. Examples of text-based applications, which may be used to produce documents having citations, include word processors, hypertext markup language (html) editors, and so forth.
Extensible markup language schemas for bibliographies and citations facilitate utilization of bibliographic information. For example, a schema utilization module may enable the creation, modification, interpretation, etc. of a schema for bibliographic information. A schema utilization module may be an independent program, part of an application program, and so forth. A schema for bibliographic information defines a framework for bibliographic information. The bibliographic information may be embedded in a document, may be embodied as a master list, and so forth. In a described implementation, the schema for bibliographic information is realized using an open-standard such as extensible markup language (XML). The schema enumerates multiple source types and the data types associated therewith. In another described implementation, employing a schema utilization module in conjunction with a schema for bibliographic information enables bibliographic source information to be created, to be inserted into a document as a citation, to be added to a master list, to be reused later, and so forth.
This Summary is provided to introduce a selection of concepts in a simplified form that are further described below in the Detailed Description. This Summary is not intended to identify key features or essential features of the claimed subject matter, nor is it intended to be used as an aid in determining the scope of the claimed subject matter. Moreover, other method, system, approach, apparatus, device, media, procedure, schema, application programming interface (API), arrangement, etc. implementations are described herein.
The same numbers are used throughout the drawings to reference like and/or corresponding aspects, features, and components.
With certain implementations that are described herein, bibliographic information may be input once, edited at will, and retrieved for reuse across different documents using open-standard technology, for example. Moreover, creating the bibliographic information in accordance with a schema can enable utilization of the bibliographic information in different environments. In a specific example implementation, extensible markup language schemas for bibliographies and citations are described herein.
Extensible markup language (XML) is a universal language that provides a way to identify, exchange, and process various kinds of data. For example, XML may be used to create documents that can be utilized by a variety of different application programs. Elements of an XML file typically have an associated namespace and schema. A namespace is a unique identifier for a collection of names that are used in XML documents to define element/attribute names and types. The name of a namespace is commonly used to uniquely identify each class of XML document. XML schemata (schema) provide a way to describe and validate data in an XML context. A schema indicates, for example, what elements and attributes are used to describe content in an XML document, where each element is allowed, what types of content are allowed within it, and/or which elements can appear within which other elements. The use of schemas can ensure that documents are structured in a consistent and predictable manner, which facilitates a standard document construction and enables subsequent interpretation of individual documents.
This description is separated into seven additional sections. The third, fifth, sixth, and seventh sections are particularly pertinent to this continuation-in-part patent application. A first section is related to
Word processing documents, for example, can include embedded fields. Fields represent a portion of a document that is visibly represented by presentation data based on a field type and at least one field parameter. The presentation data can therefore change in response to changes in the value(s) of the at least one field parameter. There can be different types of fields for different purposes. Examples include a number of pages of a document, a name of the file of the document, the current date/time, a number for a (e.g., paragraph, outline, page, etc.) numbering feature, and so forth.
When the presentation of a word processing document is updated, the presentation data is likewise updated based on the at least one parameter. For example, if there is a field for a number of pages of a document, each time the document is updated for printing, the current number of pages of the document is inserted as the presentation data at the location of the embedded field.
With existing fields, the at least one field parameter pertains to intrinsically known or determinable information. For instance, the date and/or time are intrinsically known by a computing system. Also, the file name and the internal numbering operations are intrinsically determinable from the document itself Consequently, existing embedded field technology is limited and inflexible.
Thus, as described above, conventional embedded field technology is limited to field parameters that are determinable based on predetermined, intrinsic information. On the other hand, schemes, mechanisms, techniques, etc. that are described herein below are directed to determining fields for presentable files in a flexible and/or extensible manner.
In an example described implementation, a field can be a transform reference field type. A transformed reference field type indicates that referenced raw data is to be transformed, and the transformed raw data is then presented as the presentation data result of the field. A set of presentation rules may be selected from a transformation engine so that the referenced raw data is presented in a desired manner.
The transformation engine is independent of the application presenting the field, and the application is unaware of the specifics of the internal mechanics (e.g., the presentation rules) of the transformation engine. Moreover, a user can independently create or modify a transformation engine without utilizing the application, relying on the application, or even understanding details on how the application is to apply the transformation engine, as long as the created transformation engine adheres to or comports with a schema as promulgated for transformation engines generally. For example, using non-proprietary, open standards such as XML and XSLT enables a user to create, edit, etc. the raw data and the transformation engine, respectively, without involving the application.
Fields of a transform reference field type may be employed in a myriad of contexts. In an example context, a bibliographic feature employs transform reference field type schemes, mechanisms, techniques, etc. Raw data contains one or more bibliographic sources, and the transformation engine includes at least one set of presentation rules. Each presentation rule can implement a documented approach for citing bibliographic sources. Additionally, bibliographies and citations can be quickly repurposed by changing the selected set of presentation rules. This can cause the presentation of each cited bibliographic source to be changed accordingly.
A data stream construction 110 for field 108 is illustrated. Data stream construction 110 may be represented as {(Field Type) (Field Parameter(s)) | [Result]}. The “Field Type” indicates a field type of many possible field types to which a given field 108 belongs. The “Field Parameter(s)” recite at least one field parameter that serves as an argument for the Field Type. The “Result” symbolizes the result of a function characterized by a Field Type and Field Parameter(s) pair.
By way of example only, the field type may be a paragraph reference number with the field parameter being a pointer to the referenced paragraph having a number. The result is therefore the current paragraph number of the referenced paragraph. For certain field types, the field parameter may be empty or omitted when the field type alone provides information that is sufficient to determine the result.
A logical construction 112 for field 108 is illustrated as a block diagram. Field 108 includes function information 114 and result 120. Function information 114 includes the pair of field type 116 and one or more parameters 118. When the function characterized by field type 116 and parameters 118 is evaluated or otherwise determined, result 120 is produced. When presented file 102 is updated, result 120 is presented as presentation data 106 as part of data stream presentation 104.
Presentable file 202 is the origin or underlying information for presented file 102 (of
As illustrated, presentable file 202 includes data stream information 210 and additional information 212. Data stream presentation 104 is produced primarily from data stream information 210. Additional information 212, if present, contains additional information that is usable for manipulating, presenting, or otherwise utilizing data stream information 210 and/or the overall presentable file 202. For example, additional information 212 may include properties information, a change history, etc. for presentable file 202. Moreover, additional information 212 can contain all or a portion of raw data 204 and/or transformation engine 206 to enhance the portability of presentable file 202, as is described further herein below with particular reference to
Raw data 204 and transformation engine 206 are also illustrated in
Application 208, in a described implementation, includes field interpreter 214, raw data extractor 216, and raw data transformer 218. Field interpreter 214 is capable of interpreting field 108, especially function information 114. Raw data extractor 216 is capable of extracting raw data from raw data 204 in accordance with a parameter 118 that contains a reference to raw data 204. Raw data transformer 218 is capable of transforming the extracted raw data in accordance with one or more presentation rules of transformation engine 206 without being in direct control of the transformation.
Raw data transformer 218 is capable of applying transformation engine 206 to the extracted data of raw data 204 without being aware of the internal mechanics (including the specifics of any included presentation rules) of transformation engine 206. Hence, result 120 of field 108 can be independent of application 208. A schema 220 is known to application 208, and application 208 is adapted to interoperate with transformation engines 206 that adhere to/comport with schema 220. Schema 220 specifies one or more formats for transformation engine 206. Consequently, as long as transformation engine 206 adheres to/comports with schema 220, raw data transformer 218 is capable of applying transformation engine 206 to raw data 204 without being aware of the internal mechanics thereof. It should be understood that application 208 may also be capable of independently interpreting other (e.g., traditional) fields 108 without relying on raw data 204 or a transformation engine 206.
As illustrated in the example block diagram of
In fact, in a described implementation, at least a portion of raw data 204 is stored as part of additional information 212, and at least a portion of transformation engine 206 may be utilized by application 208 when transforming referenced raw data 204 to produce result 120. With such an implementation, at least the relevant (e.g., referenced) raw data of raw data 204 is transportable as part of presentable file 202. Consequently, a presentable file 202 may be e.g. emailed to a recipient with the relevant raw data being included as part of presentable file 202. Similarly, if the recipient has an application 208 that is expected to access and properly present presentable file 202, the inclusion of at least a portion of transformation engine 206 as a part of additional information 212 ensures that presentable file 202 can be presented in a manner intended by its creator.
At block 302, data stream information of a presentable file is processed until an embedded field is encountered. For example, data stream information 210 of presentable file 202 may be processed into data stream presentation 104 of presented file 102 until a field 108 is encountered.
At block 304, the field is interpreted. For example, field interpreter 214 of application 208 may interpret field 108. More specifically, at block 304(1), a field type is ascertained. For instance, field interpreter 214 may ascertain field type 116 of function information 114. At block 304(2), one or more parameters 118 are acquired. For instance, field interpreter 214 may acquire parameter(s) 118 of function information 114.
In a described implementation, field type 116 comprises a transform reference field type 116. This indicates to field interpreter 214 that a reference points to raw data, which is to be transformed prior to presentation. Thus, at least one parameter 118 comprises a reference to raw data 204. Another parameter 118 may identify all or part of transformation engine 206. Alternatively, a transformation engine 206 that is to be employed for a presentable file 202 may be identified (and optionally contained) in the additional information 212. As another example, transformation engine 206 may be identified by a global setting that is set by or through application 208.
At block 306, raw data for the field is extracted. For example, raw data extractor 216 of application 208 may extract raw data for field 108 from raw data 204. More specifically, at block 306(1), raw data is located responsive to acquired parameter(s). For instance, raw data extractor 216 may locate raw data 204, and/or a portion thereof, responsive to at least one parameter 118 that includes a reference to the raw data. At block 306(2), the located raw data is retrieved. For instance, raw data extractor 216 may retrieve the located raw data from raw data 204.
At block 308, the extracted raw data is transformed. For example, raw data transformer 218 of application 208 may cause the extracted raw data of raw data 204 to be transformed responsive to the separate transformation engine 206. More specifically, at block 308(1), the relevant transformation engine 206 is identified. For instance, raw data transformer 218 may identify the relevant transformation engine 206, and/or the relevant presentation rules thereof, using at least one parameter 118, using a transform identification (e.g., a transformation engine identifier) in additional information 212, using a global setting of application 208, and so forth. At block 308(2), the identified transformation engine is applied to the retrieved raw data. For instance, raw data transformer 218 may apply the identified transformation engine 206, including a set of presentation rules thereof, to the retrieved raw data of raw data 204 to produce result 120. Raw data transformer 218 can cause transformation engine 206 to perform this transformation without knowing any specifics about the contents of transformation engine 206.
At block 310, the transformed raw data, or field result, is presented as part of the data stream presentation of the presented file. For example, application 208 may present result 120, which comprises the transformed raw data, as presentation data 106 for field 108 as part of presented file 102. The actions of flow diagram 300 may be performed in orders that vary from those that are illustrated. For example, the transforming of block 308 may be performed prior to or completely or partially overlapping with the extracting of block 306. Thus, in an example implementation, only those portions of the raw data that are to remain after any filtering need be fully extracted.
Field interpreter 214 ascertains that field type 116 is a transform reference field type 402 as indicated by arrow 408. As such, field 108 is determined based on raw data reference 404 and responsive to (i) raw data 204 (of
Field interpreter 214 provides raw data reference 404 to raw data extractor 216 as indicated by arrow 410. Field interpreter 214 also provides transform identification 406 to raw data transformer 218 as indicated by arrow 412. Three example locations at which transform identification 406 may be found are illustrated. These examples include parameter(s) 118, additional information 212, and application 208. However, transform identification 406 may alternatively be located within or in association with other component(s). Also, raw data transformer 218 may alternatively be capable of independently acquiring transform identification 406 from any location.
Data items 502 include one or more respective tag fields 504 and associated respective data 506, which are referred to herein as tag-data couplets. As illustrated, data item #k 502(k) includes “n” respective tag fields 504 that are associated with “n” respective data entries 506. In other words, tag field #1 is associated with data entry #1, tag field #2 is associated with data entry #2, tag field #3 is associated with data entry #3, and tag field #n is associated with data entry #n. The manner in which tag fields 504 are utilized by raw data transformer 218 is described further herein below with particular reference to
As illustrated, raw data reference 404 references data item #k 502(k). Raw data reference 404 can comprise a link, a pointer, an address, a universal resource locator, a uniform resource locator, some combination thereof, and so forth. Raw data extractor 216 uses raw data reference 404 to locate and then retrieve data item #k 502(k) as indicated by arrow portion 508. Data item #k 502(k), or at least a portion thereof, is then provided to raw data transformer 218 as indicated by arrow portion 510.
Filter, order, and/or format capability 602 is adapted so as to filter, order, and/or format data item #k 502(k) with respect to tag fields 504, in accordance with a selected set of presentation rules, and responsive to a data item type of data item #k 502(k). In this example case, the selected set of presentation rules pertaining to data item type “Θ” is applied to data item #k 502(k) because it is of data item type “Θ”.
Generally, presentation rules can stipulate which tag fields 504 are filtered out, how the remaining tag fields 504 are ordered, and how the surviving data entries 506 are formatted. Specifically, tag-data couplets (e.g., respective tag fields 504 that are associated with respective data entries 506) may be filtered, ordered, and/or formatted. More specifically, one or more individual tag-data couplets may be filtered out (e.g., removed and/or excluded from presentation). Also, tag-data couplets may be reordered into a prescribed order. Furthermore, tag-data couplets may be formatted such that the presented text is centered, bolded, italicized, underlined, spaced appropriately, capitalized, punctuated, some combination thereof, and so forth.
Thus, filter, order, and/or format capability 602 of transformation engine 206 produces result 120, which is presented as presentation data 106. As illustrated in
The data entries 506 may also be formatted individually or as a group to produce the final appearance for presentation data 106. Although result 120 is shown as including tag fields 504 in addition to data entries 506, result 120 may alternatively be streamlined by omitting tag fields 504 such that result 120 is effectively equivalent to presentation data 106. Consequently, result 120 may be presented as presentation data 106 without first stripping out tag fields 504.
With reference to the set of presentation rules A 702(A), there is a different subset 704 of presentation rules for each data item type of multiple data item types. As illustrated, presentation rules A 702(A) includes rule subsets 704 that target data items of type Δ, type Σ, type Θ . . . type Ω. The presentation rule subsets 704 for each data item type may include their own set of filter, order, and/or format capability 602. Consequently, data entries 506 that are associated with the same kind of tag field 504 may be filtered, ordered, and/or formatted differently if they are part of data items 502 that correspond to different data item types. This is further explained by way of example in the following section with the bibliographic-related examples.
Transform identification 406 (of
Although both sets of presentation rules A and B 702(A and B) as illustrated in the transformation engine 206 of
An example application for determining fields, in accordance with certain implementations as described herein above, is in a bibliographic context. Bibliographic data for cited sources may be entered once, and the bibliographic data may subsequently be used for footnotes, endnotes, and so forth. A user can retrieve bibliographic data for a citation or bibliography entry to a given source whenever that source data has been entered.
Moreover, cited sources within a presentable file 202 are included within data stream information 210 as fields 108 having a field type 116 of transform reference 402. Accordingly, bibliographic data may be extracted from raw data 204. Additionally, the raw bibliographic data 204 may be transformed in accordance with an established presentation rule 702. The presented file 102 may then be re-purposed merely be selecting a different presentation rule 702. In other words, the user can insert a citation or bibliographic entry, pulling raw data (the source data) and transforming it according to a documentation style such as MLA or APA. After a citation or bibliographic entry is inserted, it can be repurposed by selecting a different documentation style (transform).
Transformation engine 206 (e.g., as an XSLT or other non-proprietary file) is installed and/or called by application 208. However, application 208 need not be used to create or modify a transformation engine 206. Instead, a user may utilize any program that is capable of generating a file that adheres to or comports with the schema 220 that specifies available format(s) for transformation engine 206. Hence, a transformation engine 206 that is generated by an unknown file can be installed and/or called by application 208 to determine fields in presentable files. For example, a word processing program realization of application 208 may install or call any transformation engine 206 that comports with the specified schema 220, regardless of how the transformation engine 206 was created.
In a described implementation, raw data 204 may comprise a master bibliographic data file and/or a portion of additional information 212 of presentable file 202. For example, a user may enter bibliographic data directly into a master file and have cited portions thereof copied into additional information 212. Alternatively, a user may enter bibliographic data directly into additional information 212 (e.g., via an application 208) and have the bibliographic data of the newly-entered citations copied into the master file for subsequent use. As noted above, inclusion of bibliographic data in additional information 212 is an optional implementation.
Raw data 204 includes at least one data item 502. As illustrated in
Data item #k 502(k) typically includes multiple entries. Specifically, there are respective data entries 506 that are associated with respective tag fields 504. Tag field #n 504 is shown in this example as a title for the book that is the source for this data item 502. Consequently, the associated data entry #n 506 comprises the actual title of source #k. Although only one tag-data couplet is shown in
In a bibliographic-related implementation, transformation engine 206 comprises one or more bibliographic formatting standards. Thus, each presentation rule 702 may be realized as an individual bibliographic formatting standard. As illustrated, presentation rules A 702(A) is realized as a set of rules that transforms raw bibliographic data into bibliographic data that comports with the American Psychological Association (APA) rules of documentation style. Other example bibliographic-related realizations for presentation rules 702 include, but are not limited to the following bibliographic standards: Modern Language Association (MLA), Chicago Manual of Style, Turabian, Author-Date, and so forth.
In such a bibliographic-related implementation, transformation engine 206 can therefore be an XSLT for MLA, APA, etc. that is installed or called by a word processing application. Other XSLTs for other bibliographic documentation styles can be created by users and then installed or called by the word processing application. Such other transformation engine 206 realizations operate in conjunction with the word processing application as long as they are created so as to adhere to the specified schema 220. The word processing application need not understand the internal mechanics of a transformation engine, and the user need not create or modify the transformation engine with the word processing application.
Because presentation rules 702 tend to differ by source type, each source type has a corresponding item type presentation rule subset 704. Consequently, book citations may be formatted differently from periodical citations. As illustrated, item type Δ 704 is realized as a presentation rules subset 704 of APA that is targeted to transforming raw data for books into book citations that comport with the APA, and item type Σ is realized as a presentation rules subset 704 of APA that is targeted to transforming raw data for periodicals into periodical citations that comport with the APA.
In operation, parameters in a presentation rules subset 704 stipulate which tag fields 504 are to be present in result 120 as well as their order. They may also stipulate the appropriate formatting, including capitalization and punctuation. More specifically, the parameters stipulate which ones of data entries 506 are to be presented as presentation data 106 of presented file 102.
In a described implementation, a transformation engine is created in accordance with a selected open standard (e.g., XSTL) so as to adhere to a given schema. The given schema is associated with a given application. The given schema specifies a format for transformation engines with which the given application is capable of interoperating.
Thus, the given application is adapted to apply the transformation engine to fields of a presentable file (e.g., by installing and/or calling the transformation engine). The fields may be determined by the given application based on a field type and at least one parameter of the field, as well as responsive to raw data and the transformation engine. This determination may be effectuated by the application even if the application is unaware of the internal mechanics of the transformation engine.
The transformation engine may be created, modified, etc. by a user without utilizing the given application. The creation and/or modification is performed such that the resulting transformation engine comports with the given schema. The user may utilize any program that is capable of manipulating files for transformation engines.
By way of example only, the fields being determined can be bibliographic-related entries for a word processing document. The raw data, which may be formatted in accordance with an open standard such as XML, may include bibliographic-related data. The transformation engine may comprise one or more bibliographic citation styles, such as APA and MLA. A user may create his or her own bibliographic citation style or modify a documented one without utilizing the word processing application. Regardless, the word processing application may determine bibliographic-related fields of the word processing document by applying a transformation engine comprising at least one bibliographic citation style without the word processing application having to understand details of the internal mechanics of the transformation engine.
Example operating environment 900 is only one example of an environment and is not intended to suggest any limitation as to the scope of use or functionality of the applicable device (including computer, network node, entertainment device, mobile appliance, general electronic device, etc.) architectures. Neither should operating environment 900 (or the devices thereof) be interpreted as having any dependency or requirement relating to any one or to any combination of components as illustrated in
Additionally, implementations for extensible markup language schemas for bibliographies and citations may be realized with numerous other general purpose or special purpose device (including computing system) environments or configurations. Examples of well known devices, systems, environments, and/or configurations that may be suitable for use include, but are not limited to, personal computers, server computers, thin clients, thick clients, personal digital assistants (PDAs) or mobile telephones, watches, hand-held or laptop devices, multiprocessor systems, microprocessor-based systems, set-top boxes, programmable consumer electronics, video game machines, game consoles, portable or handheld gaming units, network PCs, videoconferencing equipment, minicomputers, mainframe computers, network nodes, distributed or multi-processing computing environments that include any of the above systems or devices, some combination thereof, and so forth.
Implementations for extensible markup language schemas for bibliographies and citations may be described in the general context of processor-executable instructions. Generally, processor-executable instructions include routines, programs, protocols, objects, functions, interfaces, components, schemas, data structures, etc. that perform and/or enable particular tasks and/or implement particular abstract data types. Realizations of extensible markup language schemas for bibliographies and citations, as described in certain implementations herein, may also be practiced in distributed processing environments where tasks are performed by remotely-linked processing devices that are connected through a communications link and/or network. Especially but not exclusively in a distributed computing environment, processor-executable instructions may be located in separate storage media, executed by different processors, and/or propagated over transmission media.
Example operating environment 900 includes a general-purpose computing device in the form of a computer 902, which may comprise any (e.g., electronic) device with computing/processing capabilities. The components of computer 902 may include, but are not limited to, one or more processors or processing units 904, a system memory 906, and a system bus 908 that couples various system components including processor 904 to system memory 906.
Processors 904 are not limited by the materials from which they are formed or the processing mechanisms employed therein. For example, processors 904 may be comprised of semiconductor(s) and/or transistors (e.g., electronic integrated circuits (ICs)). In such a context, processor-executable instructions may be electronically-executable instructions. Alternatively, the mechanisms of or for processors 904, and thus of or for computer 902, may include, but are not limited to, quantum computing, optical computing, mechanical computing (e.g., using nanotechnology), and so forth.
System bus 908 represents one or more of any of many types of wired or wireless bus structures, including a memory bus or memory controller, a point-to-point connection, a switching fabric, 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 may 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, a Peripheral Component Interconnects (PCI) bus also known as a Mezzanine bus, some combination thereof, and so forth.
Computer 902 typically includes a variety of processor-accessible media. Such media may be any available media that is accessible by computer 902 or another (e.g., electronic) device, and it includes both volatile and non-volatile media, removable and non-removable media, and storage and transmission media.
System memory 906 includes processor-accessible storage media in the form of volatile memory, such as random access memory (RAM) 910, and/or non-volatile memory, such as read only memory (ROM) 912. A basic input/output system (BIOS) 914, containing the basic routines that help to transfer information between elements within computer 902, such as during start-up, is typically stored in ROM 912. RAM 910 typically contains data and/or program modules/instructions that are immediately accessible to and/or being presently operated on by processing unit 904.
Computer 902 may also include other removable/non-removable and/or volatile/non-volatile storage media. By way of example,
The disk drives and their associated processor-accessible media provide non-volatile storage of processor-executable instructions, such as data structures, program modules, and other data for computer 902. Although example computer 902 illustrates a hard disk 916, a removable magnetic disk 920, and a removable optical disk 924, it is to be appreciated that other types of processor-accessible media may store instructions that are accessible by a device, such as magnetic cassettes or other magnetic storage devices, flash memory, compact disks (CDs), digital versatile disks (DVDs) or other optical storage, RAM, ROM, electrically-erasable programmable read-only memories (EEPROM), and so forth. Such media may also include so-called special purpose or hard-wired IC chips. In other words, any processor-accessible media may be utilized to realize the storage media of the example operating environment 900.
Any number of program modules (or other units or sets of processor-executable instructions) may be stored on hard disk 916, magnetic disk 920, optical disk 924, ROM 912, and/or RAM 910, including by way of general example, an operating system 928, one or more application programs 930, other program modules 932, and program data 934. These processor-executable instructions may include, for example, a schema, the accessing of a schema, the modifying of a schema, the use of a schema to interpret and/or create a data structure, and so forth.
A user may enter commands and/or information into computer 902 via input devices such as a keyboard 936 and a pointing device 938 (e.g., a “mouse”). Other input devices 940 (not shown specifically) may include a microphone, joystick, game pad, satellite dish, serial port, video camera, scanner, and/or the like. These and other input devices are connected to processing unit 904 via input/output interfaces 942 that are coupled to system bus 908. However, input devices and/or output devices may instead be connected by other interface and bus structures, such as a parallel port, a game port, a universal serial bus (USB) port, an infrared port, an IEEE 1394 (“Firewire”) interface, an IEEE 802.11 wireless interface, a Bluetooth® wireless interface, and so forth.
A monitor/view screen 944 or other type of display device may also be connected to system bus 908 via an interface, such as a video adapter 946. Video adapter 946 (or another component) may be or may include a graphics card for processing graphics-intensive calculations and for handling demanding display requirements. Typically, a graphics card includes a graphics processing unit (GPU), video RAM (VRAM), etc. to facilitate the expeditious display of graphics and performance of graphics operations. In addition to monitor 944, other output peripheral devices may include components such as speakers (not shown) and a printer 948, which may be connected to computer 902 via input/output interfaces 942.
Computer 902 may operate in a networked environment using logical connections to one or more remote computers, such as a remote computing device 950. By way of example, remote computing device 950 may be a peripheral device, a personal computer, a portable computer (e.g., laptop computer, tablet computer, PDA, mobile station, etc.), a palm or pocket-sized computer, a watch, a gaming device, a server, a router, a network computer, a peer device, another network node, or another device type as listed above, and so forth. However, remote computing device 950 is illustrated as a portable computer that may include many or all of the elements and features described herein with respect to computer 902.
Logical connections between computer 902 and remote computer 950 are depicted as a local area network (LAN) 952 and a general wide area network (WAN) 954. Such networking environments are commonplace in offices, enterprise-wide computer networks, intranets, the Internet, fixed and mobile telephone networks, ad-hoc and infrastructure wireless networks, mesh networks, other wireless networks, gaming networks, some combination thereof, and so forth. Such networks and logical and physical communications connections are additional examples of transmission media.
When implemented in a LAN networking environment, computer 902 is usually connected to LAN 952 via a network interface or adapter 956. When implemented in a WAN networking environment, computer 902 typically includes a modem 958 or other component for establishing communications over WAN 954. Modem 958, which may be internal or external to computer 902, may be connected to system bus 908 via input/output interfaces 942 or any other appropriate mechanism(s). It is to be appreciated that the illustrated network connections are examples and that other manners for establishing communication link(s) between computers 902 and 950 may be employed.
In a networked environment, such as that illustrated with operating environment 900, program modules or other instructions that are depicted relative to computer 902, or portions thereof, may be fully or partially stored in a remote media storage device. By way of example, remote application programs 960 reside on a memory component of remote computer 950 but may be usable or otherwise accessible via computer 902. Also, for purposes of illustration, application programs 930 and other processor-executable instructions such as operating system 928 are illustrated herein as discrete blocks, but it is recognized that such programs, components, and other instructions reside at various times in different storage components of computing device 902 (and/or remote computing device 950) and are executed by processor(s) 904 of computer 902 (and/or those of remote computing device 950).
Example implementations described herein relate generally to extensible markup language (XML) schemas for bibliographies and/or citations. For example, certain implementations may be realized as data structure(s) comprising a schema, including portion(s) of an overall schema, for bibliographic information. Other example implementations may be realized as at least one module that is capable of utilizing a schema for bibliographic information. The data structures, modules, etc. may be embodied on or as part of a processor-accessible media.
Application 208 provides access to a document 202*. The access may include creating, presenting, modifying, interpreting, etc. document 202*. Application 208 may be, for example, a text-based application such as a word processor, html editor, and so forth. Document 202* is a specific example of a presentable file 202 (of
Raw data 204 is described generally herein above. Raw data 204 may be document-embedded, may be part of a master list, and so forth. Document-specific raw data 204 may be embedded as part of document 202*. A bibliographic information file that acts as a master list is discussed herein above with particular reference to
Raw data 204 includes bibliographic information 1002. Raw data 204, and thus bibliographic information 1002, may be realized as part of a master list of bibliographic information, as bibliographic information that is embedded in a document (e.g., as shown with respect to document 202*), and so forth. Although not specifically illustrated in
Generally, a raw data 204 master list is a file that includes many bibliographic entries for a user, for an application, for a computing device, some combination thereof, and so forth. Usually, a raw data 204 master list includes bibliographic entries that are used and/or usable across multiple documents 202*. Bibliographic entries may be entered first into a raw data 204 master list and then copied into a document 202*. Alternatively, bibliographic entries may be entered first into a document 202* and then copied into a raw data 204 master list.
In a described implementation, schema 1004 provides a framework for bibliographic information 1002. For example, schema 1004 may define, explain, indicate, describe, etc. the layout, organization, interrelationships, permissible content, etc. of bibliographic information 1002. Schema 1004 may be incorporated as part of schema 220 (of
By way of example only, schema 1004 may comport with an extensible markup language (XML) formatting. A schema defining different source types for an example XML-based schema 1004 for bibliographic information 1002 is set forth and described below. The example schema below defines which bibliographic source types can include which pieces of data. The example schema also defines acceptable data format(s) (e.g., string, integer, a specially-defined type, etc.) for each of the pieces of data.
Schema utilization module 1006 is adapted to enable utilization of bibliographic information 1002. Examples of schema utilization include creation, modification, interpretation, application, etc. of a schema and/or of information that comports with a schema. Schema utilization module 1006 may be part of (including being a plug-in of) application 208 or another software program (including an OS), or schema utilization module 1006 may be a stand-alone program. Regardless, schema utilization module 1006 may be configured to interact with another program. Such interaction may include, for example, being callable by another program, being a plug-in of another program, calling another program, and so forth. As a specific example, a web service may create an add-on to the “Research and Reference” pane introduced in Microsoft® Word® 2003 (available from Microsoft® Corporation of Redmond, Wash.). The web service accepts search criteria and returns matches with bibliographic metadata that conforms to schema 1004. The bibliographic information 1002 may then be inserted into the document 202*.
By way of example, an application 208 that is to present document 202*, which has been previously created by some program, may employ schema utilization module 1006 to interpret bibliographic information 1002 in accordance with schema 1004. As another example, application 208 may call schema utilization module 1006 so that schema 1004 may be utilized to create a data structure of bibliographic information 1002 that is formulated in accordance with schema 1004. The created data structure of bibliographic information 1002 may be a master list of raw data 204, document-embedded raw data 204, and so forth. Additionally, application 208 may call schema utilization module 1006 so that schema 1004 may be utilized to modify a data structure of bibliographic information 1002 that is formulated in accordance with schema 1004.
In one example, a user may input source data for bibliographic information 1002 into document 202* using application 208 (e.g., in conjunction with schema utilization module 1006). The user may input the source data using a window (e.g., a dialog box or similar) having respective fields that are identified as corresponding to respective tagged parts (e.g., title, author, publication date, etc.) of a given source type (e.g., book, periodical article, etc.). Example XML-based source types, along with tagged parts thereof, that may be utilized to create such an input window are described herein below in the section entitled “Extensible Markup Language-Based Descriptions of Source Types for Bibliographies and Citations”. The input source data may be automatically incorporated into bibliographic information 1002 that is configured in accordance with a schema 1004 for bibliographic information. The bibliographic information 1002 may then be saved as part of document 202* by application 208.
In some implementations, an object-oriented programming model is provided to allow for manipulation of bibliographic information 1002 individually or in the context of a document 202* via a set of APIs or object-oriented message calls either directly through one or more APIs or programmatically through other software application programs (e.g., a schema utilization module 1006 that enables manipulation of bibliographic information 1002) that is written according to a variety of programming languages. Such programming languages include, for example C, C++, C#, Visual Basic, and the like. In one example, the object-oriented programming model is configured according to that disclosed in U.S. patent application Ser. No. 11/______, (Docket Nos. MS1-2280US/MS#310673.01), filed on even date herewith and entitled “Programmable Object Models for Bibliographies and Citations.”
Example XML-Based Schema for Bibliographies and Citations
As described above, a schema 1004 may be created, interpreted, modified or otherwise utilized by a schema utilization module 1006. Schema 1004 may be utilized by schema utilization module 1006 in accordance with the example bibliographic source schema provided below.
Thus, the following is a description of an example schema associated with XML notations for bibliographies and citations. Although a specific example schema is set forth below, more, fewer, and/or different source types may alternatively be included in a given XML schema for bibliographies and citations. Furthermore, different interrelationships and data types may alternatively be defined by such a schema.
The example schema below includes seventeen (17) different bibliographic source types, which are: book, book section, journal article, article in a periodical, conference proceeding, report, sound recording, performance, art, document from an internet site, internet site, film, interview, patent, electronic source, case, and miscellaneous. The example schema is:
Example implementations for source types are described below. Although other formats may alternatively be used, the seventeen (17) example source types are presented below in an XML format. By way of example only, the XML data tags may be used to populate a dialog box or similar user-input mechanism that is used in a word processing or other text-editing program. The dialog box enables the acquisition of bibliographic source information or raw data for a master list, for document-embedded bibliographic information, and so forth. Each bibliographic source can have a number of pieces of data associated with it, as specifically indicated below by data tags for each respective source type.
Thus, the following is a description of example XML that can be used to power a dialog box in an application 208. A user can enter notations for bibliographies and citations that conform to schema 1004. The example notations are separated into seventeen (17) portions with each respective portion corresponding to a respective bibliographic source type. However, more, fewer, and/or different source types may alternatively be included in a given XML notation set for bibliographies and citations.
The description below of example source types is primarily directed to respective sets of tagged parts that may correspond to or be associated with respective source types. Each example tagged part is for an attribute of the respective source type and generally includes two sub-tags: a label and a data tag. The source types may be combined into a forms collection.
The seventeen (17) example source types are: book, book section, journal article, article in a periodical, conference proceeding, report, sound recording, performance, art, document from an internet site, internet site, film, interview, patent, electronic source, case, and miscellaneous.
Source Type #1: Book
A book may be cited as a bibliographic source. Example attributes for a book bibliographic source are: Author, Title, Year, City, State/Country, Publisher, Editor, Short Title, Volume, Number of Volumes, Translator, Standard Number, and Comments.
An example XML portion for book bibliographic sources is:
Source Type #2: Book Section
A book section may be cited as a bibliographic source. Example attributes for a book section bibliographic source are: Author, Title, Book Author, Book Title, Year, Pages, City, State/Country, Publisher, Editor, Translator, Short Title, Volume, Number of volumes, Standard Number, and Comments.
An example XML portion for book section bibliographic sources is:
Source Type #3: Journal Article
A journal article may be cited as a bibliographic source. Example attributes for a journal article bibliographic source are: Author, Title, Journal Name, City, Month, Day, Year, Pages, Editor, Publisher, Volume, Issue, Short Title, Standard Number, and Comments.
An example XML portion for journal article bibliographic sources is:
Source Type #4: Article in a Periodical
An article in a periodical may be cited as a bibliographic source. Example attributes for an article in a periodical bibliographic source are: Author, Title, Periodical Title, City, Month, Day, Year, Pages, Short Title, Editor, Publisher, Edition, Volume, Issue, Standard Number, and Comments.
An example XML portion for article-in-a-periodical bibliographic sources is:
Source Type #5: Conference Proceedings
Conference proceedings may be cited as a bibliographic source. Example attributes for a conference proceeding bibliographic source are: Author, Title, Editor, Pages, Year, Conference Name, City, Publisher, Short Title, Volume, Standard Number, and Comments.
An example XML portion for conference proceeding bibliographic sources is:
Source Type #6: Report
A report may be cited as a bibliographic source. Example attributes for a report bibliographic source are: Author, Title, Year, Department, Institution, Publisher, City, Short Title, Pages, Report Type, Standard Number, and Comments.
An example XML portion for report bibliographic sources is:
Source Type #7: Sound Recording
A sound recording may be cited as a bibliographic source. Example attributes for a sound recording bibliographic source are: Composer, Conductor, Performer, Artist, Title, Album Title, Produce Name, Production Company, Year, Medium, City, State/Country, Recording Number, Short Title, Standard Number, and Comments.
An example XML portion for sound recording bibliographic sources is:
Source Type #8: Performance
A performance may be cited as a bibliographic source. Example attributes for a performance bibliographic source are: Title, Writer, Performer, Producer Name, Production Company, Director, Theater, City, State/Country, Month, Day, Year, Short Title, and Comments.
An example XML portion for performance bibliographic sources is:
Source Type #9: Art
Art may be cited as a bibliographic source. Example attributes for an art bibliographic source are: Artist, Title, Institution, Publication Title, City, State/Country, Publisher, Year, Pages, Short Title, and Comments.
An example XML portion for art bibliographic sources is:
Source Type #10: Document From Internet Site
A document from an internet site may be cited as a bibliographic source. Example attributes for a document-from-an-internet-site bibliographic source are: Author, Title, Editor, Internet Site Title, Producer Name, Production Company, Month, Day, Year, Month Accessed, Day Accessed, Year Accessed, URL, Medium, Version, Short Title, Standard Number, and Comments.
An example XML portion for bibliographic sources for documents from internet sites is:
Source Type #11: Internet Site
An internet site may be cited as a bibliographic source. Example attributes for an internet site bibliographic source are: Author, Title, Internet Site Title, Editor, Producer Name, Production Company, Month, Day, Year, Month Accessed, Day Accessed, Year Accessed, URL, Medium, Version, Short Title, and Comments.
An example XML portion for internet site bibliographic sources is:
Source Type #12: Film
A film may be cited as a bibliographic source. Example attributes for a film bibliographic source are: Title, Performer, Producer Name, Production Company, Director, Country, Distributor, Writer, Medium, Short Title, Year, Standard Number, and Comments.
An example XML portion for film bibliographic sources is:
Source Type #13: Interview
An interview may be cited as a bibliographic source. Example attributes for an interview bibliographic source are: Interviewee, Interview Title, Program Title, Interviewer, Month, Day, Year, Publisher, Broadcaster, Station, City, State/Country, Editor, Translator, Compiler, Pages, Short Title, Standard Number, and Comments.
An example XML portion for interview bibliographic sources is:
Source Type #14: Patent
A patent may be cited as a bibliographic source. Example attributes for patent bibliographic sources are: Inventor, Title, Month, Day, Year, Country, Type, Patent Number, Short Title, Editor, Translator, and Comments.
An example XML portion for patent bibliographic sources is:
Source Type #15: Electronic Source
An electronic source may be cited as a bibliographic source. Example attributes for a bibliographic source that is from an electronic source are: Author, Title, Publication Title, City, State/Country, Editor, Producer Name, Production Company, Translator, Publisher, Edition, Medium, Volume, Month, Day, Year, Short Title, Standard Number, and Comments.
An example XML portion for electronic source bibliographic sources is:
Source Type #16: Case
A case may be cited as a bibliographic source. Example attributes for a case bibliographic source are: Author, Title, Year, Case Number, Reporter, Place Published, Court, Month, Day, Year, Counsel, Short Title, Abbreviated Case Number, and Comments.
An example XML portion for case bibliographic sources is:
Source Type #17: Miscellaneous
A “miscellaneous” source may be cited as a bibliographic source. Example attributes for miscellaneous bibliographic sources are: Author, Title, Publication Title, Month, Day, Year, City, State/Country, Publisher, Editor, Pages, Short Title, Volume, Edition, Issue, Translator, Compiler, Standard Number, and Comments.
An example XML portion for miscellaneous bibliographic sources is:
The devices, actions, aspects, features, functions, procedures, modules, data structures, objects, components, etc. of
Thus, although systems, media, devices, methods, procedures, apparatuses, techniques, approaches, procedures, schemas, arrangements, and other implementations have been described in language specific to structural, logical, algorithmic, and functional features and/or diagrams, it is to be understood that the invention defined in the appended claims is not necessarily limited to the specific features or diagrams described. Rather, the specific features and diagrams are disclosed as example forms of implementing the claimed invention.
This U.S. patent application is a continuation-in-part (CIP) application of prior application Ser. No. 11/109,415 (Docket Nos. MS1-2279US/MS#310061.01), filed Apr. 19, 2005. Application Ser. No. 11/109,415 and application Ser. No. 11/______ (Docket Nos. MS1-2280US/MS#310673.01), which is filed on even date herewith and entitled “Programmable Object Models for Bibliographies and Citations”, are hereby incorporated by reference in their entirety herein.
Number | Date | Country | |
---|---|---|---|
Parent | 11109415 | Apr 2005 | US |
Child | 11280609 | Nov 2005 | US |