2011年12月27日火曜日

Visioで接続ポイントを追加する


プログラムの相関図をVisioで描いていて、「一つのオブジェクトに複数のプログラムがアクセスする」という事象に遭遇した。
単に、そのままコネクタを接続させれば目的は果たせるんだけど、一つの図形にコネクタが何本もくっついて、コネクタの方はみんな重なって表示されてしまって、どうにも見づらい…。
どうにかならないのかなぁ、と思って調べていたらオブジェクトの接続ポイント増やせばいいことが分かった。
http://office.microsoft.com/ja-jp/visio-help/HP001231166.aspx

簡単に書くと

  1. メニューの[表示]から[接続ポイント]をクリックして、接続ポイントツールを使えるようにする
  2. 接続ポイントを追加したい図形をクリック
  3. [コネクタツール]の横の▽をクリックして[接続ポイントツール]を選択
  4. 接続ポイントを追加した図形上で、Ctrlを押しながら、クリックすればOK


これで見やすくなった!

2011年12月15日木曜日

pg_queryでSQLの失敗時にFALSEを返さない


PHPからPostgreSQLへpg_queryでSQL文を実行してみている。
その時に、構文間違いやデータ整合性などの理由で失敗する。
で、エラーを出して終了してしまう。

マニュアルによるとFALSEを返すはずなんだけど…。
とりあえずset_error_handlerでカスタムエラーハンドラを作って対処してみた。



function pg_query_test( $conn )
{
  $sql = "INSERT INTO NO_EXIST_TABLE VALUES ( 1 );";
  // エラー終了させないようエラーハンドラをセット
  set_error_handler( "my_error_handler" );
  $result = pg_query( $conn, $sql );
  restore_error_handler();if ( $result )
  {
    return true;
  }
  else
  {
    return false;
  }
}
function my_error_handler( $errno, $errstr, $errfile, $errline )
{
  echo "[errno]:   $errno\n";
  echo "[errstr]:  $errstr\n";
  echo "[errfile]: $errfile\n";
  echo "[errline]: $errline\n";
}
?>


実行してみて、errnoは2(E_WARNING)と分かった。
しかし、pg_queryの前でset_error_handlerして、終わったらrestore_error_handlerってのもあんまりスマートなやり方じゃないね…。
ひとまずこれで行っておくか…。

と思いきや、pg_queryだけじゃなくて、pg_copy_fromなんかでも同じようにエラーを出して終了しちゃう…。
さすがにpg_系が全部間違っているとは考えにくいので、DBかPHPの設定?と思い、とりあえず/etc/php.iniを見てみた。
"Error handling and logging"の部分で、
error_reporting  =  E_ALL
となっているのを発見。

試しに関数内で
error_reporting( E_ERROR );
にしてみたところ、失敗してもちゃんとFALSEを返すようになった!

ただ、これだと毎回error_reporting関数を呼ばなくちゃいけないので、面倒。
/etc/php.iniを変えて問題なければ、書き換えたほうが楽だね。
多分、問題ないけど検証してからやってみよう!

2011年12月14日水曜日

シェルスクリプトの関数にパイプで渡す


bashでシェルスクリプトを書いていて、関数を使っていたんだけど、パイプで標準入力を渡したくなった。
で、どうしたもんかと思っていたら、こちらに出会った。
http://dsas.blog.klab.org/archives/51060184.html

これは素晴らしい!
実はパイプでどう受けるとかも知らなかったので、
cat -
を知っただけで目からウロコ。

さらには、testコマンドで パイプで繋いできてるのかまで判定できると知って衝撃。
これは便利。

助かりました!