TeamJapan/ja:support/docs/search/index.php

From Camino Wiki
< TeamJapan
Revision as of 06:43, 28 February 2006 by Caminofreak (talk | contribs)
(diff) ← Older revision | Latest revision (diff) | Newer revision → (diff)
Jump to navigation Jump to search

検索エンジンのカスタマイズ Camino Project : Documentation : Customizing Search Engines

ツールバーの検索欄

Googleの通常検索やイメージ検索、サイト内検索などを行える検索欄がツールバーにあります。 検索欄の検索エンジンリストを編集できるインターフェイスはありませんが、テキストエディタがあればリストを編集できます。 まず、ツールバーに検索欄を表示しておきましょう。 デフォルトではツールバーにあるはずですが、ない場合は次のCaminoの設定に従って検索欄を追加してください。

仕組み

検索エンジンを記述するplistファイルは ~/Library/Application Support/Camino/SearchURLList.plist です。 SearchURLList.plistのフォーマットは単純です。 基本的には、検索エンジン名と検索URLのリストです。 検索エンジン名は検索欄の拡大鏡メニューで使用され、検索URLはCaminoが検索を行うのに使用されます。

検索を行うために、検索URLに2つの特殊な文字列を使用します。

%s — ユーザの検索語句

   ユーザの検索語句に置き換えられます。 例えば、検索URLが “http://www.google.com/search?q=%s” のとき、ユーザが「Mac Browser Camino」と入力すると、Caminoは “http://www.google.com/search?q=Mac Browser Camino” を実行します。 %s は検索URLに必須です。

%d — 現在のURLのホストネーム

   現在ユーザが訪れているURLのホストネームに置き換えられます。 例えば、検索URLが “http://www.google.com/search?q=%s site:%d” のとき、ユーザがhttp://apple.comを訪れていて「Mac OS X」と入力すると、Caminoは “http://www.google.com/search?q=Mac OS X site:www.apple.com.” を実行します。 Googleのサイト内検索のように%d が使用できる検索エンジンはほとんどありません。

最後に、SearchURLList.plistにはPreferredSearchEngineと呼ばれる特殊なキーがあります。 このキーは、デフォルトで選択される検索エンジンを指定するのに使われます。 キーに一致する検索エンジンがないと、SearchURLList.plistの読み出しが正しく行われません。 キーの値は、plist内にある検索エンジン名のうち一つと同じにしなければいけません。 デフォルトでは、値は “Google” です。 もし別の検索エンジンを追加してそれをデフォルトにしたい場合は、PreferredSearchEngineの値をその検索エンジン名に変更します。

デフォルトのSearchURLList.plistの内容は以下のようになっています:

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE plist PUBLIC "-//Apple Computer//DTD PLIST 1.0//EN" "http://www.apple.com/DTDs/PropertyList-1.0.dtd">
<plist version="1.0">
<dict>
<key>Google</key>
<string>http://www.google.com/search?q=%s</string>
<key>Google Images</key>
<string>http://images.google.com/images?q=%s</string>
<key>PreferredSearchEngine</key>
<string>Google</string>
<key>Search this Site</key>
<string>http://www.google.com/search?q=%s site:%d</string>
</dict>
</plist>

新しい検索エンジン(例えば、Dictionary.com、dMoz.org、eBay、Google Newsなど)を追加するには、まず各エンジンの検索URLを調べます。 方法はいろいろありますが、最も簡単なのはそのサイトを訪れて “CAMINO_SEARCH_STRING” のような目立つ文字列を検索し、検索結果ページのURLを確認するというものです。 例えば、Dictionary.comでの検索結果は “http://dictionary.reference.com/search?q=CAMINO_SEARCH_STRING” になります。 CAMINO_SEARCH_STRING を %sで置き換えると、“http://dictionary.reference.com/search?q=%s” になります。

他の検索エンジンについても同じ方法を使い、最終的に以下のようにします:

Dictionary.com

   http://dictionary.reference.com/search?q=%s

dmoz.org

   http://search.dmoz.org/cgi-bin/search?search=%s

eBay

   http://search.ebay.com/search/search.dll?
   cgiurl=http%3A%2F%2Fcgi.ebay.com%2Fws%2F&krd=1&
   from=R8&MfcISAPICommand=GetResult&ht=1&
   SortProperty=MetaEndSort&query=%s

Google News

   http://news.google.com/news?hl=en&q=%s&btnG=Search+News

