WO2000041095A2 - Method and apparatus for performing supplemental searches over a network - Google Patents

Method and apparatus for performing supplemental searches over a network Download PDF

Info

Publication number
WO2000041095A2
WO2000041095A2 PCT/US1999/027776 US9927776W WO0041095A2 WO 2000041095 A2 WO2000041095 A2 WO 2000041095A2 US 9927776 W US9927776 W US 9927776W WO 0041095 A2 WO0041095 A2 WO 0041095A2
Authority
WO
WIPO (PCT)
Prior art keywords
search
application program
user
database
results
Prior art date
Application number
PCT/US1999/027776
Other languages
French (fr)
Other versions
WO2000041095A3 (en
Inventor
Daniel E. Tedesco
Jay S. Walker
Marc D. Kessman
Original Assignee
Walker Digital, Llc
Priority date (The priority date is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the date listed.)
Filing date
Publication date
Family has litigation
First worldwide family litigation filed litigation Critical https://patents.darts-ip.com/?family=22838436&utm_source=google_patent&utm_medium=platform_link&utm_campaign=public_patent_search&patent=WO2000041095(A2) "Global patent litigation dataset” by Darts-ip is licensed under a Creative Commons Attribution 4.0 International License.
Application filed by Walker Digital, Llc filed Critical Walker Digital, Llc
Priority to AU21553/00A priority Critical patent/AU2155300A/en
Publication of WO2000041095A2 publication Critical patent/WO2000041095A2/en
Publication of WO2000041095A3 publication Critical patent/WO2000041095A3/en

Links

Classifications

    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F40/00Handling natural language data
    • G06F40/20Natural language analysis
    • G06F40/232Orthographic correction, e.g. spell checking or vowelisation
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F40/00Handling natural language data
    • G06F40/20Natural language analysis
    • G06F40/253Grammatical analysis; Style critique
    • YGENERAL TAGGING OF NEW TECHNOLOGICAL DEVELOPMENTS; GENERAL TAGGING OF CROSS-SECTIONAL TECHNOLOGIES SPANNING OVER SEVERAL SECTIONS OF THE IPC; TECHNICAL SUBJECTS COVERED BY FORMER USPC CROSS-REFERENCE ART COLLECTIONS [XRACs] AND DIGESTS
    • Y10TECHNICAL SUBJECTS COVERED BY FORMER USPC
    • Y10STECHNICAL SUBJECTS COVERED BY FORMER USPC CROSS-REFERENCE ART COLLECTIONS [XRACs] AND DIGESTS
    • Y10S707/00Data processing: database and file management or data structures
    • Y10S707/99931Database or file accessing
    • Y10S707/99933Query processing, i.e. searching

Definitions

  • the present invention relates generally to tools for improving the efficiency of software programs, such as word processing programs and spreadsheet programs, and more particularly, to a method and apparatus for cooperating with such software programs to perform supplemental searches over the Internet or another public network.
  • the AutoFormat feature in Microsoft WordTM works "in the background" (i.e., substantially separate from other functions of the program and/or absent interaction with the user) to automate a number of formatting tasks, while the user focuses on the document content.
  • the AutoFormat feature analyzes each paragraph to determine how the paragraph is used in a document. For example, the AutoFormat feature may determine whether a given paragraph is used as a heading or as an item in a numbered list. Thereafter, the AutoFormat feature applies a style that is appropriate for the identified item.
  • the AutoFormat feature automatically formats Internet, network, and e-mail addresses as hyperlink addresses. There is a vast amount of information available on the World Wide Web
  • the Web and other public networks.
  • a browser such as Netscape Navigator CommunicatorTM, commercially available from Netscape Communications Corporation of Mountain View, CA
  • a browser is used to access a web site with a known uniform resource locator ("URL") address directly, or to access a search engine, such as Yahoo!TM or Alta VistaTM, that can identify other web sites containing relevant information.
  • URL uniform resource locator
  • search engine such as Yahoo!TM or Alta VistaTM, that can identify other web sites containing relevant information.
  • the search engine the user enters keywords directing a search on a desired topic and the browser receives the search results from the search engine for presentation to the user.
  • the search results comprise a set of hyperlinks pointing to web sites containing relevant information. While helpful information can often be found in this manner, the process can be quite slow.
  • Pre-fetching strategies attempt to load documents into a client application before the user has actually selected any of these documents for browsing.
  • URL uniform resource locator
  • the addressed document may have already been prefetched and stored (e.g., cached) on or near the user's machine, thus reducing the document access time observed by the user.
  • multitasking allows a user to run several programs simultaneously, which can each be viewed and managed by the user through a single graphical user interface (GUI).
  • GUI graphical user interface
  • a user can initiate an Internet search using a browser and then return to operating a word processing program in another window.
  • both programs are open on the desktop simultaneously, and the user can switch between applications, the user only actively uses one program at a time). Specifically, the one program that is currently affected by user commands and data entry is deemed to be in the "foreground," while any other programs are in the background.
  • the spelling and grammar check features of conventional word processing programs have not been fully integrated with browsers and other Internet tools.
  • the spelling and grammar check features suffer from a number of limitations, which, if overcome, could greatly increase the utility and efficiency of such features.
  • the spelling and grammar check features compare a document against a predefined database to identify improper usage. Since new words and phrases are continuously adopted and acceptable grammar usage will change over time, the predefined databases used by the spelling and grammar check features become quickly outdated. While conventional word processing programs often include a mechanism to allow users to update the spelling and grammar databases to reflect such changes, there is a need for spelling and grammar check tools that utilize a dynamic database that inherently reflects such changes in common usage.
  • a method and apparatus for cooperating with a software program, such as a word processing program or a spreadsheet program, to perform a supplemental search over the Internet or another public network.
  • a supplemental search is performed in the background over the Internet or another public network, to obtain desired information while the user continues the primary task of creating a document.
  • an illustrative word processing application program spawns a background thread (corresponding to a process running in the background) in a multithreaded environment to perform the supplemental search using a browser while the word processing application program maintains continuous control until the search results are obtained and viewed by the user.
  • a supplemental search can be performed on a given topic when requested by a user.
  • the user selects a desired data element (e.g., one or more words) in a document and initiates a supplemental search of the data element, for example, by clicking on a toolbar icon, selecting a search command option from a menu or performing a predefined series of keystrokes.
  • the supplemental search is launched in the background and the user continues working in the word processing application program until the search results are received.
  • the user does not have to divert his or her attention from the primary task of creating the document to manually initiate a search.
  • a supplemental search can be performed automatically if a predefined condition is detected in a document of an application program.
  • a supplemental search can be performed to evaluate the usage of an apparently improper data element that fails to satisfy the requirements of a spelling or grammar database associated with the word processing application program.
  • a supplemental search of an apparently improper data element can be launched automatically if the apparently improper data element appears more than a threshold number of times in a document.
  • the supplemental usage search is launched in the background, transparent to the user, and the user continues working in the word processing application program until the search results are received.
  • the present invention can be configured to perform Internet-based spelling or grammar checking.
  • the present invention determines if the apparently improper data element has been used more than a threshold number of times on remote servers accessed through the public network, such as the Internet. In this manner, the present invention automatically detects the adoption of new words or phrases and changes in acceptable grammar usage. If the apparently improper data element has been used more than a threshold number of times, the user can be queried to update the document to reflect the new usage.
  • the static spelling or grammar databases associated with the word processing application program can optionally be dynamically updated to reflect such new words or phrases and changes in grammar usage as the content available on a public network changes and grows.
  • the word processing application program automatically determines if a document being created corresponds to one or more predefined categories. If a document being created corresponds to a predefined category, the document can optionally be provided to an expert associated with said identified category for review. The results of the expert review are then provided to the user. The user can be required to guarantee payment for the expert review, for example, using a credit card or a prepaid account, or to otherwise prepay for the expert review.
  • a particular expert can be identified, for example, by accessing a database indicating one or more experts for each predefined category, or by one or more designated experts, such as individuals having predefined qualifications.
  • FIG. 1 is a schematic block diagram of a network environment in accordance with the present invention
  • FIG. 2 is a schematic block diagram of an illustrative user computing device of FIG. 1;
  • FIG. 3 is a sample table illustrating an exemplary process identifier (PID) database of FIG. 2;
  • FIGS. 4A through 4C collectively, are a flow chart illustrating an exemplary word processing application program implemented by the user computing device of FIG. 2;
  • FIGS. 5A through 5E collectively, are a flow chart illustrating an exemplary supplemental search process implemented by the user computing device of FIG. 2; and FIGS. 6A and 6B, collectively, are a flow chart illustrating an exemplary expert finder process implemented by the user computing device of FIG. 2.
  • FIGS. 5A through 5E collectively, are a flow chart illustrating an exemplary supplemental search process implemented by the user computing device of FIG. 2; and FIGS. 6A and 6B, collectively, are a flow chart illustrating an exemplary expert finder process implemented by the user computing device of FIG. 2.
  • FIG. 1 illustrates a network environment 100 in accordance with the present invention.
  • the network environment 100 includes a user computing device 200, discussed below in conjunction with FIG. 2, that includes a Web browser 110 and an application program 400, such as a word processing program or a spreadsheet program.
  • the present invention may be used in any environment where a user obtains Web resources from one or more remote servers, such as servers 150-1 through 150-N, over a publicly accessible network, such as the Internet 140.
  • the browser 110 cooperates with a proxy server 130 (or a firewall) of an Internet Service Provider ("ISP") to access the Internet or World Wide Web (“Web”) environment 140 to obtain the Web resources from the remote servers 150-N.
  • ISP Internet Service Provider
  • Web World Wide Web
  • Web resources are entities that can be requested from a remote server 150-N, including HTML documents, images, audio and video streams and applets.
  • a user of the application program 400 can perform a supplemental search in the background over the Internet 140 or another public network, to obtain desired information, while the user continues the primary task of creating the document.
  • the word processing application program 400 spawns a background thread in a multithreaded environment to perform the supplemental search using the browser 1 10, while the word processing application program 400 maintains continuous control until the search results are obtained and viewed by the user.
  • the word processing application program 400 launches a supplemental search on a given data element when requested by a user.
  • the user selects a desired data element in a document and initiates a supplemental search of the data element by clicking on a toolbar icon, selecting a search command option from a menu or performing a corresponding predefined series of keystrokes.
  • the supplemental search is launched in the background and the user continues working in the word processing application program 400 until the search results are received.
  • the user does not have to divert his or her attention from the primary task of creating the document to manually initiate a search.
  • the word processing application program 400 launches a supplemental search automatically, for example, to evaluate the usage of an apparently improper data element that fails to satisfy the requirements of a spelling or grammar database associated with the word processing application program 400.
  • a supplemental search of an apparently improper data element is launched automatically if the apparently improper data element appears more than a threshold number of times in a document.
  • the supplemental usage search is launched in the background, transparent to the user, and the user continues working in the word processing application program 400 until the search results are received.
  • the present invention can be configured to perform Internet-based spelling or grammar checking.
  • the present invention determines if the apparently improper data element has been used more than a threshold number of times on the remote servers 150-1 through 150-N accessed through the public network 140, such as the Internet. In this manner, the present invention automatically detects the adoption of new words and phrases and changes in acceptable grammar usage. If the apparently improper data element has been used more than a threshold number of times, the user can be queried to update the document to reflect the new usage, and the static spelling or grammar databases associated with the word processing application program 400 can optionally be updated. In a further variation, the supplemental searches for unrecognized words or terms can be batched and executed when the operating system detects that the word processing application program 400 has been inactive for more than an established threshold period of time.
  • the word processing application program 400 automatically determines if a document being created corresponds to one or more predefined categories. If a document being created does correspond to a predefined category, the document can optionally be provided to an expert associated with said identified category for review. For example, a document with repeated occurrences of the term "material evidence” or "modus operandi" may be categorized as a legal document. The results of the expert review are then provided to the user.
  • FIG. 2 is a block diagram showing the architecture of an illustrative user computing device 200.
  • the user computing device 200 includes a central processing unit (CPU) 210 in communication with a data storage device 215, a read only memory (ROM) 220, a random access memory (RAM) 230, one or more input device(s) 240, one or more output device(s) 250, and a communications port 260.
  • the CPU 210 can be in communication with the data storage device 215, the read only memory (ROM) 220, the random access memory (RAM) 230, the input device(s) 240, the output device(s) 250 and the communications port 260, by means of a shared data bus or dedicated connections, as shown in FIG. 2.
  • the input device 240 may be embodied, for example, as one or more of a keyboard, mouse, joystick and optical scanner.
  • the output device 250 may be embodied, for example, as one or more of a display, a printer, network interface card (NIC) and an audio output.
  • the communications port 260 connects the user computing device 200 to the public network, such as the Internet 140.
  • the communication port 260 may include multiple communication channels for simultaneous communication with more than one remote terminal and/or server.
  • the data storage device 215 includes a browser 110 and an application program 400, discussed further below in conjunction with FIGS. 4A through 4C.
  • the browser 110 may be embodied, for example, as Netscape Navigator TM, commercially available from Netscape Communications Corporation of Mountain View, CA, as modified to configure the browser 110 for a proxy by going, for example, to Edit/Preferences/ Advanced/Proxies.
  • the application program 400 is embodied as a word processing application, such as Microsoft WordTM commercially available from Microsoft Corporation of Redmond, WA, as modified herein to incorporate features and functions of the present invention.
  • the word processing application program 400 includes a conventional spell check program 270 and related spelling database, and a conventional grammar check program 280 and related grammar database.
  • the spelling database or the grammar database may be updated by the present invention to reflect a new usage as determined by an Internet search.
  • the data storage device 215 includes a dispatch thread message queue 290 for sending messages to a dispatch thread manager in the multithreaded environment of the present invention, and an inter-process communication (IPC) message queue 295 for sending IPC messages between processes in accordance with the present invention.
  • IPC inter-process communication
  • the data storage device 215 also includes a process identifier (PID) database 300 that stores information on each process created by the operating system.
  • PID process identifier
  • the data storage device 215 and/or ROM 220 are operable to store one or more programs that the CPU 210 is operable to retrieve, interpret and execute.
  • the data storage device 215 also includes a supplemental search process 500 and an expert finder process 600.
  • the word processing application program 400 together with the supplemental search process 500, or the expert finder process 600, directs the CPU 210 to operate in accordance with the present invention, and particularly in accordance with the methods described in detail herein.
  • the word processing application program 400 directs the CPU 210 to launch the supplemental search process 500 (i) when a supplemental search is requested by a user on a given topic, or (ii) automatically, to evaluate the usage of an apparently improper data element that fails to satisfy the requirements of the spelling or grammar databases 270, 280.
  • the expert finder process 600 runs in the background to automatically determine if a document being created corresponds to one or more predefined categories, and, if so, to optionally provide the document to an expert in said identified category for review.
  • the word processing application program 400, the supplemental search process 500, and/or the expert finder process 600 may each include program elements that may be necessary, such as "device drivers" for allowing the CPU 210 to interface, for example, with the output device 250 and other computer peripheral devices (not shown). Appropriate device drivers and other necessary program elements are known to those skilled in the art, and need not be described in detail herein.
  • PID database 300 is an exemplary arrangement for stored representations of information to illustrate the principles of the invention. A number of other arrangements and informational content may be employed, as would be apparent to a person of ordinary skill in the art.
  • the process identifier (PID) database 300 typically includes a plurality of records, such as records 305, 310, 315, 320 and 325, each associated with a different active process.
  • the process identifier (PID) database 300 includes a description of the process type in field 335, a task in field 340 and an identification of the assigned memory segment in field 345.
  • records 310 and 325 correspond to two versions of a browser program 1 10 that have been created by the operating system in accordance with the present invention.
  • the version of the browser program 1 10 associated with record 310 corresponds to a first "data searching" embodiment of the invention, where the user has initiated a search on a specified data element.
  • the version of the browser program 1 10 associated with record 325 corresponds to a second "evaluate usage" embodiment of the invention, where a supplemental search is performed automatically to determine the number of occurrences on the Internet of an apparently misspelled term.
  • the word processing application program 400 launches the supplemental search process 500 (FIGS. 5A through 5E) (i) when a supplemental search is requested by a user on a given topic, or (ii) automatically, to evaluate the usage of an apparently improper data element that fails to satisfy the requirements of the spelling or grammar databases 270, 280 or another set of conditions.
  • the word processing application program 400 processes the results of the supplemental search that are returned by the browser 110.
  • the word processing application program 400 is generally launched during step 403 when a user starts or executes the word processing application program 400.
  • a test is performed during step 406 to determine if a version of the application is already running. If it is determined during step 406 that a version of the application is not already running, then the application must create a version of the application and requests a process identifier during step 409 from the operating system.
  • the application is assigned a process identifier during step 412, and the operating system records the process identifier in the process identifier (PID) database 300.
  • the application requests and is allocated a memory segment during step 415. The memory segment allocation is likewise recorded in the process identifier (PID) database 300.
  • the application goes through an initialization phase during step 418, such as resetting counters, zeroing out memory and resetting variable values, before starting a dispatcher thread manager.
  • step 406 If, however, it is determined during step 406 that that a version of the application is already running, then the application requests the focus from the operating system (i.e., requests to be brought to the foreground) during step 421. Thus, the application that was just started (or was already running) is now the active window.
  • the word processing application program 400 then enters a sleep state during step 424 until it is detected during step 427 that the user has requested the attention of the application with a keystroke or mouse event. In this manner, the application program 400 does not waste system resources by unnecessarily taking CPU cycles away from other applications. Once a keystroke or mouse event is detected during step 427, the event will be trapped and acted upon.
  • the user request associated with the keystroke or mouse event, or an operating system request associated with an operating system message is then handled during step 430 (FIG. 4B).
  • the user request processed during step 430 may be, for example, to display characters on the screen, to save a file, to copy and paste data, to find or replace text, or to print or preview a document.
  • FIGS. 4B and 4C The processing of user or operating system requests associated with the present invention are shown in FIGS. 4B and 4C.
  • a test is performed during step 433 to determine if the user request consists of the highlighting of text by the user. If it is determined during step 433 that the user request does not consist of highlighting text, then processing continues in a conventional manner during step 435. If, however, it is determined during step 433 that the user request does consist of highlighting text, then the user is notified during step 436 of the various actions that are possible on selected text. It is noted that a user may select text, for example, by holding down the shift key and moving the arrow to cover the desired text, or holding down the left mouse button and moving the mouse to highlight the desired text.
  • a test is performed during step 439 to determine if the selected action is data searching in accordance with the present invention. It is noted that the user can click on the "data searching" option with the left mouse button, or can move up or down the list of various actions until the "data searching" option is highlighted and then depress the enter key. If it is determined during step 439 that the selected action is not data searching, then processing continues in a conventional manner during step 435. If, however, it is determined during step 439 that the selected action is data searching, then a task variable is set to "data searching" during step 442.
  • the word processing application program 400 will then utilize multithreading technology to return control of the word processing application program 400 to the user at step 424, while simultaneously spawning a background thread to handle the "data searching" task performed by the supplemental search process 500.
  • the word processing application program 400 launches the supplemental search process 500 during step 445, while simultaneously returning control of the word processing application program 400 to step 424.
  • step 450 another test is periodically performed in the background during step 450 to determine if there is a data element in the document that does not match the correct usage requirements indicated in either the spelling or grammar databases associated with the word processing application program 400. If it is determined during step 450 that all the data elements in the document match the correct usage requirements indicated in either the spelling or grammar databases, then processing continues in a conventional manner during step 435.
  • a further test is performed during step 453 to determine if the number of occurrences of the apparently improper data element in the document exceed a predefined threshold.
  • the threshold acts as a filter that may be predefined or specified by the user to prevent a supplemental search from being performed unnecessarily. In this manner, the threshold can be set relatively high, to eliminate hypersensitivity and to allow for a more conservative use of language in a document. Likewise, the thresholds can be set low, such as one occurrence, to perform a supplemental search on any data element that does not satisfy the requirements of the spelling or grammar checking programs.
  • the thresholds can be dynamically established based upon the user's skill and accuracy as a speller or writer. For example, a user making many errors that are detected and corrected by the spelling or grammar checking programs might establish high thresholds to avoid unnecessary supplemental searches on the Internet for words that are likely misspelled.
  • the word processing application program 400 may also be configured such that only words with the ".com" extension are searched over the Internet.
  • the word processing application program 400 can detect the over-use of a word or term such that the supplemental search accesses a thesaurus to identify words with similar meanings. If it is determined during step 453 that the number of occurrences of the data element in the document does not exceed the predefined threshold, then processing continues in a conventional manner during step 435.
  • step 453 If, however, it is determined during step 453 that the number of occurrences of the data element in the document exceed the predefined threshold, then the task variable is set to "evaluate usage" during step 456. Thereafter, the word processing application program 400 will utilize multithreading technology to return control of the word processing application program 400 to the user at step 424, while simultaneously spawning a background thread to handle the "evaluate usage" task performed by the supplemental search process 500. Thus, as shown in FIG. 4B, the word processing application program 400 launches the supplemental search process 500 during step 445, while simultaneously returning control of the word processing application program 400 to step 424.
  • the supplemental search process 500 will determine the number of occurrences of the same apparent misspelling on the Internet. The operation of the supplemental search process 500 will be discussed below in conjunction with FIGS. 5A through 5E.
  • the word processing application program 400 After the supplemental search process 500 has completed either the "data searching" or "evaluate usage" tasks, the word processing application program 400 must process the results. Thus, as shown in FIG. 4C, the word processing application program 400 will periodically perform a test during step 460 to determine if the word processing application program 400 has received any task completion messages from the supplemental search process 500. If it is determined during step 460 that no task completion messages have been received, then program control will return to step 424 (FIG. 4A).
  • step 463 determines if the task associated with the message is a "data search" task. If it is determined during step 463 that the task associated with the message is a "data search” task, then the user is notified of the search status during step 466. For example, the word processing application program 400 can display a "popup" window (or dialog box) or a status indicator on the status bar or a toolbar to the user. A test is performed during step 469 to determine if the user activates the search results, for example, by clicking on the "view results” button in a "pop-up” window or clicking on a corresponding icon in the toolbar.
  • step 469 If it is determined during step 469 that the user has not yet activated the search results, then the word processing application program 400 will wait during step 472 until the user activates the results. If, however, it is determined during step 469 that the user has activated the search results, then the user is presented with the data returned by the browser program 1 10 during step 475, before program control returns to step 424 (FIG. 4A).
  • step 463 If, however, it is determined during step 463 that the task associated with the message is a not "data search" task, then a further test is performed during step 480 to determine if the task associated with the message is an "evaluate usage” task. If it is determined during step 480 that the task associated with the message is not an "evaluate usage” task, then an unknown task completion message has been received and an error message is passed to an e ⁇ or handling routine during step 483, which will notify the user of the problem. If, however, it is determined during step 480 that the task associated with the message is an "evaluate usage” task, then a further test is performed during step 486 to determine if the search results indicate that the apparently incorrect data element has been used on the Internet more than a threshold number of times. If it is determined during step 486 that the results do not exceed the predefined threshold, then program control returns to step 424 (FIG. 4A).
  • step 486 If, however, it is determined during step 486 that the results do exceed the predefined threshold, then the appropriate spelling or grammar database is optionally updated during step 489, and the user is queried during step 492 to determine if one or more of the instances of the data element should be updated in the document. Thereafter, program control returns to step 424 (FIG. 4A).
  • the word processing application program 400 shown in FIG. 4, launches the supplemental search process 500, shown in FIGS. 5A through 5E, (i) when a supplemental search is requested by a user on a given topic, or (ii) automatically, to evaluate the usage of an apparently improper data element that fails to satisfy the requirements of the spelling or grammar databases 270, 280. As shown in FIG.
  • the word processing application program 400 initially sends a message to the dispatcher thread manager during step 502 to make the dispatcher thread manager aware of a new task that needs attention.
  • the message is placed in the dispatcher thread message queue 290 (FIG. 2) during step 504.
  • the word processing application program 400 can queue up requests for the dispatcher thread manager and the dispatcher thread manager can take requests, for example, using a first-in-first-out (FIFO) protocol.
  • FIFO first-in-first-out
  • a test is performed during step 506 to determine if the message is retrieved from the queue 290 by the dispatcher thread manager. If it is determined during step 506 that the message is not retrieved by the dispatcher thread manager, then the word processing application program 400 contacts the operating system during step 508 to verify the existence of the dispatcher thread manager. The operating system performs a test during step 510 to determine if the dispatcher thread manager exists. If it is determined during step 510 that the dispatcher thread manager does exist, then the dispatcher thread manager must be in a run-away state and the operating system locates the thread identifier to destroy the dispatch thread during step 512. If, however, it is determined during step 510 that the dispatcher thread manager does not exist, then the application 400 contacts the operating system to start the creation of a new thread during step 514. A new dispatcher thread manager is created during step 516 and released to the application for use.
  • the dispatcher thread manager reads the message in the queue during step 518 and determines what task to perform.
  • a test is performed by the dispatcher thread manager during step 520 (FIG. 5B) to determine if a worker thread is available. If it is determined during step 520 that a worker thread is not available, then the dispatcher thread manager requests a thread from the operating system during step 522, records the thread identifier and releases the thread during step 524. If, however, it is determined during step 520 that a worker thread is already available (or after creation and release of a thread during steps 522 and 524), then the dispatcher thread manager forwards the message received from the application
  • the worker thread reads the message during step 528.
  • a test is performed by the worker thread during step 530 to determine if the libraries required to complete the designated task are available. If it is determined during step 530 that all the libraries required to complete the designated task are not available, then the worker thread determines which libraries are needed during step 532, and loads the libraries into the shared memory pool during step 534.
  • step 530 If it is determined during step 530 that all the libraries required to complete the designated task are available (or after the appropriate libraries have been loaded during steps 532 and 534), then the browser program 110 is spawned during step 536 (FIG. 5C).
  • the worker thread performs a test during step 538 to determine if the browser program 110 is successfully spawned. For example, if the worker thread cannot record the process identifier of the browser, then the spawning process has likely failed.
  • step 538 If it is determined during step 538 that the browser program 110 has not been successfully spawned, then the worker thread can attempt to spawn the browser again, until a maximum number of retries is detected during step 540. If it is determined during step 540 that the maximum number of retries has been attempted, then the result is passed to an error handling routine during step 542, and the user and application 400 are notified of the error during step 544.
  • the worker thread forwards the message received from the dispatcher thread manager to the browser program 110 during step 546, using interprocess communication (IPC) techniques.
  • IPC interprocess communication
  • the message may indicate the search term to the browser program 110, for example, in the form of a well-known binary query. It is noted that searching performed by the browser 1 10 can be geographically restricted to account for different languages and dialects.
  • the worker thread periodically checks the IPC queue 295 during steps 550 through 554 to ensure that messages are picked up by the appropriate processes. Thus, a test is performed during step 550 to determine if messages are picked up from the IPC queue 295.
  • step 552 If it is determined during step 552 that a message is not picked up from the queue 295 within a predefined period of time, then the message is removed from the queue during step 556 and the result is passed to an error handling routine for notification of the user and application 400 during step 558.
  • step 550 If, however, it is determined during step 550 that messages are picked up from the IPC queue 295, then the worker thread will wait during step 560 until the browser program 110 triggers an event to "awaken" the worker thread. In other words, the worker thread checks the message queue for new messages. If the worker thread finds a new message, the worker thread will act on it. Otherwise, the worker thread goes into a sleep state until a new message indicating that the browser program has completed its task is received. Thus, a test is performed during step 562 to determine if the worker thread detects a wake event (task completion message). Once it is determined during step 562 that a task completion message is received from the browser program, the worker thread is notified during step 564. The browser places the task completion message in the worker thread queue with the browser's PID, so that a particular worker thread can determine what task was requested of the browser program by doing a PID data lookup to see what information was recorded before the spawning process for this particular task.
  • the worker thread verifies the integrity of the data in the task completion message and places the task completion message in the dispatcher thread message queue 290 during step 568, to notify of the task completion. If the message is not picked up within a predefined period of time, then the message is re-queued. If after a predefined number of retries, the message is not retrieved from the message queue, then the worker thread must pass an error message to the error handling routine for reporting to the user and application process 400. The message is retrieved by the dispatcher thread manager during step
  • step 572 the dispatcher thread manager reads the message during step 572 (FIG. 5E).
  • the dispatcher thread manager notifies the word processing application program 400 of the task completion message during step 574, with an indication of the requested task.
  • the dispatcher thread manager places a message into the worker thread queue during step 576 to terminate the browser program 110 associated with the completed task.
  • the worker thread uses the recorded PID to identify and then terminate the appropriate browser program 110.
  • the worker thread sends a message to the operating system to terminate the browser program and reclaim the associated resources, such as memory and CPU cycles.
  • Program control of the supplemental search process 500 terminates during step 580.
  • the expert finder process 600 shown in FIGS.
  • the expert finder process 600 may be executed periodically, or intermittently, for example, each time a document is saved or printed.
  • the expert can be contacted using the methods and apparatus disclosed, for example, in United States Patent Application Serial Number 09/112,131, entitled “Method and Apparatus for a Cryptographically Assisted Commercial Network System Designed to Facilitate and Support Expert-Based Commerce,” filed July 8, 1998 and assigned to the assignee of the present invention and incorporated by reference herein.
  • the expert finder process 600 initially identifies one or more data elements occurring frequently in a document the user is creating. A test is performed during step 615 to determine if the data element occurs in the document more than a threshold number of times. If it is determined during step 615 that the data element does not occur more than a threshold number of times, then processing continues conventionally during step 620.
  • step 615 If, however, it is determined during step 615 that the data element does occur more than a threshold number of times, then a further test is performed during step 625 to determine if there is an appropriate expert in an expert index (not shown) corresponding to the topic associated with the identified data element. If it is determined during step 625 that there is no appropriate expert, then processing continues conventionally during step 620.
  • step 625 If, however, it is determined during step 625 that there is an appropriate expert, then the user is given the option during step 630 to provide the document to the identified expert. A further test is then performed during step 635 to determine if the users selects the expert help option. If it is determined during step 635 that the users does not select the expert help option, then processing continues conventionally during step 620.
  • step 635 If, however, it is determined during step 635 that the user does select the expert help option, then the document is saved during step 640 (FIG. 6B). The document is then transmitted to a remote server associated with the expert by means of the communication port 260 during step 645. After the expert review is complete, the document including the expert's suggestions is then received during step 650 by means of the communication port 260. Finally, an output signal is provided to the user during step 655 indicating that the expert suggestions are available for review, before program control terminates.
  • the present invention can be utilized to compare the relative usage of two terms on the Internet.
  • the user can initiate a search performed in the background in accordance with the present invention that returns the number of occurrences of the word "colour” versus the number of occurrences of the word "color.” Thereafter, the user can utilize the search results to select one of the words, or the present invention can automatically select the word with the higher number of occurrences.
  • a user can insert a code or place-marker into a document in accordance with the present invention indicating that a search should be initiated to obtain a missing piece of information.
  • a user can type the phrase "Priceline.com issued @X airline tickets during 1998" into a document, with the @X code indicating that a piece of information is missing.
  • the present invention will automatically formulate a search using natural language techniques and obtain the desired data from the Internet. Thereafter, the user can utilize the search results to complete the missing information, or the present invention can automatically enter the found data.

