用途によって色んな言語が必要になり勉強してきたんですが、どうも基礎が分かってないので常に習うより慣れろ方式で、毎度繰り返しているうちに効率が悪い気がしてきました。

基礎、要はx86アセンブラで簡単な言語を実装してみれば今後、言語習得も楽なんじゃないかなと思いました。

しかし、業界で10年"作らなければいけない物があり、それに必要な技術をとにかく死に物狂いで覚える"ということを繰り返してきた結果、"作るべき物が無いと何も覚えられない"という体になってしまっていました。

おそらく、"作るべき物"に参照されない情報は寝ている間に僕の"優秀な"GCが回収してしまうようです・・・。 (一番忘れたい、ドラゴンクエストモンスターズに出てきた「"ボミエ"の呪文=敵一人の素早さを下げる」は何故かずっと回収してくれません。)

そこでquekさんに、

「何か簡単な作るべきもの無いですかね」

的なことを聞くと、Forthの処理系でjonesforthというのがコメントが豊富でシンプルなアセンブラで書かれていて分かりやすいということを教えてもらいました。(64bit対応にするのはどうか、とのこと)

もちろんx86アセンブラもForthもさっぱり分かりませんがとりあえず本を買って始めてみました。とりあえず、年明けにjonesforthを何かに移植するという目標でやってみたいと思います。
(本来、8086は専門学校で習ったハズなんですが、僕の優秀な(略・・・)

Debianでapache2落ちたら再起動

$ sudo apt-get install monit
Starting daemon monitor: monit won't be started/stopped
unless it it's configured
please configure monit and then edit /etc/default/monit
and set the "startup" variable to 1 in order to allow
monit to start

Debianでは/etc/default/monitを編集しないと起動しないみたい。

$ sudo vi /etc/monit/monitrc
set daemon 120
set logfile syslog facility log_daemon
set mailserver localhost
set mail-format { from: monit@kmsebisu.com }
set alert dev@actindi.net
check process apache with pidfile /var/run/apache2.pid
start program = "/etc/init.d/apache2 start"
stop program = "/etc/init.d/apache2 stop"
if failed host localhost port 80
protocol HTTP request / then restart
group www-data

便利だわぁ。こんな簡単なら早く使えばよかった・・・。

いつからあるのか分からないけどrake notesでTODOとかFIXMEが見れるらしいので手元のプロジェクトで行ってみた。

% rake notes
(in /Users/komagata/Sites/outing)
app/models/facility.rb:
* [ 52] [TODO] もっとメタな書き方がしたい
* [ 57] [TODO] ハッシュにしたいが、今のとこ,はエラーが出る
* [ 68] [TODO] ハッシュにしたいが、今のところはエラーが出る
* [114] [TODO] リファクタリング
% rake notes
(in /Users/komagata/Sites/tsuisumi)
app/helpers/cemeteries_helper.rb:
* [ 5] [FIXME] クラス変数が共有できないのでメソッドで対処

app/helpers/stone_shops_helper.rb:
* [ 16] [FIXME]

lib/romkan.rb:
* [221] [FIXME] ad hod solution

生々しい。面白いので僕ももっとコメント書いていこうと思いました。

__init__と__call__ってどう違うのかなと思ったけどわかった。

class Foo:
def __init__(self):
print 'init'

def __call__(self):
print 'call'

Foo()()
init
call

__init__はクラスがインスタンス化される時に呼ばれて、__call__はインスタンスが呼ばれた時に動くんですね。

この間書いた、RubyのFoo()とか使ってると混乱するわ!

関連:Ruby - クラス名と同名の関数にデフォルト動作をさせるパターン - p0t

GAEのgoogle.appengine.ext.webapp.WSGIApplicationはRailsでおなじみの_methodパラメータによるメソッドエミュレーションをやってくれないのでREST厨涙目ということで、そこだけのMiddlewareを書いてみました。

import webob

class MethodEmulator(object):
def __init__(self, application):
self.application = application

def __call__(self, environ, start_response):
req = webob.Request(environ)
if req.params.has_key('_method'):
method = req.params['_method'].upper()
if method in ['PUT', 'DELETE']:
environ['REQUEST_METHOD'] = method
return self.application(environ, start_response)

HEAD, OPTIONS, TRACEやWEBDAVのメソッドも何か怖いので無し。

application = WSGIApplication([('/', MainHandler)])
run_wsgi_app(MethodEmulator(application))

こんな感じで被せて使う。

Rackだとuse MethodEmulatorって感じだったけどRuby始めたばっかりで、

「useなんて予約語無いじゃないか!」

とか迷ったので明示的なのも分かりやすくて良いですね。

REE

$ wget https://packages.endpoint.com/endpoint-rpmsign.pub
$ sudo rpm --import endpoint-rpmsign.pub
$ sudo yum remove ruby*
$ wget https://packages.endpoint.com/rhel/5/os/i386/ruby-enterprise-1.8.7-2.ep.i386.rpm
$ wget https://packages.endpoint.com/rhel/5/os/i386/ruby-enterprise-rubygems-1.3.5-2.ep.i386.rpm
$ sudo rpm -ivh ruby-enterprise-1.8.7-2.ep.i386.rpm
$ sudo rpm -ivh ruby-enterprise-rubygems-1.3.5-2.ep.i386.rpm

RMagick

$ wget http://ftp.kddlabs.co.jp/graphics/ImageMagick/ImageMagick-6.5.8-6.tar.gz
$ tar zxf ImageMagick-6.5.8-6.tar.gz
$ cd ImageMagick-6.5.8-6
$ ./configure --prefix=/usr
$ make
$ sudo make install
$ sudo gem install rmagick
天地創造

何時の間にやらMacでのSnes9xが動くようになってるらしく、無線コントローラーのLogicool Cordless Rumblepad 2と合わせるととても快適。

俺のようなどうせ最新ハードでもレトロゲームやその復刻版か続編しか食手が伸びないおっさんにとってはこういう方が楽しいかも。

Snes9xはC++だそうですが、MacのIntel化の恩恵は少なくなさそうです。

ロジクール Cordless Rumblepad 2(ブラック) GPW-600

svn最新だけをclone

職場はsvnで個人的にgitを使うときなど、全部持ってくると死ぬほど時間がかかるので最新のtrunkだけ持ってくる。

% git svn clone -rHEAD https://svn.example.com/unk/trunk unk

svnから更新分を持ってくる

% git svn rebase

svnへ更新分を反映する

% git svn dcommit

空ディレクトリの削除をsvnにお伝えする

% git svn dcommit --rmdir

svnをgitに変換

-sは--stdlayoutでtrunk/, branches/, tags/構成を想定してブランチに変換してくれるそうです。

% git svn clone -s http://foo.com/repos/project

ブランチ一覧

% git branch

ブランチ作成

% git branch michel-jackson

ブランチ切り替え

% git checkout michel-jackson

ブランチ作りつつ切り替え

% git checkout -b michel-jackson

ブランチをマージ

% git checkout master
% git merge michel-jackson

一個前のコミットをなかった事にする

% git reset HEAD^

昔のコミットを修正する

% git rebase -i 695b1eb
(修正)
% git commit --amend
% git rebase --continue

タグ付ける

% git tag v0.0.1
% git push --tags

タグ情報付きで持ってくる

% git pull --tags

一つ戻して無理やりpush

% git reset --soft HEAD^
% git ci -a -m 'やりなおし'
% git push origin master --force

ブランチをpush

% git push origin win32

localにphp5.3.1とwordpress2.8.6をインストールしてみるが、DBに繋がらないとのエラー。詳細が知りたいのでphp.iniのerror_logを設定してエラーログを見てみるが何も出力されてない。

<?php trigger_error('error raising!'); ?>

上記の様なスクリプトを実行してみると確かにエラーログに残るのだが・・・。

% grep -r @mysql .
./wp-includes/wp-db.php: $this->dbh = @mysql_connect($dbhost, $dbuser, $dbpassword, true);
./wp-includes/wp-db.php: if (!@mysql_select_db($db, $this->dbh)) {
./wp-includes/wp-db.php: $this->result = @mysql_query($query, $this->dbh);
./wp-includes/wp-db.php: while ($i < @mysql_num_fields($this->result)) {
./wp-includes/wp-db.php: $this->col_info[$i] = @mysql_fetch_field($this->result);
./wp-includes/wp-db.php: while ( $row = @mysql_fetch_object($this->result) ) {
./wp-includes/wp-db.php: @mysql_free_result($this->result);

なるほど・・・。

これだと原因究明が難しいのでmysql_connectの@を取って実行してみた。

% diff wp-includes/wp-db.php{,.org}
341c341
< $this->dbh = mysql_connect($dbhost, $dbuser, $dbpassword, true); # FIXED by komagata
---
> $this->dbh = @mysql_connect($dbhost, $dbuser, $dbpassword, true);

php_errors.log:

[14-Dec-2009 02:49:02] PHP Warning:  mysql_connect() [<a href='function.mysql-connect'>function.mysql-connect</a>]: [2002] No such file or directory (trying to connect via unix:///tmp/mysql.sock) in /users/komagata/Sites/wordpress/wp-includes/wp-db.php on line 341
[14-Dec-2009 02:49:02] PHP Warning: mysql_connect() [<a href='function.mysql-connect'>function.mysql-connect</a>]: No such file or directory in /users/komagata/Sites/wordpress/wp-includes/wp-db.php on line 341

なるほど、/tmp/mysql.sockにソケットファイルがあると思っているために接続できないらしい。

PHP: 実行時設定 - Manual

mysql.default_socket string

他にソケット名が指定されない場合、ローカルなデータベースサーバに 接続する時のデフォルトのソケット名。

php.iniにデフォルトのMySQLのsocketの場所を設定できる項目があることがわかった。ちなみに接続時のhostにもlocalhost:/path_to/mysql.sockといった指定が可能らしい。

PHPのマニュアルは非常に詳細な内容も記載されていて、日本語訳も充実しているので巷で問題になってたりすることの殆は公式マニュアルで解決することが多い。

macportsで入れた場合のmysqlのデフォルトのsocketの場所である/opt/local/var/run/mysql5/mysqld.sockを指定したら動いた。

問題解決のためにはコード内でエラー抑制はせず、各個人の環境でdisplay_errorsやerror_logを設定すべきだと思うが、php.iniが弄れない共有レンタルサーバーで使われることが多い事や、エラーがズラズラでてもパニックに陥るだけといった理由でこういう作りになっているのかなと思った。

本番環境ではすべきでないが、大抵の共有レンタルサーバーと同じ様にdisplay_errosOnにした場合、エラー抑制子を外すと、データベースに接続できない場合はこんな感じになる。

データベースエラー

たしかにちょっと怖い感じがするかも。初めてのインストールでこれが出たら諦めちゃう人も多いかも。