/ 最近 .rdf 追記 設定 本棚

脳log[2006-07]



2006年07月02日 (日)

[SQLite] EXPLAIN QUERY PLAN sql-statement;

知らない。知らないよこんな便利なコマンド。

EXPLAIN sql-statement;

ならドキュメントに載ってるけど、これが返すのは

0|Integer|5|0|
1|MustBeInt|0|0|
2|MemStore|0|0|
3|IfMemZero|0|25|
4|IfMemPos|0|8|
5|Pop|1|0|
……

みたいな SQLがコンパイルされた結果の、VMが逐一実行する命令のリストだから腰を据えないと解読できない。

それに対して

EXPLAIN QUERY PLAN sql-statement;

が返すのは

0|0|TABLE MyBooks USING PRIMARY KEY

みたいな、テーブルに対する問い合わせのリスト。インデックスが使われるのかどうかもわかる。

EXPLAIN QUERY PLANを発見
http://www.sqlite.org/cvstrac/tktview?tn=1878 (SQLite CVSTrac)
SQLite 3.2.6から追加された実験的なコマンドだって
http://www.sqlite.org/cvstrac/wiki?p=QueryPlans (SQLite CVSTrac)

2006年07月04日 (火)

[]2点

  • [単行本] 桜庭 一樹【少女七竈と七人の可愛そうな大人】 角川書店
  • [コミック] 萩原 一至【BASTARD 24―暗黒の破壊神 (24) (ジャンプコミックス)】 集英社

 七竈

著者がインタビューで語ったところによると七竈を読んだ複数の人曰く「『エレンディラ』」らしいので先に、なぜか手許にある、1982年のノーベル文学賞を受賞した南米の作家ガルシア=マルケスの短編集『エレンディラ』に収録されている『無垢なエレンディラと無情な祖母の信じがたい悲惨の物語』を読むことにする。


2006年07月09日 (日)

[Firefox] ブラウザ、フォーカス、Tabキー

 タブキーでフォーカスが移動する先は現在表示されてる(フレームに収まってる)部分だけで良い。

あるページを読んでいる。読み進んでいく。「次のページへ」というリンクがある。タブキーを押す。ページがギュンッと巻き戻って一番最初のリンク*にフォーカスが移動する。さらにタブを押す、押し続ける。サイドバーのリンクを順にたどってフォーカスがページ下方へ移動していく。やがてまたもページが巻き戻る。今度は本文中のリンクを順に下方にたどっていく。やっと「次のページへ」にたどり着く。

今見ているリンクにフォーカスを合わそうとしているのに、フォーカスはとんでもないところに飛んでいく。タブキーを押すことによってスクロール位置が変わるのが非常にストレス。タブキーでフォーカスが移動する先は現在表示されてる(フレームに収まってる)部分だけで良い。

 tabindexを失念していた

HTML作成者が tabindexをリンクやフォームに割り振っていた場合 tabindexの小さい順にフォーカスが移動するのだった。tabindexが一つでも指定されていればそちらを優先すべきだな。(といっても、tabindexが指定されていて欲しいのは自分がよく使うページだけだけど。不特定の人に見せるのが目的のページで押し付けは良くない。)

tabindexはフォーカスの順番を決めるだけのものではないのだなぁ。

 これを機に Firefoxの拡張に手を出すか、ありもので間に合わすか。

ありものは↓。

Mouseless Browsingを使っているが Find As You Typeと競合するのでテンキーを Mouseless Browsing専用にしている。そうすると、テキストフィールドに数字を入力するのが不便(テンキーが使えないので)。

自前でやる場合、次にフォーカスを得るエレメントがどれなのかを自前で探すのは避けたいところ。それをするんだったら greasemonkeyで onblurを捕まえて、次にフォーカスを得るエレメントを順に辿っていって、最初に見つかったブラウザのフレーム内に収まってる(=見えている)エレメントを focus()すればいいはず。

* 普通はソーステキスト中に一番最初に登場したもの。tabindexが指定されていれば最小の tabindexを与えられたもの。


2006年07月11日 (火)