Abstract

A method and apparatus are disclosed for cooperating with a first software program to perform a supplemental search over the Internet or another public network. A supplemental search is performed in the background to obtain desired information, while the user continues the primary task of creating, for example, a document. The user does not have to divert his or her attention from the primary task of creating the document to manually initiate a search. An illustrative word processing application program spawns a background thread in a multithreaded environment to perform the supplemental search using a browser, while the word processing application program maintains continuous control until the search results are obtained and viewed by the user. A supplemental search can be performed on a given topic (i) when requested by a user, or (ii) automatically, if a predefined condition, such as the occurrence of an apparently improper data element that fails to satisfy the requirements of a spelling or grammar database, is detected in a document of an application program. Thus, the invention can be configured to perform Internet-based spelling or grammar checking and automatically detect the adoption of new words or phrases and changes in acceptable grammar usage. In addition, the word processing application program automatically determines if a document being created corresponds to one or more predefined categories. If a document being created corresponds to a predefined category, the document can optionally be provided to an expert associated with said identified category for review.

Description

METHOD AND APPARATUS FOR PERFORMING SUPPLEMENTAL SEARCHES OVER A NETWORK
Field of the Invention
The present invention relates generally to tools for improving the efficiency of software programs, such as word processing programs and spreadsheet programs, and more particularly, to a method and apparatus for cooperating with such software programs to perform supplemental searches over the Internet or another public network.
Background of the Invention
Commercially available software programs, such as word processing programs and spreadsheet programs, include a number of features and tools that increase user efficiency. As such software programs have become more sophisticated with each new release, manual tasks have generally become more automated and utilization of the software has become easier. For example, the Microsoft Word™ word processing program from Microsoft Corporation of Redmond, WA includes an AutoCorrect feature that uses shortcuts to insert frequently used text and graphics and to automatically correct a number of frequent errors, such as the accidental usage of the "capitals lock" key on the keyboard.
Similarly, the AutoFormat feature in Microsoft Word™ works "in the background" (i.e., substantially separate from other functions of the program and/or absent interaction with the user) to automate a number of formatting tasks, while the user focuses on the document content. Specifically, the AutoFormat feature analyzes each paragraph to determine how the paragraph is used in a document. For example, the AutoFormat feature may determine whether a given paragraph is used as a heading or as an item in a numbered list. Thereafter, the AutoFormat feature applies a style that is appropriate for the identified item. In addition, the AutoFormat feature automatically formats Internet, network, and e-mail addresses as hyperlink addresses. There is a vast amount of information available on the World Wide Web
(the "Web") and other public networks. Anyone who is connected to the Internet and has a browser, such as Netscape Navigator Communicator™, commercially available from Netscape Communications Corporation of Mountain View, CA, can access information on the Web. Generally, to access desired information, a browser is used to access a web site with a known uniform resource locator ("URL") address directly, or to access a search engine, such as Yahoo!™ or Alta Vista™, that can identify other web sites containing relevant information. If the user accesses a search engine, the user enters keywords directing a search on a desired topic and the browser receives the search results from the search engine for presentation to the user. Generally, the search results comprise a set of hyperlinks pointing to web sites containing relevant information. While helpful information can often be found in this manner, the process can be quite slow.
Thus, a number of techniques have been proposed for improving the access time for Internet resources, from the user's point of view. Pre-fetching strategies, for example, attempt to load documents into a client application before the user has actually selected any of these documents for browsing. When a user selects a hyperlink in a currently viewed document, or identifies a document using a uniform resource locator ("URL") address, the addressed document may have already been prefetched and stored (e.g., cached) on or near the user's machine, thus reducing the document access time observed by the user. In addition, multitasking allows a user to run several programs simultaneously, which can each be viewed and managed by the user through a single graphical user interface (GUI). For example, a user can initiate an Internet search using a browser and then return to operating a word processing program in another window. Although both programs are open on the desktop simultaneously, and the user can switch between applications, the user only actively uses one program at a time). Specifically, the one program that is currently affected by user commands and data entry is deemed to be in the "foreground," while any other programs are in the background.
There is currently little, if any, integration between browsers and other commercially available software programs, such as word processing programs. Thus, if a user of a word processing program desires to obtain information from the Web for use in a document the user is creating, the user must divert his or her attention from the primary task of creating the document to manually initiate a search. Generally, the user must (i) suspend working in the word processing environment, (ii) ensure an active connection to the Internet, (iii) manually initiate the browser application and enter the search terms for the desired topic, and (iv) await the search results. After the search results are obtained and processed, the user must regain his or her train of thought and resume the primary task of creating the document. Thus, a need exists for a word processor that facilitates the supplemental searching performed by a user.
In addition, the spelling and grammar check features of conventional word processing programs have not been fully integrated with browsers and other Internet tools. Thus, the spelling and grammar check features suffer from a number of limitations, which, if overcome, could greatly increase the utility and efficiency of such features. Specifically, the spelling and grammar check features compare a document against a predefined database to identify improper usage. Since new words and phrases are continuously adopted and acceptable grammar usage will change over time, the predefined databases used by the spelling and grammar check features become quickly outdated. While conventional word processing programs often include a mechanism to allow users to update the spelling and grammar databases to reflect such changes, there is a need for spelling and grammar check tools that utilize a dynamic database that inherently reflects such changes in common usage.
Summary of the Invention
Generally, a method and apparatus are disclosed for cooperating with a software program, such as a word processing program or a spreadsheet program, to perform a supplemental search over the Internet or another public network. According to one aspect of the invention, a supplemental search is performed in the background over the Internet or another public network, to obtain desired information while the user continues the primary task of creating a document. In one implementation, an illustrative word processing application program spawns a background thread (corresponding to a process running in the background) in a multithreaded environment to perform the supplemental search using a browser while the word processing application program maintains continuous control until the search results are obtained and viewed by the user.
In one embodiment, a supplemental search can be performed on a given topic when requested by a user. Generally, the user selects a desired data element (e.g., one or more words) in a document and initiates a supplemental search of the data element, for example, by clicking on a toolbar icon, selecting a search command option from a menu or performing a predefined series of keystrokes. The supplemental search is launched in the background and the user continues working in the word processing application program until the search results are received. Thus, the user does not have to divert his or her attention from the primary task of creating the document to manually initiate a search.
In addition, a supplemental search can be performed automatically if a predefined condition is detected in a document of an application program. For example, a supplemental search can be performed to evaluate the usage of an apparently improper data element that fails to satisfy the requirements of a spelling or grammar database associated with the word processing application program. A supplemental search of an apparently improper data element can be launched automatically if the apparently improper data element appears more than a threshold number of times in a document. The supplemental usage search is launched in the background, transparent to the user, and the user continues working in the word processing application program until the search results are received. Thus, the present invention can be configured to perform Internet-based spelling or grammar checking.
Once the search results are received, the present invention determines if the apparently improper data element has been used more than a threshold number of times on remote servers accessed through the public network, such as the Internet. In this manner, the present invention automatically detects the adoption of new words or phrases and changes in acceptable grammar usage. If the apparently improper data element has been used more than a threshold number of times, the user can be queried to update the document to reflect the new usage. In addition, the static spelling or grammar databases associated with the word processing application program can optionally be dynamically updated to reflect such new words or phrases and changes in grammar usage as the content available on a public network changes and grows.
According to another aspect of the invention, the word processing application program automatically determines if a document being created corresponds to one or more predefined categories. If a document being created corresponds to a predefined category, the document can optionally be provided to an expert associated with said identified category for review. The results of the expert review are then provided to the user. The user can be required to guarantee payment for the expert review, for example, using a credit card or a prepaid account, or to otherwise prepay for the expert review. A particular expert can be identified, for example, by accessing a database indicating one or more experts for each predefined category, or by one or more designated experts, such as individuals having predefined qualifications.
A more complete understanding of the present invention, as well as further features and advantages of the present invention, will be obtained by reference to the following detailed description and drawings.
Brief Description of the Drawings
FIG. 1 is a schematic block diagram of a network environment in accordance with the present invention; FIG. 2 is a schematic block diagram of an illustrative user computing device of FIG. 1;
FIG. 3 is a sample table illustrating an exemplary process identifier (PID) database of FIG. 2;
FIGS. 4A through 4C, collectively, are a flow chart illustrating an exemplary word processing application program implemented by the user computing device of FIG. 2;
FIGS. 5A through 5E, collectively, are a flow chart illustrating an exemplary supplemental search process implemented by the user computing device of FIG. 2; and FIGS. 6A and 6B, collectively, are a flow chart illustrating an exemplary expert finder process implemented by the user computing device of FIG. 2. Detailed Description
FIG. 1 illustrates a network environment 100 in accordance with the present invention. The network environment 100 includes a user computing device 200, discussed below in conjunction with FIG. 2, that includes a Web browser 110 and an application program 400, such as a word processing program or a spreadsheet program. The present invention may be used in any environment where a user obtains Web resources from one or more remote servers, such as servers 150-1 through 150-N, over a publicly accessible network, such as the Internet 140. In the illustrative embodiment, the browser 110 cooperates with a proxy server 130 (or a firewall) of an Internet Service Provider ("ISP") to access the Internet or World Wide Web ("Web") environment 140 to obtain the Web resources from the remote servers 150-N. As discussed further below in conjunction with FIG. 2, the browser 1 10 and the application program 400 may be independent of each other, as shown in FIG. 1, or may be integrated, as would be apparent to a person of ordinary skill. Web resources are entities that can be requested from a remote server 150-N, including HTML documents, images, audio and video streams and applets.
According to one feature of the present invention, a user of the application program 400 can perform a supplemental search in the background over the Internet 140 or another public network, to obtain desired information, while the user continues the primary task of creating the document. In one implementation, the word processing application program 400 spawns a background thread in a multithreaded environment to perform the supplemental search using the browser 1 10, while the word processing application program 400 maintains continuous control until the search results are obtained and viewed by the user.
In one embodiment, the word processing application program 400 launches a supplemental search on a given data element when requested by a user. Generally, the user selects a desired data element in a document and initiates a supplemental search of the data element by clicking on a toolbar icon, selecting a search command option from a menu or performing a corresponding predefined series of keystrokes. The supplemental search is launched in the background and the user continues working in the word processing application program 400 until the search results are received. Thus, with the present invention, the user does not have to divert his or her attention from the primary task of creating the document to manually initiate a search. In a second embodiment of the present invention, the word processing application program 400 launches a supplemental search automatically, for example, to evaluate the usage of an apparently improper data element that fails to satisfy the requirements of a spelling or grammar database associated with the word processing application program 400. In one implementation, a supplemental search of an apparently improper data element is launched automatically if the apparently improper data element appears more than a threshold number of times in a document. The supplemental usage search is launched in the background, transparent to the user, and the user continues working in the word processing application program 400 until the search results are received. In this manner, the present invention can be configured to perform Internet-based spelling or grammar checking.
Once the search results are received, the present invention determines if the apparently improper data element has been used more than a threshold number of times on the remote servers 150-1 through 150-N accessed through the public network 140, such as the Internet. In this manner, the present invention automatically detects the adoption of new words and phrases and changes in acceptable grammar usage. If the apparently improper data element has been used more than a threshold number of times, the user can be queried to update the document to reflect the new usage, and the static spelling or grammar databases associated with the word processing application program 400 can optionally be updated. In a further variation, the supplemental searches for unrecognized words or terms can be batched and executed when the operating system detects that the word processing application program 400 has been inactive for more than an established threshold period of time.
While the accuracy of prior art spelling and grammar checking programs are limited by the size of the corresponding spelling and grammar databases, the accuracy of the present invention is limited only by the content available on the publicly accessible network, such as the Internet. With over sixty million Internet users worldwide, the data available from the Internet is exponentially more abundant and up- to-date than the data available in any static spelling or grammar database. Furthermore, the grammar and spelling usage of actual users more accurately reflects conventional usage, since it is taken from common use as opposed to an interpretation of common usage.
According to another feature of the present invention, the word processing application program 400 automatically determines if a document being created corresponds to one or more predefined categories. If a document being created does correspond to a predefined category, the document can optionally be provided to an expert associated with said identified category for review. For example, a document with repeated occurrences of the term "material evidence" or "modus operandi" may be categorized as a legal document. The results of the expert review are then provided to the user. As discussed further below, the expert can be contacted using the methods and apparatus disclosed, for example, in United States Patent Application Serial Number 09/112,131, entitled "Method and Apparatus for a Cryptographically Assisted Commercial Network System Designed to Facilitate and Support Expert-Based Commerce," assigned to the assignee of the present invention and incorporated by reference herein.
FIG. 2 is a block diagram showing the architecture of an illustrative user computing device 200. The user computing device 200 includes a central processing unit (CPU) 210 in communication with a data storage device 215, a read only memory (ROM) 220, a random access memory (RAM) 230, one or more input device(s) 240, one or more output device(s) 250, and a communications port 260. The CPU 210 can be in communication with the data storage device 215, the read only memory (ROM) 220, the random access memory (RAM) 230, the input device(s) 240, the output device(s) 250 and the communications port 260, by means of a shared data bus or dedicated connections, as shown in FIG. 2.
The input device 240 may be embodied, for example, as one or more of a keyboard, mouse, joystick and optical scanner. The output device 250 may be embodied, for example, as one or more of a display, a printer, network interface card (NIC) and an audio output. The communications port 260 connects the user computing device 200 to the public network, such as the Internet 140. The communication port 260 may include multiple communication channels for simultaneous communication with more than one remote terminal and/or server.
As previously indicated, the data storage device 215 includes a browser 110 and an application program 400, discussed further below in conjunction with FIGS. 4A through 4C. The browser 110 may be embodied, for example, as Netscape Navigator ™, commercially available from Netscape Communications Corporation of Mountain View, CA, as modified to configure the browser 110 for a proxy by going, for example, to Edit/Preferences/ Advanced/Proxies. In the illustrative embodiment, the application program 400 is embodied as a word processing application, such as Microsoft Word™ commercially available from Microsoft Corporation of Redmond, WA, as modified herein to incorporate features and functions of the present invention.
As shown in FIG. 2, the word processing application program 400 includes a conventional spell check program 270 and related spelling database, and a conventional grammar check program 280 and related grammar database. As discussed below in conjunction with FIGS. 4 A through 4C, the spelling database or the grammar database may be updated by the present invention to reflect a new usage as determined by an Internet search. In addition, as discussed further below in conjunction with FIGS. 5 A through 5E, the data storage device 215 includes a dispatch thread message queue 290 for sending messages to a dispatch thread manager in the multithreaded environment of the present invention, and an inter-process communication (IPC) message queue 295 for sending IPC messages between processes in accordance with the present invention.
As discussed further below in conjunction with FIG. 3, the data storage device 215 also includes a process identifier (PID) database 300 that stores information on each process created by the operating system. In addition, the data storage device 215 and/or ROM 220 are operable to store one or more programs that the CPU 210 is operable to retrieve, interpret and execute. As shown in FIG. 2 and discussed further below in conjunction with FIGS. 5A through 5E and FIGS. 6A and 6B, respectively, the data storage device 215 also includes a supplemental search process 500 and an expert finder process 600. The word processing application program 400, together with the supplemental search process 500, or the expert finder process 600, directs the CPU 210 to operate in accordance with the present invention, and particularly in accordance with the methods described in detail herein.
Generally, the word processing application program 400 directs the CPU 210 to launch the supplemental search process 500 (i) when a supplemental search is requested by a user on a given topic, or (ii) automatically, to evaluate the usage of an apparently improper data element that fails to satisfy the requirements of the spelling or grammar databases 270, 280. The expert finder process 600 runs in the background to automatically determine if a document being created corresponds to one or more predefined categories, and, if so, to optionally provide the document to an expert in said identified category for review.
The word processing application program 400, the supplemental search process 500, and/or the expert finder process 600 may each include program elements that may be necessary, such as "device drivers" for allowing the CPU 210 to interface, for example, with the output device 250 and other computer peripheral devices (not shown). Appropriate device drivers and other necessary program elements are known to those skilled in the art, and need not be described in detail herein.
As will be understood by those skilled in the art, the schematic illustration and accompanying description of the process identifier (PID) database 300 presented herein is an exemplary arrangement for stored representations of information to illustrate the principles of the invention. A number of other arrangements and informational content may be employed, as would be apparent to a person of ordinary skill in the art.
As shown in FIG. 3, the process identifier (PID) database 300 typically includes a plurality of records, such as records 305, 310, 315, 320 and 325, each associated with a different active process. For each active process identified by a PID in field 330, the process identifier (PID) database 300 includes a description of the process type in field 335, a task in field 340 and an identification of the assigned memory segment in field 345. For example, records 310 and 325 correspond to two versions of a browser program 1 10 that have been created by the operating system in accordance with the present invention. The version of the browser program 1 10 associated with record 310 corresponds to a first "data searching" embodiment of the invention, where the user has initiated a search on a specified data element. The version of the browser program 1 10 associated with record 325 corresponds to a second "evaluate usage" embodiment of the invention, where a supplemental search is performed automatically to determine the number of occurrences on the Internet of an apparently misspelled term.
As previously indicated, the word processing application program 400, shown in FIG. 4, launches the supplemental search process 500 (FIGS. 5A through 5E) (i) when a supplemental search is requested by a user on a given topic, or (ii) automatically, to evaluate the usage of an apparently improper data element that fails to satisfy the requirements of the spelling or grammar databases 270, 280 or another set of conditions. In addition, the word processing application program 400 processes the results of the supplemental search that are returned by the browser 110.
As shown in FIG. 4A, the word processing application program 400 is generally launched during step 403 when a user starts or executes the word processing application program 400. A test is performed during step 406 to determine if a version of the application is already running. If it is determined during step 406 that a version of the application is not already running, then the application must create a version of the application and requests a process identifier during step 409 from the operating system. The application is assigned a process identifier during step 412, and the operating system records the process identifier in the process identifier (PID) database 300. The application then requests and is allocated a memory segment during step 415. The memory segment allocation is likewise recorded in the process identifier (PID) database 300. The application goes through an initialization phase during step 418, such as resetting counters, zeroing out memory and resetting variable values, before starting a dispatcher thread manager.
If, however, it is determined during step 406 that that a version of the application is already running, then the application requests the focus from the operating system (i.e., requests to be brought to the foreground) during step 421. Thus, the application that was just started (or was already running) is now the active window. The word processing application program 400 then enters a sleep state during step 424 until it is detected during step 427 that the user has requested the attention of the application with a keystroke or mouse event. In this manner, the application program 400 does not waste system resources by unnecessarily taking CPU cycles away from other applications. Once a keystroke or mouse event is detected during step 427, the event will be trapped and acted upon.
The user request associated with the keystroke or mouse event, or an operating system request associated with an operating system message is then handled during step 430 (FIG. 4B). The user request processed during step 430 may be, for example, to display characters on the screen, to save a file, to copy and paste data, to find or replace text, or to print or preview a document. The processing of user or operating system requests associated with the present invention are shown in FIGS. 4B and 4C.
As shown in FIG. 4B, a test is performed during step 433 to determine if the user request consists of the highlighting of text by the user. If it is determined during step 433 that the user request does not consist of highlighting text, then processing continues in a conventional manner during step 435. If, however, it is determined during step 433 that the user request does consist of highlighting text, then the user is notified during step 436 of the various actions that are possible on selected text. It is noted that a user may select text, for example, by holding down the shift key and moving the arrow to cover the desired text, or holding down the left mouse button and moving the mouse to highlight the desired text.
A test is performed during step 439 to determine if the selected action is data searching in accordance with the present invention. It is noted that the user can click on the "data searching" option with the left mouse button, or can move up or down the list of various actions until the "data searching" option is highlighted and then depress the enter key. If it is determined during step 439 that the selected action is not data searching, then processing continues in a conventional manner during step 435. If, however, it is determined during step 439 that the selected action is data searching, then a task variable is set to "data searching" during step 442. According to a feature of the present invention, the word processing application program 400 will then utilize multithreading technology to return control of the word processing application program 400 to the user at step 424, while simultaneously spawning a background thread to handle the "data searching" task performed by the supplemental search process 500. Thus, as shown in FIG. 4B, the word processing application program 400 launches the supplemental search process 500 during step 445, while simultaneously returning control of the word processing application program 400 to step 424.
As shown in FIG. 4B, another test is periodically performed in the background during step 450 to determine if there is a data element in the document that does not match the correct usage requirements indicated in either the spelling or grammar databases associated with the word processing application program 400. If it is determined during step 450 that all the data elements in the document match the correct usage requirements indicated in either the spelling or grammar databases, then processing continues in a conventional manner during step 435.
If, however, it is determined during step 450 that a data element in the document does not match the correct usage requirements indicated in either the spelling or grammar databases, then a further test is performed during step 453 to determine if the number of occurrences of the apparently improper data element in the document exceed a predefined threshold. It is noted that the threshold acts as a filter that may be predefined or specified by the user to prevent a supplemental search from being performed unnecessarily. In this manner, the threshold can be set relatively high, to eliminate hypersensitivity and to allow for a more conservative use of language in a document. Likewise, the thresholds can be set low, such as one occurrence, to perform a supplemental search on any data element that does not satisfy the requirements of the spelling or grammar checking programs.
In addition, the thresholds can be dynamically established based upon the user's skill and accuracy as a speller or writer. For example, a user making many errors that are detected and corrected by the spelling or grammar checking programs might establish high thresholds to avoid unnecessary supplemental searches on the Internet for words that are likely misspelled. The word processing application program 400 may also be configured such that only words with the ".com" extension are searched over the Internet. In a further variation, the word processing application program 400 can detect the over-use of a word or term such that the supplemental search accesses a thesaurus to identify words with similar meanings. If it is determined during step 453 that the number of occurrences of the data element in the document does not exceed the predefined threshold, then processing continues in a conventional manner during step 435. If, however, it is determined during step 453 that the number of occurrences of the data element in the document exceed the predefined threshold, then the task variable is set to "evaluate usage" during step 456. Thereafter, the word processing application program 400 will utilize multithreading technology to return control of the word processing application program 400 to the user at step 424, while simultaneously spawning a background thread to handle the "evaluate usage" task performed by the supplemental search process 500. Thus, as shown in FIG. 4B, the word processing application program 400 launches the supplemental search process 500 during step 445, while simultaneously returning control of the word processing application program 400 to step 424. For example, if a data element is apparently misspelled in the document, the supplemental search process 500 will determine the number of occurrences of the same apparent misspelling on the Internet. The operation of the supplemental search process 500 will be discussed below in conjunction with FIGS. 5A through 5E. After the supplemental search process 500 has completed either the "data searching" or "evaluate usage" tasks, the word processing application program 400 must process the results. Thus, as shown in FIG. 4C, the word processing application program 400 will periodically perform a test during step 460 to determine if the word processing application program 400 has received any task completion messages from the supplemental search process 500. If it is determined during step 460 that no task completion messages have been received, then program control will return to step 424 (FIG. 4A).
If, however, it is determined during step 460 that a task completion message has been received from the supplemental search process 500, then a further test is performed during step 463 to determine if the task associated with the message is a "data search" task. If it is determined during step 463 that the task associated with the message is a "data search" task, then the user is notified of the search status during step 466. For example, the word processing application program 400 can display a "popup" window (or dialog box) or a status indicator on the status bar or a toolbar to the user. A test is performed during step 469 to determine if the user activates the search results, for example, by clicking on the "view results" button in a "pop-up" window or clicking on a corresponding icon in the toolbar. If it is determined during step 469 that the user has not yet activated the search results, then the word processing application program 400 will wait during step 472 until the user activates the results. If, however, it is determined during step 469 that the user has activated the search results, then the user is presented with the data returned by the browser program 1 10 during step 475, before program control returns to step 424 (FIG. 4A).
If, however, it is determined during step 463 that the task associated with the message is a not "data search" task, then a further test is performed during step 480 to determine if the task associated with the message is an "evaluate usage" task. If it is determined during step 480 that the task associated with the message is not an "evaluate usage" task, then an unknown task completion message has been received and an error message is passed to an eπor handling routine during step 483, which will notify the user of the problem. If, however, it is determined during step 480 that the task associated with the message is an "evaluate usage" task, then a further test is performed during step 486 to determine if the search results indicate that the apparently incorrect data element has been used on the Internet more than a threshold number of times. If it is determined during step 486 that the results do not exceed the predefined threshold, then program control returns to step 424 (FIG. 4A).
If, however, it is determined during step 486 that the results do exceed the predefined threshold, then the appropriate spelling or grammar database is optionally updated during step 489, and the user is queried during step 492 to determine if one or more of the instances of the data element should be updated in the document. Thereafter, program control returns to step 424 (FIG. 4A). As previously indicated, the word processing application program 400, shown in FIG. 4, launches the supplemental search process 500, shown in FIGS. 5A through 5E, (i) when a supplemental search is requested by a user on a given topic, or (ii) automatically, to evaluate the usage of an apparently improper data element that fails to satisfy the requirements of the spelling or grammar databases 270, 280. As shown in FIG. 5A, the word processing application program 400 initially sends a message to the dispatcher thread manager during step 502 to make the dispatcher thread manager aware of a new task that needs attention. The message is placed in the dispatcher thread message queue 290 (FIG. 2) during step 504. In this manner, the word processing application program 400 can queue up requests for the dispatcher thread manager and the dispatcher thread manager can take requests, for example, using a first-in-first-out (FIFO) protocol.
A test is performed during step 506 to determine if the message is retrieved from the queue 290 by the dispatcher thread manager. If it is determined during step 506 that the message is not retrieved by the dispatcher thread manager, then the word processing application program 400 contacts the operating system during step 508 to verify the existence of the dispatcher thread manager. The operating system performs a test during step 510 to determine if the dispatcher thread manager exists. If it is determined during step 510 that the dispatcher thread manager does exist, then the dispatcher thread manager must be in a run-away state and the operating system locates the thread identifier to destroy the dispatch thread during step 512. If, however, it is determined during step 510 that the dispatcher thread manager does not exist, then the application 400 contacts the operating system to start the creation of a new thread during step 514. A new dispatcher thread manager is created during step 516 and released to the application for use.
Thereafter, the dispatcher thread manager reads the message in the queue during step 518 and determines what task to perform. A test is performed by the dispatcher thread manager during step 520 (FIG. 5B) to determine if a worker thread is available. If it is determined during step 520 that a worker thread is not available, then the dispatcher thread manager requests a thread from the operating system during step 522, records the thread identifier and releases the thread during step 524. If, however, it is determined during step 520 that a worker thread is already available (or after creation and release of a thread during steps 522 and 524), then the dispatcher thread manager forwards the message received from the application
400 to the worker thread during step 526. The worker thread reads the message during step 528.
A test is performed by the worker thread during step 530 to determine if the libraries required to complete the designated task are available. If it is determined during step 530 that all the libraries required to complete the designated task are not available, then the worker thread determines which libraries are needed during step 532, and loads the libraries into the shared memory pool during step 534.
If it is determined during step 530 that all the libraries required to complete the designated task are available (or after the appropriate libraries have been loaded during steps 532 and 534), then the browser program 110 is spawned during step 536 (FIG. 5C). The worker thread performs a test during step 538 to determine if the browser program 110 is successfully spawned. For example, if the worker thread cannot record the process identifier of the browser, then the spawning process has likely failed.
If it is determined during step 538 that the browser program 110 has not been successfully spawned, then the worker thread can attempt to spawn the browser again, until a maximum number of retries is detected during step 540. If it is determined during step 540 that the maximum number of retries has been attempted, then the result is passed to an error handling routine during step 542, and the user and application 400 are notified of the error during step 544.
If it is determined during step 538 that the browser program 110 has been successfully spawned, then the worker thread forwards the message received from the dispatcher thread manager to the browser program 110 during step 546, using interprocess communication (IPC) techniques. Thus, the message is placed in the IPC message queue 295 during step 548. The message may indicate the search term to the browser program 110, for example, in the form of a well-known binary query. It is noted that searching performed by the browser 1 10 can be geographically restricted to account for different languages and dialects. The worker thread periodically checks the IPC queue 295 during steps 550 through 554 to ensure that messages are picked up by the appropriate processes. Thus, a test is performed during step 550 to determine if messages are picked up from the IPC queue 295. If it is determined during step 552 that a message is not picked up from the queue 295 within a predefined period of time, then the message is removed from the queue during step 556 and the result is passed to an error handling routine for notification of the user and application 400 during step 558.
If, however, it is determined during step 550 that messages are picked up from the IPC queue 295, then the worker thread will wait during step 560 until the browser program 110 triggers an event to "awaken" the worker thread. In other words, the worker thread checks the message queue for new messages. If the worker thread finds a new message, the worker thread will act on it. Otherwise, the worker thread goes into a sleep state until a new message indicating that the browser program has completed its task is received. Thus, a test is performed during step 562 to determine if the worker thread detects a wake event (task completion message). Once it is determined during step 562 that a task completion message is received from the browser program, the worker thread is notified during step 564. The browser places the task completion message in the worker thread queue with the browser's PID, so that a particular worker thread can determine what task was requested of the browser program by doing a PID data lookup to see what information was recorded before the spawning process for this particular task.
The worker thread verifies the integrity of the data in the task completion message and places the task completion message in the dispatcher thread message queue 290 during step 568, to notify of the task completion. If the message is not picked up within a predefined period of time, then the message is re-queued. If after a predefined number of retries, the message is not retrieved from the message queue, then the worker thread must pass an error message to the error handling routine for reporting to the user and application process 400. The message is retrieved by the dispatcher thread manager during step
570, and the dispatcher thread manager reads the message during step 572 (FIG. 5E). The dispatcher thread manager notifies the word processing application program 400 of the task completion message during step 574, with an indication of the requested task. Finally, the dispatcher thread manager places a message into the worker thread queue during step 576 to terminate the browser program 110 associated with the completed task. The worker thread uses the recorded PID to identify and then terminate the appropriate browser program 110. The worker thread sends a message to the operating system to terminate the browser program and reclaim the associated resources, such as memory and CPU cycles. Program control of the supplemental search process 500 terminates during step 580. As previously indicated, the expert finder process 600, shown in FIGS.
6A and 6B, runs in the background to automatically determine if a document being created corresponds to one or more predefined categories, and, if so, to optionally provide the document to an expert in said identified category for review. The expert finder process 600 may be executed periodically, or intermittently, for example, each time a document is saved or printed. The expert can be contacted using the methods and apparatus disclosed, for example, in United States Patent Application Serial Number 09/112,131, entitled "Method and Apparatus for a Cryptographically Assisted Commercial Network System Designed to Facilitate and Support Expert-Based Commerce," filed July 8, 1998 and assigned to the assignee of the present invention and incorporated by reference herein.
As shown in FIG. 6A, the expert finder process 600 initially identifies one or more data elements occurring frequently in a document the user is creating. A test is performed during step 615 to determine if the data element occurs in the document more than a threshold number of times. If it is determined during step 615 that the data element does not occur more than a threshold number of times, then processing continues conventionally during step 620.
If, however, it is determined during step 615 that the data element does occur more than a threshold number of times, then a further test is performed during step 625 to determine if there is an appropriate expert in an expert index (not shown) corresponding to the topic associated with the identified data element. If it is determined during step 625 that there is no appropriate expert, then processing continues conventionally during step 620.
If, however, it is determined during step 625 that there is an appropriate expert, then the user is given the option during step 630 to provide the document to the identified expert. A further test is then performed during step 635 to determine if the users selects the expert help option. If it is determined during step 635 that the users does not select the expert help option, then processing continues conventionally during step 620.
If, however, it is determined during step 635 that the user does select the expert help option, then the document is saved during step 640 (FIG. 6B). The document is then transmitted to a remote server associated with the expert by means of the communication port 260 during step 645. After the expert review is complete, the document including the expert's suggestions is then received during step 650 by means of the communication port 260. Finally, an output signal is provided to the user during step 655 indicating that the expert suggestions are available for review, before program control terminates.
In a further variation, the present invention can be utilized to compare the relative usage of two terms on the Internet. For example, the user can initiate a search performed in the background in accordance with the present invention that returns the number of occurrences of the word "colour" versus the number of occurrences of the word "color." Thereafter, the user can utilize the search results to select one of the words, or the present invention can automatically select the word with the higher number of occurrences. In another variation, a user can insert a code or place-marker into a document in accordance with the present invention indicating that a search should be initiated to obtain a missing piece of information. For example, a user can type the phrase "Priceline.com issued @X airline tickets during 1998" into a document, with the @X code indicating that a piece of information is missing. The present invention will automatically formulate a search using natural language techniques and obtain the desired data from the Internet. Thereafter, the user can utilize the search results to complete the missing information, or the present invention can automatically enter the found data.
It is to be understood that the embodiments and variations shown and described herein are merely illustrative of the principles of this invention and that various modifications may be implemented by those skilled in the art without departing from the scope and spirit of the invention. For example, there are other ways to indicate data elements besides highlighting the data element.

