2011年9月18日日曜日

更新停止

引越しを前提にこっちで作業性確認中

引越ししました。
epgrecブランチ(もしくはフォーク)「epgrec UNA」を公開!
人柱募集中です。

2011年9月11日日曜日

いまこんなかんじ

番組表
三重テレビとEテレがマルチ編成になっているのが分かる。

番組表上での予約表示
灰色になっている番組は、自動予約禁止になっている。




公開だがもう少しかかリそう。
・マルチ編成対応を試験運用中
・公開にあたりインストールや環境変化への対応が必要
・追従処理のNHK対応が完了していない。くたばれNHK

あと気になる点だが
・衛星波まわりは、受信環境がないためEPG処理を筆頭に色々漏れがあると思う。
・まれにEPG歯抜けがepgdumpでの処理段階で発生する。SDTが抽出できない場合やEITも途中での歯抜けがあるようだ。何が原因なのか不明というか追求していない。
・自動キーワードのパラメーター変更UIがない。(phpMyAdminで済ましている)

2011年8月12日金曜日

epgrec 地デジ・マルチ編成チャンネル対応

epgdumpは、Rec10版に今まで行った変更を適用した。

epgrecは、config.phpのチャンネル設定仕様を弄らない方向で対応した。
xml取り込み時のeit[schedule]とeit[pf]のマージ処理がマルチチャンネルに対応していなかったため手間取った。これで衛星波も対応したはず。
デバッグは、まだ行っていない。チャンネルDBの内容が変化するため環境復旧が厄介になるからだ。
デバッグは時間の取れる日曜の夜になりそうだ。

2011年7月30日土曜日

録画直前のEPG更新(時間追従処理) その4

昨日と今日、NHKの高校野球に絡む予約でデバッグを行ったがうまく行かない。
EIT[schedule]が更新されず、またEIT[pf]の次番組情報も未定なため以降の番組が中止なのか繰り下がりなのか判断できないからだ。やっぱりNHKは鬼門だ。

今のままでは中止と繰り下がりの両方に対応できないのでとりあえずaribの仕様にある未確定期間のEPG二重化を検討する。かなりの大改修になるので出来れば避けたかったが仕方がない。
あと他にも仕様を見落としているのかもしれないのでaribの資料を見直さなければ

2011年7月23日土曜日

EPG放送局変動対処パッチ

番組表の異常 で述べた症状への対処パッチをあげる。
ただし本当に放送局名変更があった場合にその局のEPGが更新されなくなる副作用があるので注意すること。
放送局名変更があった場合は、放送局名をDB上で直接変更するかこのパッチを一時的に戻しgetepg.phpを動かせばよい。

本問題は、PT2での正常受信が確保できない限り根治しない。
このパッチは、あくまで対処療法である。


*** storeProgram.inc.old.php 2010-09-04 21:08:26.074996000 +0900
--- storeProgram.inc.php 2011-07-22 23:09:27.217377015 +0900
***************
*** 65,73 ****
     }
    }
    else {
!    // 存在した場合も、とりあえずチャンネル名は更新する
     $rec = new DBRecord(CHANNEL_TBL, "channel_disc", $disc );
     $rec->name = $ch->{'display-name'};
    }
    }
    catch( Exception $e ) {
--- 65,81 ----
     }
    }
    else {
! /*   // 存在した場合も、とりあえずチャンネル名は更新する
     $rec = new DBRecord(CHANNEL_TBL, "channel_disc", $disc );
     $rec->name = $ch->{'display-name'};
+ */
+    // チャンネル名の更新ではない場合に被害が大きいのでログを残して終了する
+    $rec = new DBRecord(CHANNEL_TBL, "channel_disc", $disc );
+    if( $rec->name != $ch->{'display-name'} ){
+     reclog( 'getepg::チャンネル名が違います('.$disc.' [OLD]'.$rec->name.' -> [NEW]'.$ch->{'display-name'}.')', E_ERROR );
+ //    $new_name = $xmlfile.'.'.date("Y-m-d H:i:s", time());
+ //    rename( $xmlfile, $new_name );
+     return; //信頼できないデータなので終了
    }
    }
    catch( Exception $e ) {

2011年7月20日水曜日

新実装箇所のバグつぶし

前回の
>使用上では問題はないが重複による予約漏れのログ出力がされなくなったので原因を究明中
は、新規予約と重複する既存予約との優先度判定のDBクリエ生成にバグがあった。
当方がPHPの仕様に不明であることによるバグかと思っていたがかなり間抜けなバグだった。

他に番組表で予約表示をチューナー毎に色分けするように改修したときに予約表示をバックグラウンドからボーダーに変更した為、縦方向での表示ズレが発生していたのを修正した。また既存予約のチューナーが変更された場合に番組表をリロードするようにした。

2011年7月15日金曜日

自動録画キーワードへの優先度の追加

チューナー番号の割り振りに不満が有ったのでそれを修正がてらついでに長らく放置していた自動録画キーワードへの優先度の追加を実装した。

使用上では問題はないが重複による予約漏れのログ出力がされなくなったので原因を究明中