[]5点

  • [コミック] 小畑 友紀【僕等がいた 9 (9) (フラワーコミックス)】 小学館
  • [コミック] 小畑 友紀【僕等がいた公式ファンブック (フラワーコミックス)】 小学館
  • [コミック] 凜野 ミキ【光 4 (4) IDコミックス ZERO-SUMコミックス】 一迅社
  • [文庫] グレッグ・イーガン【万物理論 (創元SF文庫)】 東京創元社
  • [文庫] カズオ イシグロ【日の名残り (中公文庫)】 中央公論社

2006年07月13日 (木)

[HTML] <a href="javascript:void(0)"> と自分で書いて初めて気付くその便利さ

onclickでごにょごにょする HTML要素があって、そいつに Tabキーでフォーカスをあてたいなと思ったときに最初に思いついたのが

<a href="javascript:void(0)">ほげほげ</a>*

のように Aタグで囲う方法。遅まきながら、この時初めてステータスバーに javascript:void(0)と表示される何もしないリンクの存在意義に気付いた。こいつがあると Tabキーでフォーカスをあてられるし、Enterキーでクリックすることもできる。そしてスクリプト(onclickハンドラ)で処理できる。簡単かつ使える範囲の広い方法。javascriptを切ってるブラウザではそもそも onclickハンドラが動かないから javascriptスキーマを使うことの是非は問われないし。onclickハンドラでキーボードとマウスをまとめて処理できることや、対応するブラウザの多さなど、書けば書くほどこれしかないって思えてくる。

次に考えついたのが、9日に "tabindexはフォーカスの順番を決めるだけのものではないのだなぁ。" と書いたように、IE(>=5.0)や Firefox1.5で、tabindexを付けることでリンクやフォームの部品以外の要素をフォーカス可能にする方法。

IEの場合、

<element>.tabIndex = 0 // 0 => フォーカス可能にはするが、タブオーダーは指定しない
<element>.onkeypress = function(){ if(event.keyCode == 13) this.click() } // Enter->Click

で済むが、Firefoxの場合 click()が実装されてるエレメントがフォームの部品などに限られているので

<element>.tabIndex = 0 // 同上
<element>.onkeypress = function(event){
  if(event.keyCode == 13) {
    var event2 = document.createEvent("MouseEvents");
    event2.initMouseEvent("click", true, true, event.view, event.detail, event.screenX, event.screenY, event.clientX, event.clientY, event.ctrlKey, event.altKey, event.shiftKey, event.metaKey, 0, null);
    this.dispatchEvent(event2);
  }
}

と、かなり冗長。

* href="" だとそのページ自身へ移動(=リロード)してしまう。void(0)以外に href="#" を使う流派もある様子(でもイマイチ)。


2006年07月14日 (金)

[]9点

  • [コミック] 小畑 友紀【僕等がいた 1 (1) (フラワーコミックス)】 小学館
  • [文庫] 清原 なつの【私の保健室へおいで… (ハヤカワ文庫 JA (696))】 早川書房
  • [文庫] 吉野 朔実【少年は荒野をめざす (1) (集英社文庫―コミック版)】 集英社
  • [コミック] 冨樫 義博【レベルE (Vol.1) (ジャンプ・コミックス)】 集英社
  • [文庫] 冨樫 義博【てんで性悪キューピッド (1) (集英社文庫―コミック版)】 集英社
  • [文庫] 冨樫 義博【てんで性悪キューピッド (2) (集英社文庫―コミック版)】 集英社
  • [文庫] 本上 まなみ【ほんじょの虫干。 (新潮文庫)】 新潮社
  • [新書] 浦賀 和宏【火事と密室と、雨男のものがたり (講談社ノベルス)】 講談社
  • [文庫] フィツジェラルド, 野崎 孝【グレート・ギャツビー (新潮文庫)】 新潮社

 僕等がいた

アニメ、面白いです。だからマンガを買ったけど、でも一番は声が素晴らしい。普通っぽくてつぶやきが多くてツボ。

 冨樫 義博

デスノートにしろ、レベルEにしろ、連載を追いかけるほど面白い漫画は案外手元になかったりする。レベルEには冨樫義博に期待する要素がコンパクトに詰まっている。

てんで性悪キューピッドは幽遊白書以前にジャンプで連載されていた。お色気系。未読。

 ほんじょ

単行本が出たときは高校生。1900円は高すぎた。文庫版は加筆があり、写真が一部差し替え。

 浦賀 和宏