Claims

We claim:
1. A method for searching a database, comprising the steps of: receiving a command from a user of a first application program to initiate a search of a selected search term, said search being performed on said database; initiating said search using a search tool responsive to said received command without preempting said first application program; and providing access to results of said search to said user.
2. The method according to claim 1 , wherein said search tool is a browser.
3. The method according to claim 1 , wherein said first application program executes on a first thread in a multithreaded environment and said search tool executes on a background thread.
4. The method according to claim 1 , wherein said first application program is a word processing program.
5. The method according to claim 1 , wherein said first application program is a spreadsheet program.
6. The method according to claim 1 , wherein said first application program is a database management program.
7. The method according to claim 1 , wherein said search is performed on the Internet.
8. The method according to claim 1 , wherein said search is performed on a proprietary network.
9. The method according to claim 1 , wherein said search is performed on a dedicated database.
10. The method according to claim 1, wherein said search is performed on a publicly accessible database.
11. The method according to claim 1, wherein said user is notified of said search results by means of a dialog box.
12. The method according to claim 1, wherein said user is notified of said search results by means of an icon presented on a toolbar.
13. A method for searching a database, comprising the steps of: receiving a command from a user of a first application program to initiate a search of a selected search term, said search being performed on said database using a search tool; initiating said search using a background thread using said search tool responsive to said received command while said first application program maintains control; and providing access to results of said search to said user.
14. The method according to claim 13, wherein said search tool is a browser.
15. The method according to claim 13, wherein said first application program executes on a first thread in a multithreaded environment and said search tool executes on a background thread.
16. The method according to claim 13, wherein said first application program is selected from the group consisting essentially of a word processing program, a spreadsheet program and a database management program.
17. The method according to claim 13, wherein said search is performed on a publicly accessible database.
18. The method according to claim 13, wherein said user is notified of said search results by means of a dialog box.
19. The method according to claim 13, wherein said user is notified of said search results by means of an icon presented on a toolbar.
20. A system for searching a database, comprising: a memory for storing computer-readable code; and a processor operatively coupled to said memory, said processor configured to: receive a command from a user of a first application program to initiate a search of a selected search term, said search being performed on said database; initiate said search using a search tool responsive to said received command without preempting said first application program; and provide access to results of said search to said user.
21. A system for searching a database, comprising: a memory for storing computer-readable code; and a processor operatively coupled to said memory, said processor configured to: receive a command from a user of a first application program to initiate a search of a selected search term, said search being performed on said database using a search tool; initiate said search using a background thread using said search tool responsive to said received command while said first application program maintains control; and provide access to results of said search to said user.
22. A method for searching a database, comprising the steps of: selecting a search term in a document of a first application program; initiating a search of said search term using a search tool, while continuing to work in said document while said search is performed; and receiving access to results of said search.
23. The method according to claim 22, wherein said search tool is a browser.
24. The method according to claim 22, wherein said first application program executes on a first thread in a multithreaded environment and said search tool executes on a background thread.
25. The method according to claim 22, wherein said first application program is selected from the group consisting essentially of a word processing program, a spreadsheet program and a database management program.
26. The method according to claim 22, wherein said search is performed on a publicly accessible database.
27. The method according to claim 22, wherein said receiving step comprises the step of being notified of said search results by means of a dialog box.
28. The method according to claim 22, wherein said receiving step comprises the step of being notified of said search results by means of an icon presented on a toolbar.
29. A method for searching a database, comprising the steps of: selecting a search term in a document of a first application program; initiating a search of said search term using a search tool, while said first application program maintains control; and receiving access to results of said search.
30. The method according to claim 29, wherein said search tool is a browser.
31. The method according to claim 29, wherein said first application program executes on a first thread in a multithreaded environment and said search tool executes on a background thread.
32. The method according to claim 29, wherein said first application program is selected from the group consisting essentially of a word processing program, a spreadsheet program and a database management program.
33. The method according to claim 29, wherein said search is performed on a publicly accessible database.
34. The method according to claim 29, wherein said receiving step comprises the step of being notified of said search results by means of a dialog box.
35. The method according to claim 29, wherein said receiving step comprises the step of being notified of said search results by means of an icon presented on a toolbar.
36. A method for searching a database, comprising the steps of: determining if a predefined condition has occurred in a first application program; initiating a search in said database responsive to said predefined condition using a search tool without preempting said first application program; and providing access to results of said search to said user.
37. The method according to claim 36, wherein said predefined condition is the occurrence of a data element in a document at least a predefined number of times.
38. The method according to claim 37, wherein said data element is an apparently misspelled term.
39. The method according to claim 38, further comprising the step of updating a spelling dictionary with the apparently misspelled term if said search results detect the occurrence of said apparently misspelled term a predefined number of times.
40. The method according to claim 38, further comprising the step of determining if said user wishes to update said apparently misspelled term in said document.
41. The method according to claim 37, wherein said predefined number of times can be set by said user.
42. The method according to claim 37, wherein said data element is the occurrence of an apparent grammatical error.
43. The method according to claim 42, further comprising the step of updating a grammar database to reflect the apparent grammatical error if said search results detect the occurrence of said apparent grammatical error a predefined number of times.
44. The method according to claim 42, further comprising the step of determining if said user wishes to update said apparent grammatical error in said document.
45. The method according to claim 36, wherein said search is performed on a thesaurus database containing similar terms to said data element.
46. The method according to claim 36, wherein said search tool is a browser.
47. The method according to claim 36, wherein said first application program executes on a first thread in a multithreaded environment and said search tool executes on a background thread.
48. The method according to claim 36, wherein said first application program is selected from the group consisting essentially of a word processing program, a spreadsheet program and a database management program.
49. The method according to claim 36, wherein said search is performed on a publicly accessible database.
50. The method according to claim 36, wherein said user is notified of said search results by means of a dialog box.
51. The method according to claim 36, wherein said user is notified of said search results by means of an icon presented on a toolbar.
52. A method for searching a database, comprising the steps of: determining if a predefined condition has occurred in a first application program; initiating a search responsive to said predefined condition using a search tool executing on a background thread while said first application program maintains control; and providing access to results of said search to said user.
53. The method according to claim 52, wherein said predefined condition is the occurrence of a data element in a document at least a predefined number of times.
54. The method according to claim 53, wherein said data element is an apparently misspelled term.
55. The method according to claim 54, further comprising the step of updating a spelling dictionary with the apparently misspelled term if said search results detect the occuπence of said apparently misspelled term a predefined number of times.
56. The method according to claim 54, further comprising the step of determining if said user wishes to update said apparently misspelled term in said document.
57. The method according to claim 53, wherein said predefined number of times can be set by said user.
58. The method according to claim 53, wherein said data element is the occurrence of an apparent grammatical error.
59. The method according to claim 58, further comprising the step of updating a grammar database to reflect the apparent grammatical error if said search results detect the occurrence of said apparent grammatical error a predefined number of times.
60. The method according to claim 58, further comprising the step of determining if said user wishes to update said apparent grammatical error in said document.
61. The method according to claim 52, wherein said search is performed on a thesaurus database containing similar terms to said data element.
62. The method according to claim 52, wherein said search tool is a browser.
63. The method according to claim 52, wherein said first application program executes on a first thread in a multithreaded environment and said search tool executes on a background thread.
64. The method according to claim 52, wherein said first application program is selected from the group consisting essentially of a word processing program, a spreadsheet program and a database management program.
65. The method according to claim 52, wherein said search is performed on a publicly accessible database.
66. The method according to claim 52, wherein said user is notified of said search results by means of a dialog box.
67. The method according to claim 52, wherein said user is notified of said search results by means of an icon presented on a toolbar.
68. A system for searching a database, comprising: a memory for storing computer-readable code; and a processor operatively coupled to said memory, said processor configured to: determine if a predefined condition has occurred in a first application program; initiate a search in said database responsive to said predefined condition using a search tool without preempting said first application program; and provide access to results of said search to said user.
69. A system for searching a database, comprising: a memory for storing computer-readable code; and a processor operatively coupled to said memory, said processor configured to: determine if a predefined condition has occuπed in a first application program; initiate a search responsive to said predefined condition using a search tool executing on a background thread while said first application program maintains control; and provide access to results of said search to said user.
70. A method for searching a database, comprising the steps of: determining if a document of a first application program is related to one or more predefined categories; providing said document to an expert of said category for review; and providing results of said review to a user.
71. The method according to claim 70, wherein said providing step requires the approval of said user.
72. The method according to claim 70, further comprising the step of guaranteeing payment to said expert for reviewing said document.
73. The method according to claim 70, further comprising the step of requiring said user to guarantee payment of said expert.
74. The method according to claim 70, further comprising the step of requiring said user to prepay for said expert review.
75. The method according to claim 70, wherein said expert is identified by accessing a database indicating one or more experts for each of said predefined categories.
76. The method according to claim 70, wherein said expert is identified by one or more additional experts.
71. A system for searching a database, comprising: a memory for storing computer-readable code; and a processor operatively coupled to said memory, said processor configured to: determine if a document of a first application program is related to one or more predefined categories; provide said document to an expert of said category for review; and provide results of said review to a user.
72. An article of manufacture comprising: a computer readable medium having computer readable code means embodied thereon, said computer readable program code means comprising: a step to receive a command from a user of a first application program to initiate a search of a selected search term, said search being performed on said database; a step to initiate said search using a search tool responsive to said received command without preempting said first application program; and a step to provide access to results of said search to said user.
73. An article of manufacture comprising: a computer readable medium having computer readable code means embodied thereon, said computer readable program code means comprising: a step to receive a command from a user of a first application program to initiate a search of a selected search term, said search being performed on said database using a search tool; a step to initiate said search using a background thread using said search tool responsive to said received command while said first application program maintains control; and a step to provide access to results of said search to said user.
74. An article of manufacture comprising: a computer readable medium having computer readable code means embodied thereon, said computer readable program code means comprising: a step to determine if a predefined condition has occurred in a first application program; a step to initiate a search in said database responsive to said predefined condition using a search tool without preempting said first application program; and a step to provide access to results of said search to said user.
75. An article of manufacture comprising: a computer readable medium having computer readable code means embodied thereon, said computer readable program code means comprising: a step to determine if a predefined condition has occurred in a first application program; a step to initiate a search responsive to said predefined condition using a search tool executing on a background thread while said first application program maintains control; and a step to provide access to results of said search to said user.
76. An article of manufacture comprising: a computer readable medium having computer readable code means embodied thereon, said computer readable program code means comprising: a step to determine if a document of a first application program is related to one or more predefined categories; a step to provide said document to an expert of said category for review; and a step to provide results of said review to a user.
PCT/US1999/027776 1998-12-31 1999-11-23 Method and apparatus for performing supplemental searches over a network WO2000041095A2 (en)

