デバッグ用に楽なクラス
んと。まぁMWのレポジトリ見に行けばあるのですが( http://svn.sourceforge.jp/cgi-bin/viewcvs.cgi/debug_util.inc?rev=37&root=magicweapon&view=log )。
割合に便利な「デバッグ専用クラス」です。
dump_stringメソッド(及びそのラッパーであるdump_string_putメソッド)は、基本的には「なんか文字化けってるんだけど〜」な時に便利です。
とりあえず「文字列の16進数表記でデータとにらめっこすると」、中で何が起きてるのかが大抵わかりますから。
…っつか。昔は「dump出力」って基本中の基本だったと思うですがねぇ。
本当は「変数が実際に展開されているメモリ番地」も表示したかったのですが…方法がわからない orz
それが出来たら、いにしえの出力方法で出力しようと思ったのにw
backtrace_stringメソッドは、PHPのdebug_backtraceの戻り値を「自分なりに見やすく整形した」ものです。
とりあえず「どこからど〜ゆ〜風に呼ばれたのか」が明らかになるので、最近重宝してます。
フレームワークとか使ってる人とか楽かも。
結構デバッグとか「大甘」なので。突っ込みどころありましたらじゃかすかくださいませ。
<?php /** * debug用utilクラス * * @package magicweapon * @link http://www.grid-works-guild.net/MagicWeapon/ MagicWeapon * @access public * @author Michiaki Wuzawa <wuzawa@m-fr.net> * @create $LastChangedDate$ * @version $Revision$ **/ class debug_util { /** * 文字列のcharコード出力 * * @access public * @param string& $s 出力したい文字列への参照 * @param boolean $flg ここがtrueなら元文字列も出力、falseなら未出力 * @return string 出力用文字列 */ static public function dump_string(&$s, $flg = true) { //var_dump($s); $len = strlen($s); if (true === $flg) { $ret = $s . '('; } else { $ret = '('; } for($i = 0; $i < $len; $i ++) { $ret .= sprintf("(%02x)", ord($s[$i]) ); } $ret .= ')'; return $ret; } /** * 文字列のcharコード出力:stdoutらっぱー * * @access public * @param string& $s 出力したい文字列への参照 * @param boolean $flg ここがtrueなら元文字列も出力、falseなら未出力 */ static public function dump_string_put(&$s, $flg = true) { print debug_util::dump_string($s, $flg) . "\n"; } /** * debug_backtrace関数の整形版 * * @access public * @return string 出力用文字列 */ static public function backtrace_string() { // $awk = debug_backtrace(); // 一つ目は自分をcallしてるのがわかってるから削除 array_shift($awk); // 逆積みしてるっぽいので配列を反転 // XXX リバースイテレートとかありゃいいのに orz $awk = array_reverse($awk); $ret_array = array(); foreach($awk as $wk) { //var_dump($wk['class']); //var_dump($wk['function']); //var_dump($wk['args']); // $ret = $wk['class'] . $wk['type'] . $wk['function'] . '('; // XXX empty好かんのやけどなぁ if (false === empty($wk['args']) ) { $type_awk = array(); foreach($wk['args'] as $wk_args) { $type_awk[] = gettype($wk_args) . ' ' . $wk_args; } $ret .= implode(', ', $type_awk); } // $ret .= ')'; // $ret_array[] = $ret; } // $ret = implode(' => ', $ret_array); // return $ret; } //private: } // end of class