松浦純菜シリーズ二作目。最近三作目がでた(『上手なミステリの書き方教えます』)。既に三冊が積読で結局一冊も読んでいない。未読作家は早く読んで、買いか否かを判断せねば。

 ギャツビー

『日の名残り』(カズオ・イシグロ)を読んでいて目にした。その2、3日前にもどこかの Webサイトで目にしていた。今日 3度目に目にしたので買ってみた。


2006年07月15日 (土)

初!フィッシングメール(多分)

フィッシングメール?のスナップショット

「PayPal Account Limitation !」というタイトルのメールが来た。64.12.117.14という IPアドレスから 3回アクセスがあったからアカウントを制限したので、ログインして制限を解除しろという英文のメール。

HTMLメールだったので本文中のリンクをクリック。そこでフィッシングサイトに誘導された可能性に気付いて、Googleで PayPalを検索して二番目に表示された www.paypal.comに移動。だが Google検索で上位に表示されたからといってそこがフィッシングサイトでないともいえない。何をもって情報の送信先の身許を判断すればよいのだろう。

などと迷ってるうちに、自分が PayPalのアカウントを持ってないことに気付いて終了。アホか。

  • HTMLメールは見映えがよいので信用しがち (見映えと信用に全く関連がないのは明らかなのに)
  • リンクに見える部分が実際にはリンクでなく、リンクになってたのはログインを促す一カ所だけ (足跡を残したくない?)
  • Thunderbirdはフィッシングだと判断しなかった (当然送信前に主要なメーラーでチェックするわな)
  • 誘導されたURL→http://bastish.net/.PayPal/PayPal.limitations/online/cmcspagename.PayPalHref.urlname.PayPalccprivacysecurityreminder.online.verification/webscr.php?cmd=_login-run
  • 埋め込まれていた Webバグ→<img src="http://link.p0.com/1x1.dyn?0WkGL8-ChrTPbnlHKa37=0" width=1 height=1 width="1" height="1" border="0">
  • 使われていた画像は全て https://www.paypalobjects.com/en_US/i/ に置かれていた

[]3点

  • [コミック] CLAMP【×××HOLiC(9)(KCDX)】 講談社
  • [新書] 荻原 規子【樹上のゆりかご (C・NOVELSファンタジア)】 中央公論新社
  • [文庫] 高殿 円【神曲奏界ポリフォニカ エターナル・ホワイト (GA文庫)】 ソフトバンククリエイティブ

2006年07月18日 (火)

[]5点

  • [文庫] 支倉 凍砂【狼と香辛料〈2〉 (電撃文庫)】 メディアワークス
  • [文庫] 岩田 洋季【月の盾 (電撃文庫)】 メディアワークス
  • [コミック] 鈴木 央【ブリザードアクセル 6 (6) (少年サンデーコミックス)】 小学館
  • [コミック] 冨樫 義博【レベルE (Vol.2) (ジャンプ・コミックス)】 集英社
  • [コミック] タカハシ マコ【水色ノート (ダイヤモンドコミックス)】 松文館

2006年07月19日 (水)

[]4点

  • [文庫] 吉野 朔実【少年は荒野をめざす (2) (集英社文庫―コミック版)】 集英社
  • [文庫] 吉野 朔実【少年は荒野をめざす (3) (集英社文庫―コミック版)】 集英社
  • [コミック] 冨樫 義博【レベルE (vol.3) (ジャンプ・コミックス)】 集英社
  • [コミック] 河内 和泉【機工魔術士-enchanter 10 (10) (ガンガンWINGコミックス)】 スクウェア・エニックス

2006年07月24日 (月)

[]3点

  • [コミック] ツガノ ガク, 谷川 流, いとう のいぢ【涼宮ハルヒの憂鬱 (1) (カドカワコミックスAエース)】 角川書店
  • [文庫] 川端 康成【眠れる美女 (新潮文庫)】 新潮社
  • [文庫] ジェイムズ・P. ホーガン【内なる宇宙〈上〉 (創元SF文庫)】 東京創元社

2006年07月25日 (火)

[Firefox] Mouseless Browsing 0.4.1+

何日かマウスを使っていないのでブラウザ(Firefox)のキーボードインターフェイスが気になる。

 Find As You Typeでリンクにフォーカス