注:plistはXML形式なので、特定の文字を実体参照に置き換える必要があります。 特に重要なのが検索URLによく存在する「&」で、「&」に置き換える必要があります。 HTML/XMLで使われる実体参照の全リストはこちらです。置き換えが必要な文字が集められています。 Mac OS Xのdeveloper toolsに含まれているPropertyList Editorなら置き換えを自動で行ってくれるので、作業が少し楽になります。

少しテストすれば(そして検索エンジンの動作を少し理解すれば)、 eBayとGoogle Newsの検索URLを http://search.ebay.com/search/search.dll?query=%sと http://news.google.com/news?q=%sのように簡略化できるでしょう。 簡素化は必須ではありませんが、わかりやすくなります。

最終的に、検索エンジン名と検索URLのリストはこのようになります:

Dictionary.com

   http://dictionary.reference.com/search?q=%s

dmoz.org

   http://search.dmoz.org/cgi-bin/search?search=%s

eBay

   http://search.ebay.com/search/search.dll?query=%s

Google News

   http://news.google.com/news?q=%s

あとはこれらをSearchURLList.plistに追加するだけです。 SearchURLPlist.plistを好みのテキストエディタ(TextEditがよいでしょう)で開きます。 <key>SEARCH_ENGINE_TITLE</key> と <string>SEARCH_URL</string> をペアで記述します。SEARCH_ENGINE_TITLEには検索エンジンの名前 (例:Dictionary.com)を記述し、SEARCH_URLには前のステップで決定した検索URLを記述します。 (例:http://dictionary.reference.com/search?q=%s) この文字列は <dict> と </dict> タグの間に入れる必要があります。

Dictionary.comを追加すると以下のようになります。 赤字の部分が変更箇所です。

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE plist PUBLIC "-//Apple Computer//DTD PLIST 1.0//EN" "http://www.apple.com/DTDs/PropertyList-1.0.dtd">
<plist version="1.0">
<dict>
<key>Google</key>
<string>http://www.google.com/search?q=%s</string>
<key>Google Images</key>
<string>http://images.google.com/images?q=%s</string>
<key>PreferredSearchEngine</key>
<string>Google</string>
<key>Search this Site</key>
<string>http://www.google.com/search?q=%s site:%d</string>
<key>Dictionary.com</key>
<string>http://dictionary.reference.com/search?q=%s</string>
</dict>
</plist>

残りの3つも追加すると、以下のようになります:

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE plist PUBLIC "-//Apple Computer//DTD PLIST 1.0//EN" "http://www.apple.com/DTDs/PropertyList-1.0.dtd">
<plist version="1.0">
<dict>
<key>Google</key>
<string>http://www.google.com/search?q=%s</string>
<key>Google Images</key>
<string>http://images.google.com/images?q=%s</string>
<key>PreferredSearchEngine</key>
<string>Google</string>
<key>Search this Site</key>
<string>http://www.google.com/search?q=%s site:%d</string>
<key>Dictionary.com</key>
<string>http://dictionary.reference.com/search?q=%s</string>
<key>dMoz.org</key>
<string>http://search.dmoz.org/cgi-bin/search?search=%s</string>
<key>eBay</key>
<string>http://search.ebay.com/search/search.dll?query=%s</string>
<key>Google News</key>
<string>http://news.google.com/news?q=%s</string>
</dict>
</plist>

注記:検索エンジンの順番は気にしないでください。 検索欄では、検索エンジン名がアルファベット順で表示されます。

別の検索エンジンをデフォルトにしたい場合は、PreferredSearchEngineの値をデフォルトにしたい検索エンジン名に変更します。 以下の例は“Google News”をデフォルトに設定したものです:

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE plist PUBLIC "-//Apple Computer//DTD PLIST 1.0//EN" "http://www.apple.com/DTDs/PropertyList-1.0.dtd">
<plist version="1.0">
<dict>
<key>Google</key>
<string>http://www.google.com/search?q=%s</string>
<key>Google Images</key>
<string>http://images.google.com/images?q=%s</string>
<key>PreferredSearchEngine</key>
<string>Google News</string>
<key>Search this Site</key>
<string>http://www.google.com/search?q=%s site:%d</string>
<key>Dictionary.com</key>
<string>http://dictionary.reference.com/search?q=%s</string>
<key>dMoz.org</key>
<string>http://search.dmoz.org/cgi-bin/search?search=%s</string>
<key>eBay</key>
<string>http://search.ebay.com/search/search.dll?query=%s</string>
<key>Google News</key>
<string>http://news.google.com/news?q=%s</string>
</dict>
</plist>