shipit.rb
よびわけにこまったので shipit.rb とよぼう……
- svk その他への対応
- Commit/Tag とかの実際の処理を分離する
- Rake::ShipitTask::VC::{SVN,SVK,Git} とかかなぁ
- ステップ間で共有される state
- instance_variable_set でハッシュセットすればいいかなぁ
をやんないとだけど、ここにこんなふうに書いてる時点でやる気ないよなぁ (今ちょっと svk をつかっていないので、svk 使うようになったらすぐに実装する感)
というかさっきまで全くオリジナルの ShipIt のコードを読んでなかった (Shipit::Step::Twitter だけ先に読んで処理を想像してた) ことに気付いてあわてて読んだ (全部じゃないけど)……アイデアだけでふくらませて考えてた。やばい…… CPAN はオンラインで簡単にソースよめていいなぁ。rubyforge も直接見れるリンクがほしい。
ちなみに shipit.rb で initialize と prepare にわけたのは、initialize っていう名前が Ruby 的に特別な名前なので、あんまり準備をするっていうイメージがないからです。instance_variable_set するなら initialize とわけたのは正解かなぁ (new すると initialize が走ってしまうので instance_variable_set するタイミングがない)
http://coderepos.org/share/changeset/4139
state には対応した。instance_variable_set はちょっと黒い気がしたので (みえないうちにセットされてしまうので)、いまのうちに initialize の仕様を変えることにした。
update hatena with mechanize
require "rubygems"
require "mechanize"
require "pit"
config = Pit.get("hatena.ne.jp", :require => {
"username" => "username of hatena",
"password" => "password of hatena",
"diaryurl" => "http://d.hatena.ne.jp/[your id]/"
})
agent = WWW::Mechanize.new
page = agent.get "https://www.hatena.ne.jp/login?backurl=http%3A%2F%2Fd.hatena.ne.jp%2F"
form = page.forms.first
form["name"] = config["username"]
form["password"] = config["password"]
page = agent.submit(form)
raise "Login failed.." unless page.forms.empty?
page = agent.get "http://h.hatena.ne.jp/"
rkm = page.forms.last["rkm"]
page = agent.post config["diaryurl"], {
"rkm" => rkm,
"title" => "test",
"body" => "test test from mechanize",
}
p pageinplace edit の API をたたく。g.hatena もおなじでできる (URL だけかえる)。はてなはサブアカでも更新できるので、スクリプトから更新するときは、専用のサブアカ作ってパスワード設定するほうがすこしだけ安全かも。
RKM ははてな全体で共通みたいなのでてきとうなところからとってきてる。ハイクだと URL にユーザ名が入らなくて手軽っぽい (config に id じゃなくてメールアドレスいれてもいけるとかいう意味で)。
shipit.rb の Step にしようとおもったけど微妙だったのでやめた……(ハイクへの通知だとサブアカでの発言になってしまう)
shipit.rb
続・ブックマークレットとかで、設定を先頭に書けるようにする
http://subtech.g.hatena.ne.jp/cho45/20070923/1190498279 というのを書いたけど、もういっこ考えてみた。
javascript:["foobar",0].sort(function(a){alert(a)});void(0);最初に一文字入ってしまうけどそこそこいい感じ。二つまでは任意の引数がわたせる (三つ以上は二回以上よばれる)
javascript:["foo","bar"].sort(function(a,b){alert([a,b])});void(0);二文字以上とかになると普通に s="foobar";(function(){})(s); とかやればいいけどグローバル変数つかうのはなんか気持ち悪いよなぁ。
script 挿入
javascript:["url",0].sort(function(a){document.body.appendChild(s=document.createElement("script"),s.type="text/javascript",s.charset="utf-8",s.src=a)});void(0);javascript:["url",0].sort(function (a) {
document.body.appendChild(
s = document.createElement("script"),
s.type="text/javascript",
s.charset="utf-8",
s.src=a
)
});
void(0);
- JS では必要な引数以上わたしても普通は問題ない。
- 関数は引数が全て評価されてから実行される。
replace のほうがマシかなぁ。一文字あるだけで違う
Proto and Tree Style Tab
Fx3 on Mac のテーマになるらしいやつをちょっとつかってみる ( https://addons.mozilla.org/en-US/firefox/addon/6050 )
けど、縦置きのタブは全く考慮されていないので (そりゃそうだけど) スタイルあてなおした
@namespace url(http://www.mozilla.org/keymaster/gatekeeper/there.is.only.xul);
.tabbrowser-tabs * {
width: 100% !important;
}
.tabs-stack {
width: 10em !important;
padding: 5px 0 0 0 !important;
border-style: solid !important;
border-width: 1px 0 0 0 !important;
border-color: #444 !important;
background:#797979 url("") repeat-y top right !important;
}
.treestyletab-splitter {
background: #b3b2b3 !important;
border-style: solid;
border-width: 0 1px 0 0 !important;
border-color: #4e4e4e !important;
}
tab .tab-icon {
margin: 0 0 0 0 !important;
}
tab .tab-text-stack {
padding: 6px 4px 4px !important;
}
tab {
background: url("") repeat-x top left !important;
border: none !important;
padding: 0 0 0 0 !important;
height: 26px !important;
}
tab .tab-image-left {
background: url("") no-repeat top left !important;
width: 10px !important;
}
tab .tab-image-right {
background: url("") no-repeat top left !important;
width: 10px !important;
}
tab[selected="true"] {
color: #000 !important;
border: none !important;
background: url("") repeat-x top left !important;
height: 26px !important;
}
tab[selected="true"] .tab-image-left {
background: url("") no-repeat top left !important;
width: 10px !important;
}
tab[selected="true"] .tab-image-right {
background: url("") no-repeat top left !important;
width: 10px !important;
}色とか改訂されて使えなくなりそうだ
place: URI
memo
- http://mxr.mozilla.org/firefox/source/toolkit/components/places/src/nsNavHistoryQuery.cpp
- http://mxr.mozilla.org/firefox/source/toolkit/components/places/public/nsINavHistoryService.idl
- http://developer.mozilla.org/en/docs/Places:Query_System
いまいち使えない感……
- タグでの検索はどうやるんだろう (terms は title と url だけっぽい?)
- 定数なのがいちいちめんどい (うえのソースから検索)
- というか生の SQL かかせてほしい
- 現在みている URL によって……みたいなことをしたい
XPCOM 叩いたほうがよさそうだ……
Organizer で place: をかきかえても反映されないので、変更したらブックマークをつくりなおす必要があった。
mozStrage たたくしかないのかなぁ。でも自力で open したら壊れそうだ。
Gmail の web UI を常用してみる
Thunderbird のスレッド時のソート法がどうしても気になりだして拡張を入れたりしたのだけど、結局やりたいのは Gmail みたいな表示だったので、だったら Gmail そのまま使えばいいよなぁという話でした。(今までは IMAP 経由) それと、Thunderbird は Fx ほど userChrome.js を使って拡張する気になれないので、Greasemonkey で拡張できるならそのほうが楽かなぁとかいうのもあります。
公式の Gmail Notifier だとマルチアカウントに対応してないので Fx の拡張をいれてみた。Fx3 b2 にも対応してた。