Firefoxの設定で「オプション > 詳細 > 一般 > アクセシビリティ > キー入力時に検索を開始する」を有効にすると、Ctrl+Fやスラッシュを押してからでなくとも、目に付いた単語をタイプするだけでインクリメンタルなページ内検索が行える。このとき検索結果の文字列にフォーカスが移動するのが非常に都合が良くて、リンク文字列がアルファベットであればタブキーを使って順番にフォーカスを移動するよりスムーズにリンクにフォーカスをあててページを移動できる。

 Mouseless Browsingでリンクにフォーカス

Firefoxの拡張機能のひとつである Mouseless Browsingもまたキーボードを使ったナビゲーションを円滑にする。そのアプローチは全てのリンクにシリアルナンバーを割り振るというもの。リンクの右下隅に表示される数字をタイプして Enterを押すとリンク先に移動し、Enterの代わりにプラスキーを押すと新しいタブで開くといった具合。

ところで、「オプション > 詳細 > 一般 > アクセシビリティ > キー入力時に検索を開始する」と Mouseless Browsingは競合する。数字をタイプすると両方が同時に動き出すのだ。

 共存案1

最初は、Mouseless Browsingにはシリアルナンバーを割り振ることだけを任せて、Find As You Typeで数字をタイプしてリンクにフォーカスを合わせ、リンクをクリックするのは Enter(新しいタブで開くなら Ctrl+Enter。どちらも Windows版 Firefoxの標準割り当て)、でうまくいくように思えた。実際、悪くない動作をする。

唯一、気に入らないのはスクロール位置がガタガタ移動するのが避けられないこと。例えば 125番のリンクをクリックしようと [1][2][5][Enter]とタイプすると、Enterを押すまでの間に、1番のリンク、12番のリンク、125番のリンクの順にフォーカスが移動しスクロール位置も合わせて移動するので見てて疲れる。前にも書いたが、フォーカスの移動に伴ってスクロール位置が移動するのはストレス。目の見える自分にとってフォーカスをあてたい対象は今、見えている範囲にあるのだから。

原因は Find As You Typeがインクリメンタルな検索を行うことにあって、Mouseless Browsingならそういうことは起こらないのだが。

 共存案2

Mouseless Browsingは良くできたやつで、こいつの設定に「Use numpad exclusively for Mouseless Browsing」というのがある。これをチェックしておけば、テンキー以外のキーをタイプしたときは Find As You Type、テンキーを使ったときは Mouseless Browsing、とどちらも有効にしたまま棲み分けができる。テンキーを使う時にはスクロールの問題も起こらない。

ところがこれにも問題が。このチェックが有効だとフォームに数字を入力するときにテンキーが使えない。exclusiveだとはいってもフォーカスが文字入力可能な場所にあるときはキーボード入力を Firefoxの標準のハンドラに譲って欲しい。そんなわがままを可能にする修正が下の 4点。元がいいから変更も楽だった。

 Mouseless Browsing0.4.1に加えた変更点

<Fx profile>*\extensions\{c0bcf963-624b-47fe-aa78-8cc02434cf32}\defaults\preferences\mlb_prefs.js の 13行目に一行挿入。(初期設定を追加)

12 pref("mouselessbrowsing.exclusiveNumpad", false);
13 pref("mouselessbrowsing.exclusiveNumpadUnlessWritable", false);
14 pref("mouselessbrowsing.executeAutomatic", false);

<Fx profile>\extensions\{c0bcf963-624b-47fe-aa78-8cc02434cf32}\chrome\mouselessbrowsing.jar\content\mouselessbrowsing\prefs.xul に 70-72行目を挿入。(設定画面に項目を追加)

67 <row>
68    <checkbox id="exclusiveNumpad" label="Use numpad exclusively for Mouseless Browsing" prefid="mouselessbrowsing.exclusiveNumpad" defaultValue="0"/>
69 </row>
70 <row>
71     <checkbox id="exclusiveNumpadUnlessWritable" style="margin-left:30px" label="Unless a writable element has focus" prefid="mouselessbrowsing.exclusiveNumpadUnlessWritable" defaultValue="0"/>
72 </row>
73 <row>
74     <checkbox id="executeAutomatic" label="Execute automatically without pressing Enter" prefid="mouselessbrowsing.executeAutomatic" defaultValue="false"/>
75 </row>

