んと。まぁ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