This application is related to U.S. patent application Ser. No. 11/441,636, filed on May 25, 2006, and entitled “Locating a Portion of Data on a Computer Network,” the disclosure of which is incorporated herein by reference.
The present invention relates generally to software and, more particularly, to the generation of a link to a portion of a resource.
A Uniform Resource Locator (URL) is the primary way to refer to or address resources on the Internet. Examples of such resources include HyperText Markup Language (HTML) documents, image files, video files, and other resources. In general, a URL is a string of characters conforming to a standardized format that refers to resources on the Internet by their location. For example, a URL may include the resource's name (e.g., file name) preceded by a hierarchy of directory names in which the resources are stored.
Currently, to reference a location in a document (e.g., HTML document), the URL provides an anchor identifier that points to a specific location within the document. The anchor identifier follows the server and pathname of the URL and is separated by the crosshatch “#” character. A corresponding anchor is inserted into the specific location in the document. When a Web browser reads a URL with an anchor identifier, the anchor identifier indicates to the client Web browser that it should begin displaying or scrolling the document from the specified location of the anchor.
A limitation associated with the anchor is that the anchor could only point to a specific location in the document. The anchor cannot reference a particular region or portion of the document. Thus, a URL cannot be used to reference a region in the document. Such anchor limitation limits the functionalities of application programs that may need more level of detail when using URLs to point to a document. For example, a user may want to bring attention to a specific region within a Web page and communicate this specific region to other users. One method to bring attention to this specific region is to highlight the specific portion. However, the only way currently to highlight this specific region is to modify the source code of the Web page, and typically, a user cannot modify the source code.
In view of the foregoing, there is a need for continuing efforts to improve the reference capabilities of a URL.
Various embodiments of the invention are disclosed in the following detailed description and the accompanying drawings.
Various embodiments of the invention may be implemented in numerous ways, including as a system, a process, an apparatus, or a series of program instructions on a computer readable medium such as a computer readable storage medium or a computer network where the program instructions are sent over optical or electronic communication links. In general, operations of disclosed processes may be performed in an arbitrary order, unless otherwise provided in the claims.
A detailed description of one or more embodiments is provided below along with accompanying figures. The detailed description is provided in connection with such embodiments, but is not limited to any particular example. The scope is limited only by the claims and numerous alternatives, modifications, and equivalents are encompassed. Numerous specific details are set forth in the following description in order to provide a thorough understanding. These details are provided for the purpose of example and the described techniques may be practiced according to the claims without some or all of these specific details. For the purpose of clarity, technical material that is known in the technical fields related to the embodiments has not been described in detail to avoid unnecessarily obscuring the description.
Embodiments described herein provide the generation of a link, such as a Uniform Resource Locator (URL), to a portion of a resource on a computer network. As explained in more detail below, the link may be embedded with a portion identifier that identifies one or more portions of a resource. With the portion identifier embedded in the link, the portion of the resource may be located based on the portion identifier extracted from the link and, in an embodiment, presented such as to bring attention to this specific portion of the resource.
Anchor component 104 may include anchor identifier 106 and, in an embodiment, may additionally include portion identifier 108. Anchor component 104 is separated from address component 112 by crosshatch “#” character 190. It should be appreciated that interpretation of anchor component 104 is performed by a client (e.g., a Web browser) with participation from a server (e.g., a Web server). When a client requests a resource from the Web server, the client sends address component 112 to the Web server, but does not send anchor component 104. Instead, the client waits for the Web server to send the resource identified in URL 102 and then processes the resource based on anchor component 104. Therefore, anchor component 104 is not passed to other systems during the process of resource retrieval.
Anchor identifier 106 defines the name of an anchor. In the example of
Portion identifier 108 identifies one or more portions associated with the resource. The portion may include an area, a region, a section, one or more lines of code, one or more characters within a line of code, and other portions associated with a resource. In an embodiment, the portion may be identified by a boundary associated with the portion. The boundary, for example, may be defined by the beginning of a portion and an end of a portion. In an embodiment, the portion identifier may include the start character count and an end character count associated with the portion. The character count is to the character offset within a resource, such as an HTML document. For instance, portion identifier 108 may be defined as “c:4132, 5342,” which identifies a portion of a resource beginning at character position 4132 and ends at character position 5342. It should be noted that the character count can be based on a count of the characters associated with the source code that comprise the resource or based on a count of characters that are rendered for display. In another embodiment, portion identifier 108 may include one or more characters (e.g., a number, a word, a set of words, and other characters) associated with a start of the portion and one or more characters associated with an end of the portion. For example, portion identifier 108 may be defined as “sw:‘About’,3&ew:‘there’,2,” which identifies a portion of a resource that begins where the word “About” occurs for the third time in the resource and ends where the word “there” occurs for the second time in the resource.
It should be noted that within anchor component 104, portion identifier 108 is separated from anchor identifier 106 by delimiter 110. Delimiter 110 is used to separate or mark the beginning and/or end of portion identifier 108.
With the selection of a portion provided, in an embodiment, the selection may be converted into a portion identifier in operation 203. As discussed above, the portion identifier is configured to identify the selected portion of the resource. In an embodiment, the portion identifier is configured to identify the boundary of the portion. For example, the portion identifier can be configured to identify a beginning of the portion and an end of the portion. If the beginning and end of the portion are identified by a character count, then a count of the characters is conducted to determine the beginning character position and the end character position associated with the portion of the resource. For example, the a count of the character offset may be conducted from the beginning of a document to the start and end characters positions associated with the portion of the document. If the beginning and end of the portion are identified by characters, then the characters (e.g., words) at the beginning and the end of the portion may be extracted and included in portion identifier.
A URL that is associated with the resource is also provided in operation 204 and, as discussed above, the URL includes an anchor component. In operation 206, the portion identifier is embedded into the URL to generate a URL that includes information for identifying a portion of the resource. In an embodiment, the portion identifier is embedded into or within the anchor component. As discussed above, the portion identifier is separated from an anchor identifier within the anchor component by one or more delimiters.
In the example of
To generate a link to portion 304, the portion identifier is embedded (e.g., appended or concatenated) into the URL. For example, as shown in
Web browser 302 may scroll to portion 304 and present the portion. It should be appreciated that portion 304 may be presented by a variety of methods. For example, in an embodiment, the portion may be highlighted to make the portion visually distinct from other information displayed in region 310 of the Web browser. For example, as shown in
To retrieve a resource (e.g., a Web page), client 654 (or Web browser 652) transmits a request to Web server 656 located at a URL (with embedded portion identifier) associated with the resource. In response to the request, Web server 656 transmits the resource to client 654. The resource may be stored on Web server 656 or provided to the Web server for transmission to client 654. With the resource provided, portion identifier processing application 650 may, for example, extract the portion identifier from the URL, locate the portion of the resource based on the portion identifier, and highlight the portion of the resource. It should be noted that portion identifier processing application 650 may additionally, for example, convert the selection of the portion into a portion identifier and embed the portion identifier into the URL.
In some embodiments, computing device 710 performs specific operations by processor 704 when executing one or more sequences of one or more program instructions stored in system memory 706. Such program instructions may be read into system memory 706 from another computer readable medium, such as storage device 708. In some embodiments, hard-wired circuitry may be used in place of or in combination with software program instructions to implement embodiments of the invention.
It should be appreciated that the term “computer readable medium” refers to suitable medium that participates in providing program instructions to processor 704 for execution. Such a medium may take many forms, including but not limited to, non-volatile media, volatile media, and transmission media. Non-volatile media may include, for example, optical or magnetic disks, such as storage device 708. Volatile media may include dynamic memory, such as system memory 706. Transmission media includes coaxial cables, copper wire, and fiber optics, including wires that comprise bus 702. Transmission media can also take the form of acoustic or light waves, such as those generated during radio wave and infrared data communications. Common forms of computer readable media includes, for example, magnetic mediums (e.g., floppy disk, flexible disk, hard disk, magnetic tape, and other magnetic mediums), optical mediums (e.g., compact disc read-only memory (CD-ROM) and other optical mediums), physical medium with patterns (e.g., punch cards, paper tape, any other physical mediums), memory chips or cartridges, carrier waves, (e.g., RAM, programmable read-only memory (PROM), erasable programmable read-only memory (EPROM), flash memory, and other memory chips or cartridges), and any other medium from which a computer can read.
In some embodiments, execution of the sequences of program instructions to practice the embodiments may be performed by a single computing device 710. In other embodiments, two or more computer systems, such as computing device 710, coupled by communication link 720 (e.g., local area network (LAN), public switched telephone network (PSTN), wireless network, and other communication links) may perform the sequence of program instructions to practice the embodiments in coordination with one another. In addition, computing device 710 may transmit and receive messages, data, and instructions, including program, i.e., application code, through communication link 720 and communication interface 712. Received program instructions may be executed by processor 704 as the program instructions are received, and/or stored in storage device 708, or other non-volatile storage for later execution.
The above-described embodiments provide methods and systems for generating a link to a portion of a resource. By embedding a portion identifier into the link, the link can be configured to include information that points to one or more portions of a resource. As a result, if a user wants to bring attention to a specific portion of a resource, the user can generate a link with an embedded portion identifier and share the link with other users. Furthermore, the portion of the resource may be located and highlighted by referencing the link and accordingly, a user does not need to modify the source code of the Web page in order to highlight the portion.
Although the foregoing examples have been described in some detail for purposes of clarity of understanding, the embodiments are not limited to the details provided. There are many alternative ways of implementing the embodiments. The disclosed examples are illustrative and not restrictive.
Number | Name | Date | Kind |
---|---|---|---|
5659729 | Nielsen | Aug 1997 | A |
5898836 | Freivald et al. | Apr 1999 | A |
5982370 | Kamper | Nov 1999 | A |
6574644 | Hsu et al. | Jun 2003 | B2 |
6763496 | Hennings et al. | Jul 2004 | B1 |
6950987 | Hargraves et al. | Sep 2005 | B1 |
6961909 | Lord et al. | Nov 2005 | B2 |
20010049698 | Hsu et al. | Dec 2001 | A1 |
20050034063 | Baker et al. | Feb 2005 | A1 |
20050055458 | Mohan et al. | Mar 2005 | A1 |
20050066269 | Wang | Mar 2005 | A1 |
20050149576 | Marmaros et al. | Jul 2005 | A1 |
20050149851 | Mittal | Jul 2005 | A1 |
20050268214 | Lu | Dec 2005 | A1 |
20060026496 | Joshi et al. | Feb 2006 | A1 |
20060046686 | Hawkins et al. | Mar 2006 | A1 |
20070208704 | Ives | Sep 2007 | A1 |