Priority Applications (1)

Application Number Priority Date Filing Date Title
AU21553/00A AU2155300A (en) 1998-12-31 1999-11-23 Method and apparatus for performing supplemental searches over a network

Applications Claiming Priority (2)

Application Number Priority Date Filing Date Title
US09/223,899 US6349295B1 (en) 1998-12-31 1998-12-31 Method and apparatus for performing supplemental searches over a network
US09/223,899 1998-12-31

Publications (2)

Publication Number Publication Date
WO2000041095A2 true WO2000041095A2 (en) 2000-07-13
WO2000041095A3 WO2000041095A3 (en) 2001-02-08

Family

ID=22838436

Family Applications (1)

Application Number Title Priority Date Filing Date
PCT/US1999/027776 WO2000041095A2 (en) 1998-12-31 1999-11-23 Method and apparatus for performing supplemental searches over a network

Country Status (3)

Country Link
US (1) US6349295B1 (en)
AU (1) AU2155300A (en)
WO (1) WO2000041095A2 (en)

Cited By (2)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US8549436B1 (en) 2007-06-04 2013-10-01 RedZ, Inc. Visual web search interface
WO2019118150A1 (en) * 2017-12-13 2019-06-20 Microsoft Technology Licensing, Llc Enhanced processing and communication of file content for analysis