<Fx profile>\extensions\{c0bcf963-624b-47fe-aa78-8cc02434cf32}\chrome\mouselessbrowsing.jar\content\mouselessbrowsing\mouselessbrowsingInit.js に 164行目を追加。(設定の読み込み)

163 MLB_exclusiveUseOfNumpad = prefs.getBoolPref("mouselessbrowsing.exclusiveNumpad");
164 MLB_exclusiveUseOfNumpadUnlessWritable = prefs.getBoolPref("mouselessbrowsing.exclusiveNumpadUnlessWritable");
165 MLB_executeAutomaticEnabled = prefs.getBoolPref("mouselessbrowsing.executeAutomatic");

<Fx profile>\extensions\{c0bcf963-624b-47fe-aa78-8cc02434cf32}\chrome\mouselessbrowsing.jar\content\mouselessbrowsing\mouselessbrowsingEvent.js の 361行目を変更。(条件判定ロジックの変更)

361 return MLB_exclusiveUseOfNumpad && isNumpad;

361 return MLB_exclusiveUseOfNumpad && isNumpad &&
362     !(MLB_exclusiveUseOfNumpadUnlessWritable && Utils.isWritableElement(event.originalTarget));

う〜ん。満足。

* Firefoxのプロファイルフォルダ。%APPDATA%/Mozilla/Firefox/Profiles/xxxxxxxx.default

[]5点

  • [コミック] 吉田 基已【水の色銀の月 2 (2) (モーニングKC)】 講談社
  • [コミック] 安藤 慈朗, かとり まさる【しおんの王 4 (4) (アフタヌーンKC)】 講談社
  • [コミック] Cuvie【Emotion (オークスコミックス 夢雅コミックシリーズ)】 オークス
  • [文庫] 山形 石雄【戦う司書と神の石剣 (集英社スーパーダッシュ文庫)】 集英社
  • [文庫] 熊谷 雅人【ネクラ少女は黒魔法で恋をする〈2〉 (MF文庫J)】 メディアファクトリー

2006年07月26日 (水)


2006年07月29日 (土)

Apache-2.2.3

cd httpd-2.2.3
C:\Program Files\Microsoft Visual Studio 8\VC\bin\vcvars32.bat
C:\Program Files\Microsoft Platform SDK\SetEnv.Cmd /XP32 /RETAIL
nmake -f Makefile.win _apached*
nmake -f Makefile.win _apacher

mod_dav_svnは Apache-2.2.2の時のままで動いてるみたい。APRのバージョンが変わっていないということ? mod_dav_svnの再コンパイルだけは勘弁やし。

* _apacher(Releaseモード)だけをやろうとしたら Debugフォルダの存在を仮定してる部分があって失敗したので、先に _apached。


2006年07月30日 (日)

[][SN25P]2点

  • [文庫] 吉野 朔実【少年は荒野をめざす (4) (集英社文庫―コミック版)】 集英社
  • [文庫] 片山 憲太郎【紅―ギロチン (集英社スーパーダッシュ文庫)】 集英社
  • SATAIIケーブル(20cm)

 SATAケーブル

  1. SN25Pの、特定の位置に取り付けた HDDだけがだいたい月一の頻度でクラッシュする。
  2. M/Bには SATAコネクタが 2系統 4つあるのだが、違う系統につなぎ変えてもその位置の HDDだけがクラッシュする。
  3. クラッシュする HDDの位置よりも放熱性が悪く、表面温度が明らかに他より高くなる場所もあるので温度のせいではない。
  4. ケースにプレインストールされていた SATAケーブルが悪いに違いない。

2006年07月31日 (月)

[]3点

  • [文庫] 海原 零【銀盤カレイドスコープ〈vol.7〉 (集英社スーパーダッシュ文庫)】 集英社
  • [コミック] 林家 志弦【はやて×ブレード 5 (5) (電撃コミックス)】 メディアワークス
  • [コミック] 凜野 ミキ【冥界噺 1 (1) (IDコミックス ZERO-SUMコミックス) (IDコミックス ZERO-SUMコミックス)】 一迅社