PythonのDecorator
きっかけはwycatsのこの記事
Python Decorators in Ruby « Katz Got Your Tongue?
「RubyでPythonのDecoratorを実装してみたよー」ってことらしいが、Pythonなんてprintしか知らない僕にはDecoratorがなんだかわからない。
元が何者だかわかっていないので、Rubyでの実装コードを見てみても、いまいち掴めない。
というわけで、手を動かしてPython書いてみた。
下記ページのサンプルを動かしてみた程度。
python のデコレーターは closure に syntax sugar を かぶせたものだと言われます。
とのことです。
元の関数をすり替えてしまえるし、Closureの引数として元の関数自体も呼び出せる。
パッと使い道は出てこないけど、便利そうな感じがしますね!
ここまでやったところで、1年前にRubyで実装されていたのを見つけた。
http://d.hatena.ne.jp/technohippy/20080723#1216808401
http://yugui.jp/articles/792
とりあえず、Decoratorがちょっとわかった。
あとは自分で実装してみる!・・・かどうかはわからない。
Python3.0で変わった事2つ
Decoratorのサンプルを書いている時に、Python2.6と 3.1 の両方でやってみた。
その時にはまった変更点を2つメモ。
- print が構文から関数に変更されている
#python 3.1 print 'hoge' #=> Error! print('hoge') #=> hoge
- func_X の関数が __X__に変更されている
unc_Xとは関数オブジェクトのinspectを行う関数の集まり。
func_Xと名づけられていた関数の属性は、__X__というフォームに改称されました。古いfunc_X形式の名前は関数の属性の名前空間は、ユーザが定義する属性(名)として解放されました。即ちfunc_closure、func_code、func_defaults、func_dict、func_doc、func_globals、func_nameはそれぞれ__closure__、__code__、__defaults__、__dict__、__doc__、__globals__、__name__に改称されました。
だそうな。
Python 3.0 での変更点全訳はこちら
http://text.world.coocan.jp/TSNET/?What%27sNewInPython3.0
複数のRubyを切り替えられるようにする
Ruby1.9をメインで使いつつ、1.8系も準備しておきたかったので併存させられる環境を作ってみた。
OS: Ubuntu 9.04 Server Edition
Rubyのソースを用意する
Subversionで落としてくる。当然trunk。安定とか知りません。
$ svn co http://svn.ruby-lang.org/repos/ruby/trunk ruby
$ svn co http://svn.ruby-lang.org/repos/ruby/branches/ruby_1_8 ruby1.8
必要なライブラリを入れる
OpenSSLとconfigure作成用のautoconf
bisonがどうとかいうエラーが出るので、それも入れておく
$ sudo apt-get install libssl-dev $ sudo apt-get install autoconf $ sudo apt-get install bison
makeする
/local/ruby の下にバージョン番号のディレクトリを作成して、そこに入れる。
プログラムにはバージョン番号を付けておく
$ cd ruby $ autoconf $ ./configure --prefix=/local/ruby/<VERSION> --program-suffix=<VERSION> --with-readline-dir=/local/ruby/<VERSION> $ make $ make test $ sudo make install
シンボリックリンクを張る
aliasを付けてもいいけど、gemとか他のプログラムが /usr/bin/ruby とかを見ている場合があるので、シンボリックリンクを作っておく。
投げやりなシェルスクリプトにしてみる。
$ less switch_ruby.sh #!/bin/sh ORG_PATH=/local/ruby/$2/bin PREFIX=/usr/local/bin for NAME in ruby gem irb rdoc ri do ln -s $ORG_PATH/$NAME$1 $PREFIX/$NAME echo "/usr/bin/$NAME linked @ $ORG_PATH/$NAME$1" done $ ./switch_ruby.sh 1.9 1.9.1
Mitaka.rb #3 & Tokyu.rb #9 に行ってきた
連日だったので、まとめて。
小田急線沿いというどっちつかずの中途半端な位置に生息しているため、
両方に参加してきました。
以下、飲み食いしすぎで記憶がうつろですが覚えている限り。
Mitaka.rb #3
- 会場: 三鷹のリトルスターレストラン
- 30人以上でざわざわ。プログラマーズカフェの人々も多かった。
- 料理はとてもとてもうまかった。食い過ぎで次の日腹痛かったのは内緒。
- 5人ほどLT! After Ruby Kaigi!
- Hamlの会会長、Director's cutで再び。削ったスライドからの質問が飛んだりとかw
- btoさんの話は初めて聞いたことなので大変面白かった。
日本Ruby会議2009に行ってきた
今年初参加です。
3日分の感想等まとめてアップ。それなりに長いけど中身は大してありません。
1日目
Scott Chacon from Github
- 英語が早くてほとんど聴き取れず。スライドがわかりやすかった
- gitの使い方や概念、git の運用パターンなど
- 特にgitの運用パターンは参考になりそう。あとで穴が空く程動画見る。
- Grit ruby-git library http://github.com/mojombo/grit/tree/master
- Gitのホスト設定が超めんどくさいので自動化した。
Adherison (Jason Goecke)
- 後ろの方で充電ついでにコード書いてたので、あんまり聞いてませんでしたごめんなさい。
- でも、Ruby による自動応答アプリケーションのデモはすごかった。
- http://adherison.com
Rails3 (Yahuda Kats@EngineYard)
- 英語が堪能すぎて全く聴き取れませんでした。
- スライドはとてもよかったので、もう一度見直す
- とりあえず「Rails3はすげー変わっちゃうよ」ってことは把握
2日目
Ruby1.8のゆくえ (卜部さん)
- 1.8.7 は 1.8.6 と compatible ではないと思われている
- 1.8.7 => セキュリティやバグ修正優先
- 1.8.8 => 下位互換の予定。1.8系の機能としてはこれで完成
- 1.8.9 => 出ない。
- 1.9移行へむけて、1.9の文法がParse Errorになるのをなんとかしたい
Ruby1.9.2 (Yuguiさん)
Ramaze(Mr. Michael & Mr. Uehara)
Keynote (松本さん)
- lvar_propagateのキモさに度肝を抜かれた。だが、@wycatsが興味を持ったらしい。
- その後、マジックコメントを入れた時だけ挙動が変わるようなパッチが入ったらしい。
- 公平になりましょう。
3日目
TermtterKaigi
- 企画部屋で行われていたTermtterKaigiに参加。http://jugyo.org/blog/3517
- termtter解説とか今後の課題とか。ちょっと課題を思いついたので、そのうちパッチ書く。
- 個人的にCygwinで少し使えるようにしておきたいんだが、環境が自宅にないのが難点。誰かWindowsください。
RubyでMac OS X開発 & iPhone
- RubyCocoa と HotCocoaの紹介
- iPhoneの方はIRCでちら見。あとで見る。
- http://github.com/takuma104/iphone-rubycocoa/tree/master
Haml and Sass
Take the Red Pill(角谷さん)
番外編
- yoshukiさんの経歴をかいま見る。熱い話でした。
- tatsuosakuraiさんの奥さんは美人でできた人らしい。
- takiuchiさんとメガネが一緒だった!メガネスキーとしてはうれしい!!
まとめ
スタッフ、関係者の皆様、親しく接してくださった皆様、ありがとうございました。
また、参加者の方々お疲れ様でした!
来年はLTかスタッフ辺りから関わってみたいです!
後で見る
http://www.ustream.tv/rubykaigi/videos
ニコ動かなんかがアップされたらまとめよう。どれ見るべきか忘れる。
*1:訂正:id間違えてました。ごめんなさい。
Shibuya.lisp テクニカルトーク #3 に行ってきた
letの使い方を先月知ったようなLisp童貞ですが、勇気出して行ってきました。
発表はニコ動にアップされるらしいので、内容は割愛。
色々感じるところが多かったので、感想をダイジェストでお送りします。
Shibuya.lisp » Blog Archive » 2009/07/04 Shibuya.lisp テクニカルトーク #3 開催!!
オープニング
- Shibuya.lisp ではスタッフとTalkerを募集してます!
- 研究室にこもっている人も多いみたいなので、他薦もお願いします
- なんかLispらしい悩みですよね。
世界一短いコードで web アプリ作成ができるフレームワーク開発 (松本さん)
- Lisp暦1年くらい
- それでフレームワーク作り上げるって・・・すげえええええ。
- SLIMEとかいうソフトが動いてた。文字がばらばらーっとしてかっこええ。
- ソケット通信用のソフトだったのね。http://lispuser.net/emacs/lisphacking.html
teepeedee2 fast lisp web server (John さん)
- マクロで簡単にアプリケーション構築が可能なチャットサーバー
Inside c-wrapper (小黒さん)
- GaucheからCライブラリを読み込むライブラリ
- stub書くのが面倒だから、全部自動で作っちゃえ!
- 発想が当然のようでものすごい。
- マンガでわかるc-wrapper
LT
Scheme on Ruby on Rails(yuum3さん)
失敗したら会社終わるようなプロジェクトで本当にlispを使ってみた(mitamexさん)
- PCトラブル。Windowsマシンの表示がおかしく。。。
- 会場にWindowsマシンは数台しかなかった!パワポはなし!!
- 実はあったみたいだけど、激しく盛り上がっていたので引っ張ってしまったらしいw鬼w
- WindowsのピンチをMacが救った!
MongoDB,Tokyo Tyrant, CouchDBのベンチマーク記事
maihaさんの日記を見て、MongoDBのことを思い出したので関連しそうな記事の紹介だけでも。
ヽ( ・∀・)ノくまくまー(2009-07-02)
以下の記事で、3種のkey-valueストレージの性能比較を行っている。
Evaluating key-value and document stores for short read data « Blue Collar Bioinformatics
280万件のレコードを読み込ませ、その初期読み込み時間、レコードの読み込み時間、ファイルサイズの比較を行っている。
- Tokyo Tyrant : 初期の読み込み時間が遅い
- CouchDB: レコード読み込み時間が遅い
- MongoDB: ファイルサイズが大きくなる
となったそうな。
ただ、Pythonのライブラリを経由した結果であること、コメントで様々なツッコミが入っているなど、どの程度信頼性のある数字なのかは読み取れてない。
読解力低くてごめんなさい。正確な情報は元記事を読んでください。
ともあれ
Rubyオブジェクト直接突っ込めるのは楽しそう。やってみよう。