Families Citing this family (100)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US6735585B1 (en) * 1998-08-17 2004-05-11 Altavista Company Method for search engine generating supplemented search not included in conventional search result identifying entity data related to portion of located web page
US6519594B1 (en) * 1998-11-14 2003-02-11 Sony Electronics, Inc. Computer-implemented sharing of java classes for increased memory efficiency and communication method
US6922708B1 (en) 1999-02-18 2005-07-26 Oracle International Corporation File system that supports transactions
US6549916B1 (en) 1999-08-05 2003-04-15 Oracle Corporation Event notification system tied to a file system
US7418435B1 (en) 1999-08-05 2008-08-26 Oracle International Corporation Multi-model access to data
US7280995B1 (en) 1999-08-05 2007-10-09 Oracle International Corporation On-the-fly format conversion
US7000194B1 (en) * 1999-09-22 2006-02-14 International Business Machines Corporation Method and system for profiling users based on their relationships with content topics
US8478732B1 (en) * 2000-05-02 2013-07-02 International Business Machines Corporation Database aliasing in information access system
US6704728B1 (en) 2000-05-02 2004-03-09 Iphase.Com, Inc. Accessing information from a collection of data
US6711561B1 (en) * 2000-05-02 2004-03-23 Iphrase.Com, Inc. Prose feedback in information access system
US7752275B2 (en) * 2000-05-04 2010-07-06 At&T Intellectual Property I, L.P. Method and apparatus for configuring electronic mail for delivery of electronic services
US7016937B1 (en) * 2000-05-04 2006-03-21 Bellsouth Intellectual Property Corporation Method and apparatus for generating reminders to transmit electronic mail attachments by parsing e-mail message text
US7007066B1 (en) 2000-05-04 2006-02-28 Bellsouth Intellectual Property Corp. Method and apparatus for configuring electronic mail according to a user-selected type
US7185005B1 (en) 2000-05-12 2007-02-27 Oracle International Corporation Nested transactions in a file system
US7770102B1 (en) 2000-06-06 2010-08-03 Microsoft Corporation Method and system for semantically labeling strings and providing actions based on semantically labeled strings
US7788602B2 (en) * 2000-06-06 2010-08-31 Microsoft Corporation Method and system for providing restricted actions for recognized semantic categories
US7712024B2 (en) 2000-06-06 2010-05-04 Microsoft Corporation Application program interfaces for semantically labeling strings and providing actions based on semantically labeled strings
US7451389B2 (en) 2000-06-06 2008-11-11 Microsoft Corporation Method and system for semantically labeling data and providing actions based on semantically labeled data
US7716163B2 (en) * 2000-06-06 2010-05-11 Microsoft Corporation Method and system for defining semantic categories and actions
US6408277B1 (en) 2000-06-21 2002-06-18 Banter Limited System and method for automatic task prioritization
US9699129B1 (en) 2000-06-21 2017-07-04 International Business Machines Corporation System and method for increasing email productivity
US8290768B1 (en) 2000-06-21 2012-10-16 International Business Machines Corporation System and method for determining a set of attributes based on content of communications
US6799198B1 (en) * 2000-06-23 2004-09-28 Nortel Networks Limited Method and apparatus for providing user specific web-based help in a distributed system environment
US7668740B1 (en) * 2000-09-22 2010-02-23 Ita Software, Inc. Method, system, and computer program product for interfacing with information sources
US7058648B1 (en) 2000-12-01 2006-06-06 Oracle International Corporation Hierarchy-based secured document repository
US7644057B2 (en) * 2001-01-03 2010-01-05 International Business Machines Corporation System and method for electronic communication management
US7136846B2 (en) 2001-04-06 2006-11-14 2005 Keel Company, Inc. Wireless information retrieval
US7778816B2 (en) * 2001-04-24 2010-08-17 Microsoft Corporation Method and system for applying input mode bias
US7308439B2 (en) 2001-06-06 2007-12-11 Hyperthink Llc Methods and systems for user activated automated searching
US7249034B2 (en) * 2002-01-14 2007-07-24 International Business Machines Corporation System and method for publishing a person's affinities
US7343372B2 (en) * 2002-02-22 2008-03-11 International Business Machines Corporation Direct navigation for information retrieval
US20050108195A1 (en) * 2002-05-07 2005-05-19 Microsoft Corporation Method, system, and apparatus for processing information based on the discovery of semantically labeled strings
US7707496B1 (en) 2002-05-09 2010-04-27 Microsoft Corporation Method, system, and apparatus for converting dates between calendars and languages based upon semantically labeled strings
US7707024B2 (en) * 2002-05-23 2010-04-27 Microsoft Corporation Method, system, and apparatus for converting currency values based upon semantically labeled strings
US7742048B1 (en) 2002-05-23 2010-06-22 Microsoft Corporation Method, system, and apparatus for converting numbers based upon semantically labeled strings
US7281245B2 (en) * 2002-06-05 2007-10-09 Microsoft Corporation Mechanism for downloading software components from a remote source for use by a local software application
US7827546B1 (en) 2002-06-05 2010-11-02 Microsoft Corporation Mechanism for downloading software components from a remote source for use by a local software application
US7356537B2 (en) * 2002-06-06 2008-04-08 Microsoft Corporation Providing contextually sensitive tools and help content in computer-generated documents
US8793176B2 (en) * 2002-06-13 2014-07-29 Cfph, Llc Systems and methods for providing a customizable spreadsheet application interface for an electronic trading system
US7716676B2 (en) 2002-06-25 2010-05-11 Microsoft Corporation System and method for issuing a message to a program
US7209915B1 (en) * 2002-06-28 2007-04-24 Microsoft Corporation Method, system and apparatus for routing a query to one or more providers
US20040215594A1 (en) * 2003-01-24 2004-10-28 Bea Systems, Inc. System for transaction processing with parallel execution
WO2004068294A2 (en) * 2003-01-24 2004-08-12 Bea Systems Inc. Transaction processing with parallel execution
US20040172584A1 (en) * 2003-02-28 2004-09-02 Microsoft Corporation Method and system for enhancing paste functionality of a computer software application
US7711550B1 (en) 2003-04-29 2010-05-04 Microsoft Corporation Methods and system for recognizing names in a computer-generated document and for providing helpful actions associated with recognized names
US8495002B2 (en) * 2003-05-06 2013-07-23 International Business Machines Corporation Software tool for training and testing a knowledge base
US20050187913A1 (en) * 2003-05-06 2005-08-25 Yoram Nelken Web-based customer service interface
US7739588B2 (en) 2003-06-27 2010-06-15 Microsoft Corporation Leveraging markup language data for semantically labeling text strings and data and for providing actions based on semantically labeled text strings and data
US7836010B2 (en) 2003-07-30 2010-11-16 Northwestern University Method and system for assessing relevant properties of work contexts for use by information services
US8229932B2 (en) 2003-09-04 2012-07-24 Oracle International Corporation Storing XML documents efficiently in an RDBMS
US8694510B2 (en) * 2003-09-04 2014-04-08 Oracle International Corporation Indexing XML documents efficiently
US7178102B1 (en) 2003-12-09 2007-02-13 Microsoft Corporation Representing latent data in an extensible markup language document
US7487515B1 (en) 2003-12-09 2009-02-03 Microsoft Corporation Programmable object model for extensible markup language schema validation
US7404195B1 (en) 2003-12-09 2008-07-22 Microsoft Corporation Programmable object model for extensible markup language markup in an application
US7434157B2 (en) 2003-12-09 2008-10-07 Microsoft Corporation Programmable object model for namespace or schema library support in a software application
US9288000B2 (en) 2003-12-17 2016-03-15 International Business Machines Corporation Monitoring a communication and retrieving information relevant to the communication
US20050165717A1 (en) * 2004-01-22 2005-07-28 International Business Machines Corp. Method, system and computer program product for redirecting a response to a file request from a requesting communication program to a mail server
US8655904B2 (en) * 2004-02-11 2014-02-18 Ebay, Inc. Method and system to enhance data integrity in a database
US7509573B1 (en) 2004-02-17 2009-03-24 Microsoft Corporation Anti-virus security information in an extensible markup language document
US20050182617A1 (en) * 2004-02-17 2005-08-18 Microsoft Corporation Methods and systems for providing automated actions on recognized text strings in a computer-generated document
WO2005089239A2 (en) * 2004-03-13 2005-09-29 Cluster Resources, Inc. System and method of providing a self-optimizing reservation in space of compute resources
US7930277B2 (en) * 2004-04-21 2011-04-19 Oracle International Corporation Cost-based optimizer for an XML data repository within a database
US20070266388A1 (en) 2004-06-18 2007-11-15 Cluster Resources, Inc. System and method for providing advanced reservations in a compute environment
US20070208946A1 (en) * 2004-07-06 2007-09-06 Oracle International Corporation High performance secure caching in the mid-tier
US7207004B1 (en) 2004-07-23 2007-04-17 Harrity Paul A Correction of misspelled words
US8176490B1 (en) 2004-08-20 2012-05-08 Adaptive Computing Enterprises, Inc. System and method of interfacing a workload manager and scheduler with an identity manager
US7533139B2 (en) * 2004-09-27 2009-05-12 Microsoft Corporation Method and system for multithread processing of spreadsheet chain calculations
WO2006053093A2 (en) 2004-11-08 2006-05-18 Cluster Resources, Inc. System and method of providing system jobs within a compute environment
US8180759B2 (en) 2004-11-22 2012-05-15 International Business Machines Corporation Spell checking URLs in a resource
US7627547B2 (en) * 2004-11-29 2009-12-01 Oracle International Corporation Processing path-based database operations
US7921076B2 (en) 2004-12-15 2011-04-05 Oracle International Corporation Performing an action in response to a file system event
US8131766B2 (en) * 2004-12-15 2012-03-06 Oracle International Corporation Comprehensive framework to integrate business logic into a repository
US20060149731A1 (en) * 2005-01-05 2006-07-06 Schirmer Andrew L System and method for deriving affinity relationships between objects
US8863143B2 (en) 2006-03-16 2014-10-14 Adaptive Computing Enterprises, Inc. System and method for managing a hybrid compute environment
US9231886B2 (en) 2005-03-16 2016-01-05 Adaptive Computing Enterprises, Inc. Simple integration of an on-demand compute environment
CA2603577A1 (en) 2005-04-07 2006-10-12 Cluster Resources, Inc. On-demand access to compute resources
US8131746B2 (en) * 2005-06-23 2012-03-06 International Business Machines Corporation Dynamic language checking
JP4725955B2 (en) * 2005-06-30 2011-07-13 株式会社リコー Information processing apparatus, message management method, program, and storage medium
US7992085B2 (en) 2005-09-26 2011-08-02 Microsoft Corporation Lightweight reference user interface
US7788590B2 (en) * 2005-09-26 2010-08-31 Microsoft Corporation Lightweight reference user interface
US8073841B2 (en) * 2005-10-07 2011-12-06 Oracle International Corporation Optimizing correlated XML extracts
US8356053B2 (en) * 2005-10-20 2013-01-15 Oracle International Corporation Managing relationships between resources stored within a repository
US8949455B2 (en) 2005-11-21 2015-02-03 Oracle International Corporation Path-caching mechanism to improve performance of path-related operations in a repository
US8131747B2 (en) * 2006-03-15 2012-03-06 The Invention Science Fund I, Llc Live search with use restriction
US8032821B2 (en) * 2006-05-08 2011-10-04 Microsoft Corporation Multi-thread spreadsheet processing with dependency levels
US20100179958A1 (en) * 2006-07-19 2010-07-15 Michael James Carr Apparatus, methods, and products for surfing the internet
AU2007290431B2 (en) * 2006-08-30 2012-03-01 Thomson Reuters Enterprise Centre Gmbh Document-centric workflow based on document contents, metadata, and context
US7797310B2 (en) * 2006-10-16 2010-09-14 Oracle International Corporation Technique to estimate the cost of streaming evaluation of XPaths
US7827177B2 (en) * 2006-10-16 2010-11-02 Oracle International Corporation Managing compound XML documents in a repository
US9183321B2 (en) 2006-10-16 2015-11-10 Oracle International Corporation Managing compound XML documents in a repository
US7802194B2 (en) * 2007-02-02 2010-09-21 Sap Ag Business query language
US7991609B2 (en) * 2007-02-28 2011-08-02 Microsoft Corporation Web-based proofing and usage guidance
US20090113002A1 (en) * 2007-10-30 2009-04-30 At&T Bls Intellectual Property, Inc. Electronic Message Attachment Options
US8190477B2 (en) * 2008-03-25 2012-05-29 Microsoft Corporation Computing a time-dependent variability value
US8700763B2 (en) * 2008-05-19 2014-04-15 Citrix Systems, Inc. Systems and methods for automatically testing an application
US7958112B2 (en) * 2008-08-08 2011-06-07 Oracle International Corporation Interleaving query transformations for XML indexes
US10877695B2 (en) 2009-10-30 2020-12-29 Iii Holdings 2, Llc Memcached server functionality in a cluster of data processing nodes
US11720290B2 (en) 2009-10-30 2023-08-08 Iii Holdings 2, Llc Memcached server functionality in a cluster of data processing nodes
US10068008B2 (en) * 2014-08-28 2018-09-04 Microsoft Technologies Licensing, LLC Spelling correction of email queries
US11886916B2 (en) 2020-06-30 2024-01-30 Microsoft Technology Licensing, Llc System for adaptive multithreaded recalculation operations

