Google Search | I'm feeling lucky | |
---|---|---|
Netscape | Jargoogle | Lucky Jargoogle |
MSIE | Jargoogle | Lucky Jargoogle |
Note: All my knowledge of Google's features is all acquired by expirement/guessing and might be inaccurate/incomplete/intrustable/incorrect.
Google claims:
The word "site" followed by a colon enables you to restrict your search to a specific site. To do this, use the "site:sampledomain.com" syntax in the Google search box.I tried it and although it actually accepts only domain names, it gets accurate results when searching for a jargon term within www.tuxedo.org (that's the domain where the Jargon File resources page resides). For example searching for:
foobar site:www.tuxedo.orgresults in:
http://www.tuxedo.org/~esr/jargon/html/entry/foobar.html
as the first match, which is the Right Page.
Note: I don't know CGI well; the terminology might differ from the accepted one.
Google has two CGI interfaces that provide same input for the search engine from different form inputs. The first is the simple search at `http://www.google.com/search?' and the second is the advanced search at `http://www.google.com/advanced_search?'.
Both searches accept two submit inputs: `btnG' for normal search and `btnI' for "I'm feeling lucky" searches. Only their presence matters; the values are ignored, which allows freedom in the button names (the value is taken from the button name which is not a great design decision IMHO).
The simple search accepts the search request in one string as the `q' input. This is good enough for the JavaScript in the toolbar buttons, but not for the HTML from. The advanced search builds the search request from parts given in separate inputs. `as_q' acts as `q' in the simple search but it's combined with values from other input fields. In paticular if `as_sitesearch' is specified, it's value is prepended with ` site:' and concatenated onto the search string.
The Jargoogle search form is a cut-down version of Google Advanced search form. It includes only the main `as_q' field and a hidden `as_sitesearch' field set to `www.tuxedo.org'
In the absence of either submit inputs the simple search defualt to regular (unlucky :-) Google search and the advanced search presents the adnvaced search page with the value of `as_q' parsed into the various boxes. That's used tby Google to switch from simple search to advanced search when you have already typed part of the search. I used it to make the Google logo point to the advance search page initialized with the domain restriction.
The toolbar buttons provided by Google also provide a `client' input with `googlet' value which seems to do nothing (I tried both ways). I left it in, guessing that they might be collecting statistics of toolbar button usage, and the Jargon version probably should be included.
These are simple extensions of the buttons provided by Google, at the sofistication level of a script kiddie (select the previous 2 words and press the Lucky Jargoogle button :-). The description provides my understanding of the code, as I [want to] know nothing about JavaScript. You might be better off just reading the code in the page source - the same holds for the above explanations about CGI.
The buttons are links whose URL begins with `javascript:'. It is followed by the javascript code, on one line, URL encoded and without spaces. I have removed URL encoding, added spacing and indentation here so that you can read it. Leave the indentation style flames to yourself please.
The first thing that is done is to try to get the selection to simplify search of a jargon term appearing on some web site. This is (of course) not portable accross browsers, especially contsidering that we have to check for the selection in every frame:
q = document.getSelection();
for(i = 0; i < frames.length; i++) {
q = frames[i].document.getSelection();
if(q)
break;
}
q = (document.frames.length ? '' : document.selection.createRange().text);
for(i = 0; i < document.frames.length; i++)
{
q = document.frames[i].document.selection.createRange().text;
if(q != '')
break;
}
The second thing to do is to prompt for the search string if no selection was found. This code could be portable if the check was - I haven't tried to make it the same on both browsers (lazyness...) but if it's a real difference it might result from the above Netscape code giving 0 vs. the MSIE code giving an empty string if no selection is found. The string split for readability by me:
if(!q)
void(q = prompt('Enter text to search using Google. You can also highlight ' +
'a word on this web page before clicking Google Search.', ''));
if(q == '')
void(q = prompt('Enter text to search using Google. You can also highlight ' +
'a word on this web page before clicking Google Search.', ''));
The last thing left to do is to create the URL. (Loading seems to
be automagically triggered by the change of the current location). At
least this is portable. Even the check is, probably because prompt()
returns 0 if "Cancel" is pressed in both browsers.
if(q)
location.href = 'http://www.google.com/search?client=googlet&q=' +
escape(q) +
' site:www.tuxedo.org'
Of course no closing semicolon is needed as this is the last
statement. It's known that all C-inspired languages use Pascal syntax
;-).
If you want to have an "I'm feeling lucky" search, just add the `btnI'
input:
if(q)
location.href = 'http://www.google.com/search?client=googlet&btnI=I%27m+Feeling+Lucky&q=' +
escape(q) +
' site:www.tuxedo.org'
Now you just have to combine these together.