デバッグ時のお助けGemを作ってRubygemsに公開してみた
プログラムを書いて自分の思い通りに動かない時にこんな事やりません?
- 変数や配列などの値が何なのか、片っ端からprintしてみる
- if文や条件分岐などで、どこを通っているのか調べる為に、何かしらのprint文を埋め込んで、何処を通ったか可視化して調べてみる
- Rubyの場合、オブジェクトが何のクラスなのか、とりあえず puts hoge.class で出力して調べてみる
いわゆる、Printデバッグってやつですね。自分で作っているプログラムはそんなに大きくない事と、テスト駆動する程までもなかったり、そもそもテストの書き方もイマイチピンときていなかったり。
で、自分用にデバッグを助ける為に、ログを書き出すGemを作ってみました。
どんな事が出来るか
任意のログファイルを生成し、それに色んな値を書き出すクラスを作ってみました。 プログラムの冒頭部分でオブジェクトを生成します。引数には、書き出すログのファイルパスを指定します。
プログラム内の任意の場所で、
する事ができます。
色々思案したこと
bundlerを使ってGemを公開するまでの流れ
- bundleを使って、ひな形を作る
bundle gem gem_name --test
- libディレクトリの直下の.rbファイルに、moduleを定義し、中に目的のClass定義を書く。
- specディレクトリ直下に、spec_gem_name.rbファイルを作成し、テストを書く。
- gem_name.gemspecファイルを編集して、gemの内容等を英語で書く。編集内容はこんな感じ
- github用にREADME.mdも編集する。
- rake buildコマンドでビルドして
- rake installコマンドでローカル環境にインストールして動くか試す。
- Githubにpushする
- rake release でrubygems.orgに公開する
出来上がったGemは、rubygebs.org とGithubに上げてみました。
プログラミング言語C K&R著の演習問題を解答していく その7
C言語のバイブルと言われる、K&Rの「プログラミング言語C」を第一章から読み進めて演習問題を記録していく。
- 作者: B.W.カーニハン,D.M.リッチー,石田晴久
- 出版社/メーカー: 共立出版
- 発売日: 1989/06/15
- メディア: 単行本
- 購入: 28人 クリック: 721回
- この商品を含むブログ (200件) を見る
本を読んでコードを書いたのが全開ブログを書いた時期で、以降、Cに触れる期間が相当空いてしまって随分忘れてしまってる... 継続する事が大事ですね。
第4章
- 4-1 文字列の中のパターンマッチで、最も右側のインデックスを返す関数を書く。
- 4-2 文字列を浮動小数点型(float)に変換するコードを指数表記できるように改変。
- 4-4 みんな大好き逆ポーランド記法の電卓プログラムに、値の複製や2値の交換機能を追加する。
- 4-13 再帰を使って文字列を逆転させる関数。
- 4-14
defineを使ったマクロ機能を使うプログラム。いわゆる「置換」機能と理解。
第4章、関数の使い方を学ぶ章。 再帰は仕組みがすごく好きなのだけれど、うまく使う方法がいまいちマスターできていないので使い処を知りたい所存。
Perl鍋#6に参加して、Mouseを使ったオブジェクト指向の書き方とグランフロント大阪を満喫してきた
Perl鍋に参加しました
大阪でPerlをもくもくと書いて発表したり教え合う勉強会、Perl鍋#6に参加してきました。 この勉強会の主催者は、Perl入学式in大阪で講師もされている @nqounet さんです。 勉強会の位置づけは、Perl入学式でひと通り基礎を学んだその次のステップ、「自ら何かを作ってみよう」という趣旨だそうです。
会場はグランフロントの中にあるKnowledge Salonという会員制スペース、広くて綺麗で、飲食も可能な最高の空間でした。
最近はC言語とRubyを主に勉強していたので、Perlを書くのは久しぶりでした。 何を作るか、は始まってから考えようと
- 作者: 冨田尚樹,タナカユカリ
- 出版社/メーカー: ワークスコーポレーション
- 発売日: 2011/04/08
- メディア: 単行本(ソフトカバー)
- 購入: 20人 クリック: 2,028回
- この商品を含むブログ (21件) を見る
を持参して行きました。 主催の @nqounet オブジェクト指向の設計が難しい云々といった雑談から、Perlで書くならMouseというモジュールが良いという話になり、PerlでMouseを使って基本的な書き方を試してみました。
書いた(試した)コード
Mouseは、
package Hoge; use Mouse; 1;
と書くだけで、Hogeクラスが定義できて、クラスの中で
has 'bar'=>();
と書くとプロパティ(インスタンス変数)、サブルーチンを書くことでメソッドが定義出来てしまいます。 今までは、Perlのオブジェクト指向といえば、blessを使って・・・と結構理解するまで難しかったイメージでしたが(過去のブログ記事)Mouseモジュールを使えば、簡単に実現出来ますね。とても簡単に。
継承だとかメソットのオーバーライド等を例にして、Perl入学式スタッフのクラスを定義し自己紹介をするコードを書いてみました。
Staff が大元のクラス、そこから継承させた派生クラスがPapixクラス、Azumaクラス、そしてPapixクラスから更に継承させたクラスがBoolfoolクラスです。ごく短いコードなので、読めばすぐに雰囲気がつかめるかと思います。
staff.pl
ファイルを実行すると、各クラスのインスタンスが自己紹介をします。
まとめ
今回参加して、初めてMouseのモジュールを使った事も勉強になりましたが、 @nqounet さんが作ったSlackのウェブフックも解説付きでコードを見せてもらい、こちらも新しい知見が得られました。evalを使ったエラートラップのイディオムとか、なるほどなーって感じでした。 また、普段書く機会が無いので、久しぶりにPerlオンリーの書く機会が出来たので良かったです。 普段、Perl書く機会が無いんだけどなーって方にオススメです。
大阪では、Perl入学式の次のステップとしての勉強会、Perl鍋やなにわPerlがあります。今年も開催していきますので、皆さん是非ご参加下さい。
プログラミング言語C K&R著の演習問題を解答していく その6
C言語のバイブルと言われる、K&Rの「プログラミング言語C」を第一章から読み進めて演習問題を記録していく。
- 作者: B.W.カーニハン,D.M.リッチー,石田晴久
- 出版社/メーカー: 共立出版
- 発売日: 1989/06/15
- メディア: 単行本
- 購入: 28人 クリック: 721回
- この商品を含むブログ (200件) を見る
第3章
- 3-1 二分探索法の関数の中身を書き換える問題。if文を2回重ねて比較しているコードを1回のif文のコードに書き換える。(if文の工夫)
- 3-2 文字列の中の空白やタブを可視化した文字列に置き換えるコード(switch文を使って)。
- 3-3 文字列の中の省略形記号(a-zや0-9など)を展開させるコード(ループを使って)。
- 3-4 整数を文字列に変換するコード。2の補数での負数表現を使った場合、負数最小値は最左ビットを含めた数値表現になる為、負数取り扱い時に工夫が必要。
- 3-5 符号なし整数値を指定された進数表現に変換するプログラム。
- 3-6 桁数の指定も含めた整数を文字列に変換するプログラム。文字列が桁数に満たない時はブランク文字を使って右詰めにする。
実はずいぶん前に終えていた第3章。
問題文の読解が難しかったのと、3−4、3−5のテクニック的な部分は難しかったのでアンサーブックからヒントを得て自分なりのコードを書いてみた。
第4章は近日中に上げる予定です。
プログラミング言語C K&R著の演習問題を解答していく その5
C言語のバイブルと言われる、K&Rの「プログラミング言語C」を第一章から読み進めて演習問題を記録していく。
- 作者: B.W.カーニハン,D.M.リッチー,石田晴久
- 出版社/メーカー: 共立出版
- 発売日: 1989/06/15
- メディア: 単行本
- 購入: 28人 クリック: 721回
- この商品を含むブログ (200件) を見る
第2章
2-1 問題文の意味がよくわからないのでパス。
2-2 1行の文字列を取得するfor文を、論理演算子を用いて書く。
- 2-3 16進数文字列を整数値に変換するコード。
- 2-4 文字列s1から、s2に含まれる文字を削除するコード。
- 2-5 文字列s1の中から、文字列s1がマッチした位置を返す。含まれていなかったら、-1を返す。
- 2-6 ビット(2進数の値)の一部を取得して入れ替える関数。
- 2-7 ビットの一部をビット反転する関数。
- 2-8 ビットの回転させる関数。回転とは右にシフトで押し出された値が左からシフトされる様子。
- 2-9 ビットの中の'1'の個数を数える関数。
最初、意味がさっぱり分からなくて解説をググって「x & (x - 1)の挙動」を目の当たりにして感動。 コードのアルゴリズムで感激したのは、フィボナッチ数を再帰で取得するコード以来。
- 2-10 大文字を小文字に変換するプログラム。if-else文を使わずに、? : 式を使って書く。
少しずつ進めて第2章が終了。 ビット演算のコードが面白かったのだけれど、実際には何処で活用すれば良いのだろうか。
プログラミング言語C K&R著の演習問題を解答していく その4
C言語のバイブルと言われる、K&Rの「プログラミング言語C」を第一章から読み進めて演習問題を記録していく。
- 作者: B.W.カーニハン,D.M.リッチー,石田晴久
- 出版社/メーカー: 共立出版
- 発売日: 1989/06/15
- メディア: 単行本
- 購入: 28人 クリック: 721回
- この商品を含むブログ (202件) を見る
第1章
- 1-21 ブランク列をタブとスペースを組み合わせて最小数で構成しなおす関数
- 1-22 n文字目までの最後の非ブランク文字で改行するプログラム。
- 1-23 Cのソースからコメント文を除去するプログラム。ファイル読み込みはまだやっていないので、テキストはcat と | で受け取る事とする。
- 1-24 Cのソースから( )[ ]{ }が足りているか調べるプログラム。同じくテキストはcat と | で受け取る事とする。
テキスト処理に正規表現が使えないの、辛い。 とりあえず第1章はなんとか終了。
プログラミング言語C K&R著の演習問題を解答していく その3
C言語のバイブルと言われる、K&Rの「プログラミング言語C」を第一章から読み進めて演習問題を記録していく。
- 作者: B.W.カーニハン,D.M.リッチー,石田晴久
- 出版社/メーカー: 共立出版
- 発売日: 1989/06/15
- メディア: 単行本
- 購入: 28人 クリック: 721回
- この商品を含むブログ (202件) を見る
第1章
1-16 問題文がよくわからない
1-17
- 80文字は長いので、8文字以上ある行を出力する
- 1-18
- 行末のブランク、タブを削除 && 空白行を削除して出力する
- 1-19
- 文字列を逆さまにして出力する
- 1-20
- 決まったタブストップで語句を区切って出力