Citations (8)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US5392386A (en) * 1994-02-03 1995-02-21 Inter Hi-Tec Ag Method and apparatus for adding functionality to computer programs executing under graphical user interfaces
US5526443A (en) * 1994-10-06 1996-06-11 Xerox Corporation Method and apparatus for highlighting and categorizing documents using coded word tokens
US5563805A (en) * 1994-08-16 1996-10-08 International Business Machines Corporation Multimedia context-sensitive real-time-help mechanism for use in a data processing system
EP0788062A2 (en) * 1996-01-30 1997-08-06 Sun Microsystems, Inc. Internet-based spelling checker dictionary system with automatic updating
EP0807890A2 (en) * 1996-05-17 1997-11-19 TechnoCraft Co. Text string extraction system
WO1998004061A1 (en) * 1996-07-24 1998-01-29 Walker Asset Management Limited Partnership Method and apparatus for a cryptographically-assisted commercial network system designed to facilitate and support expert-based commerce
US5787451A (en) * 1995-05-08 1998-07-28 Microsoft Corporation Method for background spell checking a word processing document
US5819267A (en) * 1995-06-30 1998-10-06 Fujitsu Limited Know-how management apparatus, and method

Family Cites Families (7)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
DE4323241A1 (en) 1993-07-12 1995-02-02 Ibm Method and computer system for finding incorrect character strings in a text
EP0742918B1 (en) 1994-03-21 1997-10-15 Object Technology Licensing Corp. Apparatus and method for document processing
US5758257A (en) 1994-11-29 1998-05-26 Herz; Frederick System and method for scheduling broadcast of and access to video programs and other data using customer profiles
US5802380A (en) 1996-03-08 1998-09-01 Microsoft Corporation Method and system for uniform access of textual data
US5873107A (en) 1996-03-29 1999-02-16 Apple Computer, Inc. System for automatically retrieving information relevant to text being authored
US5727950A (en) 1996-05-22 1998-03-17 Netsage Corporation Agent based instruction system and method
US5796952A (en) 1997-03-21 1998-08-18 Dot Com Development, Inc. Method and apparatus for tracking client interaction with a network resource and creating client profiles and resource database

