Core Bluetooth を使う開発をしていると、「あれ、さっきは普通にWriteリクエスト飛んだのに、今回は飛ばなかったな・・・」みたいなトラブルがたびたびあります。 で、原因を調査すべく CBCentralManagerDelegate や CBPeripheralDelegate プロトコルの各種デリゲートメソッドに NSLog (Swift なら println)を仕込んだりするわけですが、それぞれサービスやらキャラクタリスティックやらがたくさんあって、さらにペリフェラルが複数台ある場合、ログが大量に流れてどのペリフェラルがどこでコケてるのか追いかけるのが大変 ということがあります。 そんなわけで、ペリフェラル別にログをはく「PeripheralLogger」というクラスをつくりました。 出力例 このロガーを使用すると、サンドボックス配下の Caches/Logs に "{ペリ