Patent Citations (8)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US5392386A (en) * 1994-02-03 1995-02-21 Inter Hi-Tec Ag Method and apparatus for adding functionality to computer programs executing under graphical user interfaces
US5563805A (en) * 1994-08-16 1996-10-08 International Business Machines Corporation Multimedia context-sensitive real-time-help mechanism for use in a data processing system
US5526443A (en) * 1994-10-06 1996-06-11 Xerox Corporation Method and apparatus for highlighting and categorizing documents using coded word tokens
US5787451A (en) * 1995-05-08 1998-07-28 Microsoft Corporation Method for background spell checking a word processing document
US5819267A (en) * 1995-06-30 1998-10-06 Fujitsu Limited Know-how management apparatus, and method
EP0788062A2 (en) * 1996-01-30 1997-08-06 Sun Microsystems, Inc. Internet-based spelling checker dictionary system with automatic updating
EP0807890A2 (en) * 1996-05-17 1997-11-19 TechnoCraft Co. Text string extraction system
WO1998004061A1 (en) * 1996-07-24 1998-01-29 Walker Asset Management Limited Partnership Method and apparatus for a cryptographically-assisted commercial network system designed to facilitate and support expert-based commerce

Non-Patent Citations (2)

* Cited by examiner, † Cited by third party
Title
"PARCI ARCHITECTURE" IBM TECHNICAL DISCLOSURE BULLETIN,US,IBM CORP. NEW YORK, vol. 38, no. 3, 1 March 1995 (1995-03-01), pages 13-18, XP000507963 ISSN: 0018-8689 *
KAUTZ H ET AL: "Agent amplified communication" PROCEEDINGS OF THE NATIONAL CONFERENCE ON ARTIFICIAL INTELLIGENCE AND INNOVATIVE APPLICATIONS OF ARTIFICIAL INTELLIGENCE CONFERENCE, 4 August 1996 (1996-08-04), XP002105809 *

Cited By (8)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US8549436B1 (en) 2007-06-04 2013-10-01 RedZ, Inc. Visual web search interface
WO2019118150A1 (en) * 2017-12-13 2019-06-20 Microsoft Technology Licensing, Llc Enhanced processing and communication of file content for analysis
WO2019118151A1 (en) * 2017-12-13 2019-06-20 Microsoft Technology Licensing, Llc Split mapping for dynamic rendering and maintaining consistency of data processed by applications
WO2019118149A1 (en) * 2017-12-13 2019-06-20 Microsoft Technology Licensing, Llc Automatically launched software add-ins for proactively analyzing content of documents and soliciting user input
US10698937B2 (en) 2017-12-13 2020-06-30 Microsoft Technology Licensing, Llc Split mapping for dynamic rendering and maintaining consistency of data processed by applications
US10929455B2 (en) 2017-12-13 2021-02-23 Microsoft Technology Licensing, Llc Generating an acronym index by mining a collection of document artifacts
US11061956B2 (en) 2017-12-13 2021-07-13 Microsoft Technology Licensing, Llc Enhanced processing and communication of file content for analysis
US11126648B2 (en) 2017-12-13 2021-09-21 Microsoft Technology Licensing, Llc Automatically launched software add-ins for proactively analyzing content of documents and soliciting user input

Also Published As

Publication number Publication date
AU2155300A (en) 2000-07-24
US6349295B1 (en) 2002-02-19
WO2000041095A3 (en) 2001-02-08

Similar Documents

Publication Publication Date Title
US6349295B1 (en) Method and apparatus for performing supplemental searches over a network
US9400662B2 (en) System and method for providing context information
JP4093012B2 (en) Hypertext inspection apparatus, method, and program
US8527905B2 (en) Providing archived web page content in place of current web page content
US7043690B1 (en) Method, system, and program for checking contact information
US6788313B1 (en) Method and apparatus for providing on line help for custom application interfaces
JP3258263B2 (en) Method and apparatus for providing a browser that can simultaneously maintain multiple URLs active
US6751777B2 (en) Multi-target links for navigating between hypertext documents and the like
US6061699A (en) Method and computer program product for extracting translatable material from browser program function codes using variables for displaying MRI
US20080115086A1 (en) System and method for recognizing and storing information and associated context
US20120284329A1 (en) System and method for asynchronous client server session communication
US20030115295A1 (en) High performance client/server editor
US20010021934A1 (en) Processing device for searching information in one language using search query in another language, and recording medium and method thereof
WO1998039867A2 (en) Replicating forms from html templates
JPH10269237A (en) Document browsing system
JP2001510607A (en) Intelligent network browser using indexing method based on proliferation concept
US20080163122A1 (en) File content preview tool
EP1388091A2 (en) Category name service
US20030226104A1 (en) System and method for navigating search results
US8522128B1 (en) Systems and methods for modifying the order of links presented in a document
EP1677215B1 (en) Methods and apparatus for the evalution of aspects of a web page
EP3848824A1 (en) Landing page processing method, apparatus, device and medium
US7895337B2 (en) Systems and methods of generating a content aware interface
US5946499A (en) Method and apparatus for processing text inputs from multiple input devices in a plurality of applications
US20080243849A1 (en) Method and apparatus for supporting context links for application program text

Legal Events

Date Code Title Description
AK Designated states

Kind code of ref document: A2

Designated state(s): AE AL AM AT AU AZ BA BB BG BR BY CA CH CN CU CZ DE DK EE ES FI GB GD GE GH GM HR HU ID IL IN IS JP KE KG KP KR KZ LC LK LR LS LT LU LV MD MG MK MN MW MX NO NZ PL PT RO RU SD SE SG SI SK SL TJ TM TR TT UA UG US UZ VN YU ZA ZW

AL Designated countries for regional patents

Kind code of ref document: A2

Designated state(s): GH GM KE LS MW SD SL SZ TZ UG ZW AM AZ BY KG KZ MD RU TJ TM AT BE CH CY DE DK ES FI FR GB GR IE IT LU MC NL PT SE BF BJ CF CG CI CM GA GN GW ML MR NE SN TD TG

121 Ep: the epo has been informed by wipo that ep was designated in this application
AK Designated states

Kind code of ref document: A3

Designated state(s): AE AL AM AT AU AZ BA BB BG BR BY CA CH CN CU CZ DE DK EE ES FI GB GD GE GH GM HR HU ID IL IN IS JP KE KG KP KR KZ LC LK LR LS LT LU LV MD MG MK MN MW MX NO NZ PL PT RO RU SD SE SG SI SK SL TJ TM TR TT UA UG US UZ VN YU ZA ZW

AL Designated countries for regional patents

Kind code of ref document: A3

Designated state(s): GH GM KE LS MW SD SL SZ TZ UG ZW AM AZ BY KG KZ MD RU TJ TM AT BE CH CY DE DK ES FI FR GB GR IE IT LU MC NL PT SE BF BJ CF CG CI CM GA GN GW ML MR NE SN TD TG

DFPE Request for preliminary examination filed prior to expiration of 19th month from priority date (pct application filed before 20040101)
REG Reference to national code

Ref country code: DE

Ref legal event code: 8642

REG Reference to national code

Ref country code: DE

Ref legal event code: 8642

122 Ep: pct application non-entry in european phase