• R/O
  • HTTP
  • SSH
  • HTTPS

TinyBannavi: Commit

タイニー番組ナビゲータ本体


Commit MetaInfo

Revisión9052bf23cc1f5d8373c39725ea910741f56ad685 (tree)
Tiempo2014-09-12 14:15:46
Autorpeeweedee <peeweedee@user...>
Commiterpeeweedee

Log Message

・DBR T-450対応 0.1版

Cambiar Resumen

Diferencia incremental

--- /dev/null
+++ b/TinyBannavi/src/tainavi/pluginrec/PlugIn_RecRD_T450.java
@@ -0,0 +1,1545 @@
1+package tainavi.pluginrec;
2+
3+import tainavi.*;
4+import tainavi.TVProgram.ProgGenre;
5+
6+import java.io.File;
7+import java.io.UnsupportedEncodingException;
8+import java.net.Authenticator;
9+import java.net.URLEncoder;
10+import java.util.ArrayList;
11+import java.util.HashMap;
12+import java.util.regex.Matcher;
13+import java.util.regex.Pattern;
14+
15+
16+/*
17+ *
18+ */
19+
20+public class PlugIn_RecRD_T450 extends HDDRecorderUtils implements HDDRecorder,Cloneable {
21+
22+ public PlugIn_RecRD_T450 clone() {
23+ return (PlugIn_RecRD_T450) super.clone();
24+ }
25+
26+ private static final String thisEncoding = "MS932";
27+ private static final String utf8Encoding = "UTF-8";
28+
29+ /* 必須コード - ここから */
30+
31+ // 種族の特性
32+ @Override
33+ public String getRecorderId() { return "REGZA DBR-T450"; }
34+ @Override
35+ public RecType getType() { return RecType.RECORDER; }
36+
37+ @Override
38+ public String getLabel_MsChapter() { return "持出用録画"; }
39+ @Override
40+ public String getLabel_MvChapter() { return "持出用品質"; }
41+
42+ @Override
43+ public String getChDatHelp() { return
44+ "「レコーダの放送局名」はネットdeナビの録画予約一覧で表示される「CH」の欄の値を設定してください。\n"+
45+ "予約一覧取得が正常に完了していれば設定候補がコンボボックスで選択できるようになります。"
46+ ;
47+ }
48+
49+ // 個体の特性
50+ private GetRDStatus gs = new GetRDStatus();
51+ private ChannelCode cc = new ChannelCode(getRecorderId());
52+ private String rsvedFile = "";
53+
54+ protected void setErrmsg(String s) { errmsg = s; }
55+ private String errmsg = "";
56+
57+ /*
58+ * 定数
59+ */
60+
61+ private final String MSGID = "["+getRecorderId()+"] ";
62+ private final String ERRID = "[ERROR]"+MSGID;
63+ private final String DBGID = "[DEBUG]"+MSGID;
64+
65+ //
66+ private static final String ITEM_VIDEO_TYPE_DR = "[DR]";
67+ private static final String ITEM_VIDEO_TYPE_VR = "[VR] ";
68+ private static final String ITEM_VIDEO_TYPE_AVC = "[AVC] ";
69+
70+ private static final String ITEM_APPS_RSV_TYPE_NOMAL = "通常のみ";
71+ private static final String ITEM_APPS_RSV_TYPE_BRING = "持出のみ";
72+ private static final String ITEM_APPS_RSV_TYPE_BOTH = "通常+持出";
73+
74+ // chvalueを使っていいよ
75+ @Override
76+ public boolean isChValueAvailable() { return true; }
77+ // CHコードは入力しなくていい
78+ @Override
79+ public boolean isChCodeNeeded() { return false; }
80+
81+ // 公開メソッド
82+
83+ /*******************************************************************************
84+ * コンストラクタ
85+ ******************************************************************************/
86+
87+ public PlugIn_RecRD_T450() {
88+ super();
89+ this.setTunerNum(3);
90+ }
91+
92+ /*******************************************************************************
93+ * チャンネルリモコン機能
94+ ******************************************************************************/
95+
96+ /*
97+ *
98+ */
99+ @Override
100+ public ChannelCode getChCode() {
101+ return cc;
102+ }
103+
104+ /*
105+ * チャンネルリモコン機能
106+ */
107+ @Override
108+ public boolean ChangeChannel(String Channel) {
109+
110+ if (Channel == null) {
111+ return true;
112+ }
113+
114+ int curBC;
115+ int newBC;
116+ String chNo;
117+ //byte enc;
118+
119+ errmsg = "";
120+
121+ /*
122+ * 変更前の放送(地上波/BS/CS)
123+ */
124+ {
125+ String ch = null;
126+ for (int i=0; i<3 && (ch = gs.getCurChannel(getIPAddr())) == null; i++) {
127+ CommonUtils.milSleep(500);
128+ }
129+ if (ch == null) {
130+ errmsg = "レコーダへのアクセスに失敗しました(チャンネルリモコン)。";
131+ System.err.println(errmsg);
132+ return false;
133+ }
134+
135+ //byte[] ba = ch.getBytes();
136+ //enc = ba[0];
137+ ch = ch.substring(1,5);
138+
139+ if (ch.matches("^\\d.+")) {
140+ curBC = 0;
141+ }
142+ else if (ch.startsWith("BS")) {
143+ curBC = 1;
144+ }
145+ else if (ch.startsWith("CS")) {
146+ curBC = 2;
147+ }
148+ else {
149+ errmsg = "現在のチャンネルが認識できません("+ch+")。";
150+ System.err.println(errmsg);
151+ return false;
152+ }
153+ }
154+
155+ /*
156+ * 変更後のCH
157+ */
158+ {
159+ // 放送(地上波/BS/CS)
160+ String cd = cc.getCH_WEB2CODE(Channel);
161+ String ch = cc.getCH_CODE2REC(cd);
162+ String typ = text2value(chtype, cd);
163+ if (typ == null) {
164+ errmsg = "鯛ナビに情報が同期されていないチャンネルです("+Channel+", "+ch+")。";
165+ System.err.println(errmsg);
166+ return false;
167+ }
168+ else if (typ.matches("^l[123]$")) {
169+ errmsg = "外部入力にアサインされているチャンネルには変更できません("+Channel+", "+ch+", "+typ+")。";
170+ System.err.println(errmsg);
171+ return false;
172+ }
173+ else if (typ.equals("uvd")) {
174+ newBC = 0;
175+ }
176+ else if (typ.equals("bsd")) {
177+ newBC = 1;
178+ }
179+ else if (typ.equals("csd")) {
180+ newBC = 2;
181+ }
182+ else {
183+ errmsg = "放送種別が識別できません。プログラム異常です("+Channel+", "+ch+")。";
184+ System.err.println(errmsg);
185+ return false;
186+ }
187+
188+ // CH番号
189+ Matcher ma = Pattern.compile("(\\d\\d\\d)").matcher(ch);
190+ if (ma.find()) {
191+ chNo = ma.group(1);
192+ }
193+ else {
194+ errmsg = "CH番号が取得できません("+Channel+", "+ch+")。";
195+ System.err.println(errmsg);
196+ return false;
197+ }
198+ }
199+
200+ /*
201+ * CH変更実行
202+ */
203+
204+ // おまじない
205+ Authenticator.setDefault(new MyAuthenticator(getUser(), getPasswd()));
206+
207+ int cBC;
208+ for (int i=0; i<3 && newBC != (cBC = (curBC+i)%3); i++) {
209+ // 切り替え実行
210+ reqGET("http://"+getIPAddr()+":"+getPortNo()+"/remote/remote.htm?key=21", null);
211+
212+ // 地上波→BS・BS→CSは切り替え完了までに時間がかかる
213+ CommonUtils.milSleep((cBC == 0 || cBC == 1)?(3000):(1000));
214+ }
215+
216+ reqGET("http://"+getIPAddr()+":"+getPortNo()+"/remote/remote.htm?key=25", null);
217+ CommonUtils.milSleep(1000);
218+ for (int i=0; i<3; i++) {
219+ reqGET("http://"+getIPAddr()+":"+getPortNo()+"/remote/remote.htm?key=0"+chNo.substring(i,i+1), null);
220+ CommonUtils.milSleep(200);
221+ }
222+ reqGET("http://"+getIPAddr()+":"+getPortNo()+"/remote/remote.htm?key=44", null);
223+
224+ return true;
225+ }
226+
227+ /*
228+ * レコーダーから予約一覧を取得する
229+ */
230+ public boolean GetRdReserve(boolean force)
231+ {
232+ System.out.println("レコーダから予約一覧を取得します("+force+"): "+getRecorderId()+"("+getIPAddr()+":"+getPortNo()+")");
233+
234+ errmsg = "";
235+
236+ //
237+ rsvedFile = "env/reserved."+getIPAddr()+"_"+getPortNo()+"_"+getRecorderId()+".xml";
238+
239+ String folderTFile = "env/folders."+getIPAddr()+"_"+getPortNo()+"_"+getRecorderId()+".xml";
240+ String deviceTFile = "env/device."+getIPAddr()+"_"+getPortNo()+"_"+getRecorderId()+".xml";
241+ String mvChapterTFile = "env/mvchapter."+getIPAddr()+"_"+getPortNo()+"_"+getRecorderId()+".xml";
242+ String chValueTFile = "env/chvalue."+getIPAddr()+"_"+getPortNo()+"_"+getRecorderId()+".xml";
243+ String chTypeTFile = "env/chtype."+getIPAddr()+"_"+getPortNo()+"_"+getRecorderId()+".xml";
244+
245+ // ハードコーディング(録画設定ほか)
246+ setSettingVrate(vrate);
247+ setSettingEncoder(encoder);
248+ setSettingApps(mschapter);
249+
250+ File f = new File(rsvedFile);
251+ if ( force == false && f.exists()) {
252+ // キャッシュから読み出し(録画設定ほか)
253+ //arate = TVSload(arateTFile);
254+ folder = TVSload(folderTFile);
255+ device = TVSload(deviceTFile);
256+ mvchapter = TVSload(mvChapterTFile);
257+ chvalue = TVSload(chValueTFile);
258+ chtype = TVSload(chTypeTFile);
259+
260+ // キャッシュから読み出し(予約一覧)
261+ setReserves(ReservesFromFile(rsvedFile));
262+
263+ // なぜか設定ファイルが空になっている場合があるので、その際は再取得する
264+ if (folder.size()>0 && device.size()>0 &&
265+ mvchapter.size()>0 &&
266+ chvalue.size()>0 && chtype.size()>0) {
267+ return(true);
268+ }
269+ }
270+
271+
272+ // おまじない
273+ Authenticator.setDefault(new MyAuthenticator(getUser(), getPasswd()));
274+
275+ // RDから予約一覧を取り出す
276+ Matcher ma = null;
277+ String idx = "";
278+ String header="";
279+ String response="";
280+ {
281+ reportProgress(MSGID+"処理IDを取得します(1/3).");
282+ String[] d = reqGET("http://"+getIPAddr()+":"+getPortNo()+"/reserve/b_rsv.htm",null);
283+ header = d[0];
284+ response = d[1];
285+
286+ if (response == null) {
287+ errmsg = ERRID+"レコーダーが反応しません";
288+ return(false);
289+ }
290+ }
291+ ma = Pattern.compile("/reserve/(\\d+?)/reserve.htm").matcher(response);
292+ if ( ! ma.find()) {
293+ errmsg = ERRID+"レコーダーからの情報取得に失敗しました(処理ID)";
294+ return(false);
295+ }
296+
297+ idx = ma.group(1); // 処理ID
298+
299+ {
300+ reportProgress(MSGID+"予約一覧を取得します(2/3).");
301+ String[] d = reqGET("http://"+getIPAddr()+":"+getPortNo()+"/reserve/"+idx+"/reserve.htm",null);
302+ header = d[0];
303+ response = d[1];
304+
305+ if (response == null) {
306+ errmsg = ERRID+"レコーダーが反応しません";
307+ return(false);
308+ }
309+ }
310+
311+ // 予約エントリー数を取得する
312+ int RsvCnt = 0;
313+ ma = Pattern.compile("RsvCnt\\s*=\\s*(\\d+?);").matcher(response);
314+ if ( ! ma.find()) {
315+ errmsg = ERRID+"レコーダーからの情報取得に失敗しました(予約一覧)";
316+ return false;
317+ }
318+ RsvCnt = Integer.valueOf(ma.group(1));
319+
320+ boolean isfault = false;
321+
322+ // (1)録画設定の取得
323+ {
324+ // ハング防止のおまじない
325+ reportProgress(MSGID+"録画設定を取得します(3/3).");
326+ reqGET("http://"+getIPAddr()+":"+getPortNo()+"/reserve/"+idx+"/b_rsvinfo.htm?0&"+(RsvCnt+1),null);
327+
328+ String[] d = reqGET("http://"+getIPAddr()+":"+getPortNo()+"/reserve/"+idx+"/rsvinfo.htm",null);
329+ String hdr = d[0];
330+ String res = d[1];
331+
332+ if (res == null) {
333+ errmsg = "レコーダーが反応しません";
334+ return(false);
335+ }
336+
337+ //Matcher mb = null;
338+
339+ // 正常取得チェック
340+ if ( ! res.matches("[\\s\\S]*var hdd_folder_text[\\s\\S]*")) {
341+ errmsg = "レコーダーからの情報取得に失敗しました(録画設定)";
342+ return false;
343+ }
344+
345+ ArrayList<TextValueSet> tvsa = null;
346+
347+ // (1-6)記録先デバイス
348+ tvsa = new ArrayList<TextValueSet>();
349+ setSettingEtc(tvsa,"media",0,res);
350+ if (tvsa.size() > 0) {
351+ TVSsave(device=tvsa, deviceTFile);
352+ }
353+ else {
354+ System.err.println(errmsg = ERRID+"【致命的エラー】 記録先デバイスが取得できません");
355+ isfault = true;
356+ }
357+
358+ // (1-Y) 持出用品質
359+ tvsa = new ArrayList<TextValueSet>();
360+ setSettingEtc(tvsa,"apps_vrate",0,res);
361+ if ( tvsa.size() > 0 ) {
362+ TVSsave(mvchapter=tvsa, mvChapterTFile);
363+ }
364+ else {
365+ System.err.println(errmsg = ERRID+"【致命的エラー】 持出用品質が取得できません");
366+ isfault = true;
367+ }
368+
369+ // (1-8)チャンネルコードバリュー - uva、bsaは廃止 -
370+ ArrayList<TextValueSet> tvsb = new ArrayList<TextValueSet>();
371+ ArrayList<TextValueSet> tvsc = new ArrayList<TextValueSet>();
372+ setSettingChCodeValue(tvsb,tvsc,res);
373+ if ( tvsb.size() > 0 && tvsc.size() > 0 ) {
374+ TVSsave(chvalue = tvsb, chValueTFile);
375+ TVSsave(chtype = tvsc, chTypeTFile);
376+ }
377+ else {
378+ System.err.println(errmsg = ERRID+"【致命的エラー】 チャンネルコードバリューが取得できません");
379+ isfault = true;
380+ }
381+ }
382+
383+ ArrayList<TextValueSet> tvsa = new ArrayList<TextValueSet>();
384+ for ( TextValueSet devset : device ) {
385+ String dev = devset.getText();
386+
387+ reportProgress(MSGID + "フォルダ一覧を取得します("+dev+").");
388+ String[] d = reqGET("http://" + getIPAddr() + ":" + getPortNo() + "/reserve/" + idx + "/folderlist.htm?"+dev, null, utf8Encoding);
389+ String hdr = d[0];
390+ String res = d[1];
391+
392+ if (res == null) {
393+ errmsg = ERRID + "レコーダーが反応しません";
394+ continue;
395+ }
396+
397+ ArrayList<String> text = new ArrayList<String>();
398+ ArrayList<String> value = new ArrayList<String>();
399+ Matcher mdev = Pattern.compile("var\\s+folder_list_text\\s+=\\s+new\\s+Array\\((.+?)\\);.+?var\\s+folder_list_value\\s+=\\s+new\\s+Array\\((.+?)\\);", Pattern.DOTALL).matcher(res);
400+ if ( mdev.find() && mdev.groupCount() == 2 ) {
401+ String[] textTemp = mdev.group(1).split("[\\n\\r]+");
402+ for ( String ts : textTemp ) {
403+ String t = ts.trim();
404+ if ( t.length() > 0 ) {
405+ text.add(t);
406+ System.out.println(t);
407+ }
408+ }
409+ String[] valueTemp = mdev.group(2).split("[\\n\\r]+");
410+ for ( String vs : valueTemp ) {
411+ String v = vs.trim();
412+ if ( v.length() > 0 ) {
413+ value.add(v);
414+ }
415+ }
416+
417+ if ( text.size() == value.size() ) {
418+ for ( int i=0; i < text.size(); i ++ ) {
419+ TextValueSet tvs = new TextValueSet();
420+ tvs.setText(String.format("[%s] %s", dev, text.get(i)));
421+ tvs.setValue(value.get(i));
422+ tvsa.add(tvs);
423+ }
424+ }
425+ }
426+ }
427+ TVSsave(folder = tvsa, folderTFile);
428+
429+ // 予約一覧データの分析
430+ setReserves(decodeReservedList(response));
431+
432+ // キャッシュに保存
433+ ReservesToFile(getReserves(), rsvedFile);
434+
435+ // 取得した情報の表示
436+ System.out.println("---Reserved List Start---");
437+ for ( int i = 0; i<getReserves().size(); i++ ) {
438+ // 詳細情報の取得
439+ ReserveList e = getReserves().get(i);
440+ System.out.println(String.format("[%s] %s\t%s\t%s\t%s:%s\t%s:%s\t%sm\t%s\t%s\t%s(%s)\t%s\t%s",
441+ (i+1),
442+ e.getId(),
443+ e.getRec_pattern(), e.getRec_nextdate(), e.getAhh(), e.getAmm(), e.getZhh(), e.getZmm(), e.getRec_min(),
444+ e.getRec_mschapter(), ((e.getAppsRsv())?(e.getRec_mvchapter()):(e.getRec_mode())),
445+ e.getTitle(), e.getTitlePop(),
446+ e.getChannel(), e.getCh_name()));
447+ }
448+ System.out.println("---Reserved List End---");
449+
450+ return( ! isfault);
451+ }
452+
453+ @Override
454+ public boolean isThereAdditionalDetails() {
455+ return true;
456+ }
457+ @Override
458+ public boolean GetRdReserveDetails()
459+ {
460+ /*
461+ * 前処理
462+ */
463+
464+ // おまじない
465+ Authenticator.setDefault(new MyAuthenticator(getUser(), getPasswd()));
466+
467+ Matcher mx = null;
468+ String idx = "";
469+ String header="";
470+ String response="";
471+ {
472+ reportProgress("処理IDを取得します(1/1).");
473+ String[] d = reqGET("http://"+getIPAddr()+":"+getPortNo()+"/reserve/b_rsv.htm",null);
474+ header = d[0];
475+ response = d[1];
476+
477+ if (response == null) {
478+ errmsg = "レコーダーが反応しません";
479+ return(false);
480+ }
481+ }
482+ mx = Pattern.compile("/reserve/(\\d+?)/reserve.htm").matcher(response);
483+ if ( ! mx.find()) {
484+ errmsg = "レコーダーからの情報取得に失敗しました(処理ID)";
485+ return(false);
486+ }
487+ idx = mx.group(1);
488+
489+ /*
490+ * 詳細確認
491+ */
492+ int lineno = 0;
493+ ArrayList<ReserveList> ra = getReserves();
494+ for (ReserveList entry : ra) {
495+
496+ lineno++;
497+
498+ // 詳細情報を引いてみる
499+ reportProgress("+番組詳細を取得します("+lineno+"/"+ra.size()+").");
500+ reqGET("http://"+getIPAddr()+":"+getPortNo()+"/reserve/"+idx+"/b_rsvinfo.htm?"+entry.getId()+"&"+lineno,null);
501+
502+ String[] d = reqGET("http://"+getIPAddr()+":"+getPortNo()+"/reserve/"+idx+"/rsvinfo.htm",null);
503+ if (d[1] == null) {
504+ reportProgress("レコーダーからの戻り値が不正です");
505+ continue;
506+ }
507+
508+ // (1-1)画質設定
509+ mx = Pattern.compile("videotype_digital_value = (\\d+);").matcher(d[1]);
510+ if ( ! mx.find()) {
511+ reportProgress("レコーダーからの戻り値が不正です(画質1)");
512+ continue;
513+ }
514+ String vtypestr = mx.group(1);
515+ mx = Pattern.compile("videomode_digital_value = (\\d+);").matcher(d[1]);
516+ if ( ! mx.find()) {
517+ reportProgress("レコーダーからの戻り値が不正です(画質2)");
518+ continue;
519+ }
520+ String vmodestr = mx.group(1);
521+ entry.setRec_mode(value2text(vrate, vtypestr+":"+vmodestr));
522+
523+ // (1-6)記録先デバイス [一覧から取得]
524+
525+ // (1-3)フォルダ
526+ mx = Pattern.compile("var folder_current = \"(\\d+?)\";").matcher(d[1]);
527+ if ( ! mx.find()) {
528+ reportProgress("レコーダーからの戻り値が不正です(フォルダ)");
529+ continue;
530+ }
531+ {
532+ ArrayList<TextValueSet> currentFolderList = new ArrayList<TextValueSet>();
533+ final String deviceId = String.format("[%s] ", entry.getRec_device());
534+ for ( TextValueSet f : folder ) {
535+ if ( f.getText().startsWith(deviceId) ) {
536+ currentFolderList.add(f);
537+ }
538+ }
539+ int index = Integer.parseInt(mx.group(1));
540+ System.out.println(currentFolderList.size()+", "+index);
541+ if ( currentFolderList.size() <= index ) {
542+ reportProgress("レコーダーからの戻り値が不正です(フォルダリスト)");
543+ continue;
544+ }
545+ entry.setRec_folder(currentFolderList.get(index).getText());
546+ }
547+
548+ // (1-Y) 持出用録画関連
549+ {
550+ mx = Pattern.compile("var apps_rsv_use_current\\s+?=\\s+?(\\d+?);").matcher(d[1]);
551+ if ( ! mx.find()) {
552+ reportProgress("レコーダーからの戻り値が不正です(持出用録画有無)");
553+ continue;
554+ }
555+ int apps_rsv_use = Integer.valueOf(mx.group(1));
556+ if ( apps_rsv_use != 0 ) {
557+ mx = Pattern.compile("var apps_rsv_type_current\\s+?=\\s+?(\\d+?);").matcher(d[1]);
558+ if ( ! mx.find()) {
559+ reportProgress("レコーダーからの戻り値が不正です(持出用録画方法)");
560+ continue;
561+ }
562+ apps_rsv_use = Integer.valueOf(mx.group(1)) + 1;
563+ }
564+ entry.setRec_mschapter(mschapter.get(apps_rsv_use).getText());
565+
566+ mx = Pattern.compile("var apps_vrate_current\\s+?=\\s+?(\\d+?);").matcher(d[1]);
567+ if ( ! mx.find()) {
568+ reportProgress("レコーダーからの戻り値が不正です(持出用録画品質)");
569+ continue;
570+ }
571+ int apps_vrate = Integer.valueOf(mx.group(1));
572+
573+ entry.setRec_mvchapter(mvchapter.get(apps_vrate).getText());
574+ }
575+
576+ // (1-8)チャンネル [一覧から取得]
577+ }
578+
579+ // キャッシュに保存
580+ ReservesToFile(getReserves(), rsvedFile);
581+
582+ return(true);
583+ }
584+
585+ /*
586+ * 予約を実行する
587+ */
588+ public boolean PostRdEntry(ReserveList r)
589+ {
590+ System.out.println("Run: PostRdEntry("+r.getTitle()+")");
591+
592+ errmsg = "";
593+
594+ //
595+ if (cc.getCH_WEB2CODE(r.getCh_name()) == null) {
596+ errmsg = "【警告】Web番組表の放送局名「"+r.getCh_name()+"」をCHコードに変換できません。CHコード設定を修正してください。" ;
597+ System.out.println(errmsg);
598+ return(false);
599+ }
600+
601+
602+ /*
603+ * 予約情報の整理
604+ */
605+
606+ // 予約パターンID・次回予定日
607+ r.setRec_pattern_id(getRec_pattern_Id(r.getRec_pattern()));
608+ r.setRec_nextdate(CommonUtils.getNextDate(r));
609+
610+ // 録画長
611+ r.setRec_min(CommonUtils.getRecMin(r.getAhh(),r.getAmm(),r.getZhh(),r.getZmm()));
612+
613+ // 開始日時・終了日時
614+ getStartEndDateTime(r);
615+
616+
617+ /*
618+ * 予約実行
619+ */
620+
621+ // おまじない
622+ Authenticator.setDefault(new MyAuthenticator(getUser(), getPasswd()));
623+
624+ // RDから予約一覧を取り出す
625+ Matcher ma = null;
626+ String idx = "";
627+ String header;
628+ String response;
629+ {
630+ reportProgress("処理IDを取得します(1/7).");
631+ String[] d = reqGET("http://"+getIPAddr()+":"+getPortNo()+"/reserve/b_rsv.htm",null);
632+ header = d[0];
633+ response = d[1];
634+
635+ if ( response == null ) {
636+ errmsg = "レコーダーが反応しません。";
637+ return(false);
638+ }
639+ }
640+ ma = Pattern.compile("/reserve/(\\d+?)/reserve.htm").matcher(response);
641+ if (ma.find()) {
642+ reportProgress("予約実行前の予約一覧を取得します(2/7).");
643+ idx = ma.group(1);
644+ String[] d = reqGET("http://"+getIPAddr()+":"+getPortNo()+"/reserve/"+idx+"/reserve.htm",null);
645+ header = d[0];
646+ response = d[1];
647+
648+ if ( response == null ) {
649+ errmsg = "レコーダーが反応しません。";
650+ return(false);
651+ }
652+ }
653+ ArrayList<String[]> oldids = getIds(response);
654+
655+ // 予約エントリー数を取得する
656+ int RsvCnt = 0;
657+ ma = Pattern.compile("RsvCnt\\s*=\\s*(\\d+?);").matcher(response);
658+ if (ma.find()) {
659+ RsvCnt = Integer.valueOf(ma.group(1));
660+ }
661+
662+ // RDに新規登録要請
663+ {
664+ // ハング防止のおまじない
665+ reportProgress("予約ページを開きます(3/7).");
666+ reqGET("http://"+getIPAddr()+":"+getPortNo()+"/reserve/"+idx+"/b_rsvinfo.htm?0&"+(RsvCnt+1),null);
667+
668+ reportProgress("予約ページを開きます(4/7).");
669+ reqGET("http://"+getIPAddr()+":"+getPortNo()+"/reserve/"+idx+"/rsvinfo.htm",null);
670+ }
671+
672+ // POSTデータを変換する
673+ HashMap<String, String> pdat = modPostdata(r);
674+
675+ // RDへの情報作成
676+ String pstr = joinPoststr(pdat);
677+
678+ // RDへ情報送信
679+ {
680+ reportProgress("予約を実行します(5/7).");
681+ String[] d = reqPOST("http://"+getIPAddr()+":"+getPortNo()+"/reserve/"+idx+"/entry.htm", pstr, null);
682+ header = d[0];
683+ response = d[1];
684+ }
685+
686+ // 登録結果の確認
687+ ma = Pattern.compile("alert\\(msg\\)").matcher(response);
688+ if ( ma.find() ) {
689+ Matcher mb = Pattern.compile("\\bmsg=\"([\\s\\S]+?)\";").matcher(response);
690+ if (mb.find()) {
691+ errmsg = mb.group(1);
692+ System.out.printf("\n<<< Message from RD >>> \"%s\"\n\n", errmsg);
693+ Matcher mc = Pattern.compile("(予約時間が重複しています。|W録の振り替えをおこないました)").matcher(errmsg);
694+ if ( ! mc.find() ) {
695+ return(false);
696+ }
697+ }
698+ }
699+
700+ // 予約ID番号を取得(キャッシュに存在しない番号が新番号)
701+ {
702+ reportProgress("処理IDを取得します(6/7).");
703+ String[] d = reqGET("http://"+getIPAddr()+":"+getPortNo()+"/reserve/b_rsv.htm",null);
704+ header = d[0];
705+ response = d[1];
706+ }
707+ ma = Pattern.compile("/reserve/(\\d+?)/reserve.htm").matcher(response);
708+ if (ma.find()) {
709+ idx = ma.group(1);
710+ reportProgress("予約実行後の予約一覧を取得します(7/7).");
711+ //
712+ String param = "/reserve.htm";
713+ if ( getDebug() ) {
714+ param = "/reserve2.htm";
715+ }
716+ String[] d = reqGET("http://"+getIPAddr()+":"+getPortNo()+"/reserve/"+idx+param,null);
717+ //
718+ header = d[0];
719+ response = d[1];
720+ }
721+ ArrayList<String[]> newids = getIds(response);
722+
723+ // 予約IDの取得
724+ ArrayList<String[]> rids = new ArrayList<String[]>();
725+ for ( String[] nid : newids ) {
726+ String[] rid = nid;
727+ for ( String[] oid : oldids ) {
728+ if ( nid[0].equals(oid[0]) ) {
729+ rid = null;
730+ break;
731+ }
732+ }
733+ if ( rid != null ) {
734+ rids.add(rid);
735+ }
736+ }
737+ System.out.println("+追加された予約IDの数: "+rids.size());
738+ if ( rids.size() > 0 ) {
739+ for ( String[] rid : rids ) {
740+ System.out.println("+-予約ID: "+rid[0]);
741+ ReserveList nr = r.clone();
742+ if ( rid[1].equals("0") && (nr.getRec_mschapter().equals(ITEM_APPS_RSV_TYPE_NOMAL)||nr.getRec_mschapter().equals(ITEM_APPS_RSV_TYPE_BOTH)) ) {
743+ // 通常
744+ nr.setAppsRsv(false);
745+ nr.setRec_mschapter(ITEM_APPS_RSV_TYPE_NOMAL);
746+ }
747+ else if ( rid[1].equals("1") && (nr.getRec_mschapter().equals(ITEM_APPS_RSV_TYPE_NOMAL)||nr.getRec_mschapter().equals(ITEM_APPS_RSV_TYPE_BOTH)) ) {
748+ // 持出
749+ nr.setAppsRsv(true);
750+ nr.setRec_mschapter(ITEM_APPS_RSV_TYPE_BRING);
751+ }
752+ else {
753+ errmsg = "【警告】予約IDと予約情報が一致しません。";
754+ continue;
755+ }
756+ nr.setId(rid[0]);
757+ getReserves().add(nr);
758+ }
759+ }
760+ else {
761+ errmsg = "【警告】予約IDが取得できませんでした。";
762+ }
763+
764+
765+ // 予約リストをキャッシュに保存
766+ ReservesToFile(getReserves(), rsvedFile);
767+
768+
769+ System.out.printf("\n<<< Message from RD >>> \"%s\"\n\n", "正常に登録できました。");
770+ return(true);
771+ }
772+
773+
774+ /*
775+ * 予約を更新する
776+ */
777+ public boolean UpdateRdEntry(ReserveList o, ReserveList r) {
778+
779+ System.out.println("Run: UpdateRdEntry()");
780+
781+ errmsg = "";
782+
783+ //
784+ if (cc.getCH_WEB2CODE(r.getCh_name()) == null) {
785+ errmsg = "【警告】Web番組表の放送局名「"+r.getCh_name()+"」をCHコードに変換できません。CHコード設定を修正してください。" ;
786+ System.out.println(errmsg);
787+ return(false);
788+ }
789+
790+ if ( ! o.getRec_mschapter().equals(r.getRec_mschapter()) ) {
791+ errmsg = String.format("【警告】持出用録画の設定は変更できません。(%s→%s)",o.getRec_mschapter(),r.getRec_mschapter()) ;
792+ System.out.println(errmsg);
793+ return(false);
794+ }
795+
796+ /*
797+ * 予約情報の整理
798+ */
799+
800+ // 予約パターンID・次回予定日
801+ r.setRec_pattern_id(getRec_pattern_Id(r.getRec_pattern()));
802+ r.setRec_nextdate(CommonUtils.getNextDate(r));
803+
804+ // 録画長
805+ r.setRec_min(CommonUtils.getRecMin(r.getAhh(),r.getAmm(),r.getZhh(),r.getZmm()));
806+
807+ // 開始日時・終了日時
808+ getStartEndDateTime(r);
809+
810+
811+ /*
812+ * 予約実行
813+ */
814+
815+ // おまじない
816+ Authenticator.setDefault(new MyAuthenticator(getUser(), getPasswd()));
817+
818+ // 更新準備
819+ Matcher ma = null;
820+ String idx = "";
821+ String header;
822+ String response;
823+ {
824+ reportProgress("処理IDを取得します(1/5).");
825+ String[] d = reqGET("http://"+getIPAddr()+":"+getPortNo()+"/reserve/b_rsv.htm",null);
826+ header = d[0];
827+ response = d[1];
828+
829+ if ( response == null ) {
830+ errmsg = "レコーダーが反応しません。";
831+ return(false);
832+ }
833+ }
834+ ma = Pattern.compile("/reserve/(\\d+?)/reserve.htm").matcher(response);
835+ if (ma.find()) {
836+ idx = ma.group(1);
837+ reportProgress("更新対象の予約を確認します(2/5).");
838+ String[] d = reqGET("http://"+getIPAddr()+":"+getPortNo()+"/reserve/"+idx+"/reserve.htm",null);
839+ header = d[0];
840+ response = d[1];
841+
842+ if ( response == null ) {
843+ errmsg = "レコーダーが反応しません。";
844+ return(false);
845+ }
846+ }
847+ int lineno = getLineNo(response, r.getId());
848+
849+ // RDに更新要請
850+ {
851+ // ハング防止のおまじない
852+ reportProgress("予約ページを開きます(3/5).");
853+ reqGET("http://"+getIPAddr()+":"+getPortNo()+"/reserve/"+idx+"/b_rsvinfo.htm?"+r.getId()+"&"+lineno,null);
854+
855+ reportProgress("予約ページを開きます(4/5).");
856+ reqGET("http://"+getIPAddr()+":"+getPortNo()+"/reserve/"+idx+"/rsvinfo.htm",null);
857+ }
858+
859+ // POSTデータを変換する
860+ HashMap<String, String> pdat = modPostdata(r);
861+
862+ // RDへの情報作成
863+ String pstr = joinPoststr(pdat);
864+
865+ // RDへ情報送信
866+ {
867+ reportProgress("更新を実行します(5/5).");
868+ String[] d = reqPOST("http://"+getIPAddr()+":"+getPortNo()+"/reserve/"+idx+"/entry.htm", pstr, null);
869+ header = d[0];
870+ response = d[1];
871+
872+ if ( response == null ) {
873+ errmsg = "レコーダーが反応しません。";
874+ return(false);
875+ }
876+ }
877+
878+ // 更新結果の確認
879+ ma = Pattern.compile("alert\\(msg\\)").matcher(response);
880+ if ( ma.find() ) {
881+ Matcher mb = Pattern.compile("\\bmsg=\"([\\s\\S]+?)\";").matcher(response);
882+ if (mb.find()) {
883+ errmsg = mb.group(1);
884+ System.out.printf("\n<<< Message from RD >>> \"%s\"\n\n", errmsg);
885+ Matcher mc = Pattern.compile("(予約時間が重複しています。|W録の振り替えをおこないました)").matcher(errmsg);
886+ if ( ! mc.find() ) {
887+ return(false);
888+ }
889+ }
890+ }
891+
892+ System.out.printf("\n<<< Message from RD >>> \"%s\"\n\n", "正常に更新できました。");
893+
894+
895+ /*
896+ * 予約情報の調整
897+ */
898+
899+ // 情報置き換え
900+ getReserves().remove(o);
901+ getReserves().add(r);
902+
903+ // キャッシュに保存
904+ ReservesToFile(getReserves(), rsvedFile);
905+
906+ return(true);
907+ }
908+
909+ /*
910+ * 予約を削除する
911+ */
912+ public ReserveList RemoveRdEntry(String delid) {
913+
914+ System.out.println("Run: RemoveRdEntry()");
915+
916+ errmsg = "";
917+
918+ // おまじない
919+ Authenticator.setDefault(new MyAuthenticator(getUser(), getPasswd()));
920+
921+ // 削除対象を探す
922+ ReserveList rx = null;
923+ for ( ReserveList reserve : getReserves() ) {
924+ if (reserve.getId().equals(delid)) {
925+ rx = reserve;
926+ break;
927+ }
928+ }
929+ if (rx == null) {
930+ return(null);
931+ }
932+
933+ // 予約行番号を取得
934+ Matcher ma = null;
935+ String idx = "";
936+ String header;
937+ String response;
938+ {
939+ reportProgress("処理IDを取得します(1/5).");
940+ String[] d = reqGET("http://"+getIPAddr()+":"+getPortNo()+"/reserve/b_rsv.htm",null);
941+ header = d[0];
942+ response = d[1];
943+ if ( response == null ) {
944+ errmsg = "レコーダーが反応しません。";
945+ return(null);
946+ }
947+ }
948+ ma = Pattern.compile("/reserve/(\\d+?)/reserve.htm").matcher(response);
949+ if (ma.find()) {
950+ idx = ma.group(1);
951+ reportProgress("削除対象の予約を確認します(2/5).");
952+ String[] d = reqGET("http://"+getIPAddr()+":"+getPortNo()+"/reserve/"+idx+"/reserve.htm",null);
953+ header = d[0];
954+ response = d[1];
955+ }
956+ int lineno = getLineNo(response, rx.getId());
957+
958+ // RDに削除要請
959+ {
960+ // ハング防止のおまじない
961+ reportProgress("予約ページを開きます(3/5).");
962+ reqGET("http://"+getIPAddr()+":"+getPortNo()+"/reserve/"+idx+"/b_rsvinfo.htm?"+rx.getId()+"&"+lineno,null);
963+
964+ reportProgress("予約ページを開きます(4/5).");
965+ reqGET("http://"+getIPAddr()+":"+getPortNo()+"/reserve/"+idx+"/rsvinfo.htm",null);
966+ }
967+ {
968+ reportProgress("削除を実行します(5/5).");
969+ String[] d = reqGET("http://"+getIPAddr()+":"+getPortNo()+"/reserve/"+idx+"/delete.htm", null);
970+ header = d[0];
971+ response = d[1];
972+
973+ if ( response == null ) {
974+ errmsg = "レコーダーが反応しません。";
975+ return(null);
976+ }
977+ }
978+
979+ // 削除結果の確認
980+ ma = Pattern.compile("alert\\(msg\\)").matcher(response);
981+ if ( ma.find() ) {
982+ Matcher mb = Pattern.compile("\\bmsg=\"([\\s\\S]+?)\";").matcher(response);
983+ if (mb.find()) {
984+ errmsg = mb.group(1);
985+ System.out.printf("\n<<< Message from RD >>> \"%s\"\n\n", errmsg);
986+ Matcher mc = Pattern.compile("W録の振り替えをおこないました").matcher(errmsg);
987+ if ( ! mc.find() ) {
988+ return(null);
989+ }
990+ }
991+ }
992+
993+ // 予約リストを更新
994+ getReserves().remove(rx);
995+
996+ // キャッシュに保存
997+ ReservesToFile(getReserves(), rsvedFile);
998+
999+ System.out.printf("\n<<< Message from RD >>> \"%s\"\n\n", "正常に削除できました。");
1000+ return(rx);
1001+ }
1002+
1003+ /*
1004+ *
1005+ */
1006+ public String getErrmsg() {
1007+ return(errmsg.replaceAll("\\\\r\\\\n", ""));
1008+ }
1009+
1010+
1011+
1012+
1013+ /* ここまで */
1014+
1015+
1016+
1017+
1018+
1019+
1020+ /* 個別コード-ここから最後まで */
1021+
1022+ /*
1023+ * 非公開メソッド
1024+ */
1025+
1026+ private String joinPoststr(HashMap<String, String> pdat)
1027+ {
1028+ String[] pkeys = {
1029+ "bExec",
1030+ "start_form",
1031+ "title_name",
1032+ "detail",
1033+ "genre",
1034+ "enc_type",
1035+ "broadcast",
1036+ "channel_list",
1037+ "rec_priority",
1038+ "maiyoubi_type",
1039+ "date",
1040+ "start_hour",
1041+ "start_minute",
1042+ "end_hour",
1043+ "end_minute",
1044+ "apps_rsv_use", // new
1045+ "apps_rsv_type", // new
1046+ "apps_vrate", // new
1047+ "disc",
1048+ "vrate",
1049+ "amode",
1050+ "videotype_digital",
1051+ "videomode_digital",
1052+ "folder",
1053+ "auto_delete",
1054+ "dvdr",
1055+ "lVoice",
1056+ "edge_left",
1057+ "CM_Chapter",
1058+ "channel_no",
1059+ "dtv_sid",
1060+ "dtv_nid",
1061+ "net_link",
1062+ "add_ch_text",
1063+ "add_ch_value",
1064+ "sport_ext_submit",
1065+ "title_link_submit",
1066+ "end_form"
1067+ };
1068+
1069+ String pstr = "";
1070+ for ( String key : pkeys ) {
1071+ if (pdat.containsKey(key)) {
1072+ pstr += key+"="+pdat.get(key)+"&";
1073+ }
1074+ }
1075+ pstr = pstr.substring(0, pstr.length()-1);
1076+
1077+ System.err.println("poststr: "+pstr);
1078+
1079+ return(pstr);
1080+ }
1081+
1082+ private HashMap<String, String> modPostdata(ReserveList r) {
1083+
1084+ HashMap<String, String> newdat = new HashMap<String, String>();
1085+ try {
1086+ // 実行するよ
1087+ newdat.put("bExec", (r.getExec())?("ON"):("OFF"));
1088+ if (r.getUpdateOnlyExec()) {
1089+ return(newdat);
1090+ }
1091+
1092+ // 予約名・予約詳細
1093+ if ( r.getAutocomplete() ) {
1094+ newdat.put("title_name", "");
1095+ //newdat.put("detail", "");
1096+ }
1097+ else {
1098+ try {
1099+ newdat.put("title_name", URLEncoder.encode(CommonUtils.substringrb(r.getTitle(),86),thisEncoding));
1100+ } catch (UnsupportedEncodingException e1) {
1101+ e1.printStackTrace();
1102+ }
1103+
1104+ // 予約詳細
1105+ /*
1106+ try {
1107+ newdat.put("detail", URLEncoder.encode(CommonUtils.substringrb(r.getDetail().replaceAll("\n", Matcher.quoteReplacement("\r\n")),75*5), thisEncoding));
1108+ } catch (UnsupportedEncodingException e) {
1109+ e.printStackTrace();
1110+ }
1111+ */
1112+ }
1113+
1114+ // 録画チャンネル - uva、bsaは廃止 -
1115+ String channel = cc.getCH_WEB2CODE(r.getCh_name());
1116+ String ch_no = cc.getCH_CODE2REC(channel);
1117+ String typ = text2value(chtype, channel);
1118+ if (typ.equals("l1")) {
1119+ newdat.put("broadcast","2"); // 外部入力(L1)
1120+ }
1121+ else if (typ.equals("l2")) {
1122+ newdat.put("broadcast","3"); // 外部入力(L2)
1123+ }
1124+ else if (typ.equals("l3")) {
1125+ newdat.put("broadcast","4"); // 外部入力(L3)
1126+ }
1127+ else if (typ.equals("bsd")) {
1128+ newdat.put("broadcast","10"); // BSデジタル
1129+ }
1130+ else if (typ.equals("csd")) {
1131+ newdat.put("broadcast","11"); // 110度CSデジタル
1132+ }
1133+ else if (typ.equals("uvd")) {
1134+ newdat.put("broadcast","12"); // 地上デジタル
1135+ }
1136+ else {
1137+ // 普通ここには落ちない
1138+ if (ch_no.startsWith("C")) {
1139+ newdat.put("broadcast","2"); // "C***"は外部入力(L1)
1140+ }
1141+ else if (ch_no.startsWith("SP")) {
1142+ newdat.put("broadcast","4"); // "SP***"は外部入力(L3)
1143+ }
1144+ else {
1145+ newdat.put("broadcast","3"); // 未定義は全部外部入力(L2)
1146+ }
1147+ }
1148+
1149+ try {
1150+ String ech = URLEncoder.encode(channel,thisEncoding);
1151+ newdat.put("channel_list", ech);
1152+ newdat.put("channel_no", ech);
1153+ } catch (UnsupportedEncodingException e1) {
1154+ e1.printStackTrace();
1155+ }
1156+
1157+ // 開始・終了日時
1158+ Matcher ma = Pattern.compile("^\\d").matcher(r.getRec_pattern());
1159+ if (ma.find()) {
1160+ newdat.put("maiyoubi_type","0");
1161+ try {
1162+ newdat.put("date", URLEncoder.encode(r.getRec_pattern(),thisEncoding));
1163+ } catch (UnsupportedEncodingException e1) {
1164+ e1.printStackTrace();
1165+ }
1166+ }
1167+ else {
1168+ newdat.put("maiyoubi_type", "1");
1169+ int i = 1;
1170+ for ( String s : RPTPTN ) {
1171+ if ( s.equals(r.getRec_pattern()) == true ) {
1172+ newdat.put("date", String.valueOf(i));
1173+ }
1174+ i++;
1175+ }
1176+ }
1177+
1178+ newdat.put("start_hour", r.getAhh());
1179+ newdat.put("start_minute", r.getAmm());
1180+ newdat.put("end_hour", r.getZhh());
1181+ newdat.put("end_minute", r.getZmm());
1182+
1183+ String val;
1184+
1185+ /*
1186+ * 持出用録画のありなしが影響する項目
1187+ */
1188+
1189+ if ( r.getRec_mschapter().equals(ITEM_APPS_RSV_TYPE_NOMAL) || r.getRec_mschapter().equals(ITEM_APPS_RSV_TYPE_BOTH) ) {
1190+ // 保存先
1191+ try {
1192+ newdat.put("folder", URLEncoder.encode(text2value(folder, r.getRec_folder()),thisEncoding));
1193+ } catch (UnsupportedEncodingException e) {
1194+ e.printStackTrace();
1195+ }
1196+
1197+ // 記録先
1198+ newdat.put("disc", text2value(device, r.getRec_device()));
1199+
1200+ // 録画レート
1201+ ma = Pattern.compile("^(\\d+?):(.*?)$").matcher(text2value(vrate, r.getRec_mode()));
1202+ if (ma.find()) {
1203+ if (ma.group(1).equals("1")) {
1204+ // VR
1205+ newdat.put("videotype_digital",ma.group(1));
1206+ newdat.put("videomode_digital",ma.group(2));
1207+ }
1208+ else if (ma.group(1).equals("2")) {
1209+ // AVC
1210+ newdat.put("videotype_digital",ma.group(1));
1211+ newdat.put("videomode_digital",ma.group(2));
1212+ }
1213+ else {
1214+ // DR
1215+ newdat.put("videotype_digital",ma.group(1));
1216+ }
1217+ }
1218+ }
1219+
1220+ // 持出用録画
1221+ if ( r.getRec_mschapter().equals(ITEM_APPS_RSV_TYPE_BRING) || r.getRec_mschapter().equals(ITEM_APPS_RSV_TYPE_BOTH) ) {
1222+ newdat.put("apps_rsv_use", "1");
1223+ newdat.put("apps_rsv_type", text2value(mschapter,r.getRec_mschapter()));
1224+ newdat.put("apps_vrate", text2value(mvchapter,r.getRec_mvchapter()));
1225+ }
1226+ else {
1227+ //newdat.put("apps_rsv_use", "0");
1228+ }
1229+
1230+
1231+ // 追加
1232+ newdat.put("start_form" , "");
1233+ //newdat.put("dtv_sid" , "0"); // ?
1234+ //newdat.put("dtv_nid" , "0"); // ?
1235+ //newdat.put("net_link" , "0"); // ?
1236+ newdat.put("add_ch_text" , "");
1237+ newdat.put("add_ch_value" , "");
1238+ //newdat.put("sport_ext_submit" , "undefined"); // 本体から受信した予約状態を上書きしない(>>208.)
1239+ //newdat.put("title_link_submit" , "undefined"); // 本体から受信した予約状態を上書きしない(>>208.)
1240+ newdat.put("end_form" , "0");
1241+ }
1242+ catch ( Exception e ) {
1243+ e.printStackTrace();
1244+ }
1245+
1246+ return(newdat);
1247+ }
1248+
1249+
1250+
1251+ /*
1252+ * 録画設定の解読
1253+ */
1254+ protected void setSettingVrate(ArrayList<TextValueSet> vrate)
1255+ {
1256+ vrate.clear();
1257+ TextValueSet t = null;
1258+
1259+ t = new TextValueSet();
1260+ t.setText(ITEM_VIDEO_TYPE_DR);
1261+ t.setValue("128:");
1262+ vrate.add(t);
1263+
1264+ t = new TextValueSet();
1265+ t.setText(ITEM_VIDEO_TYPE_AVC+"AF");
1266+ t.setValue("2:8");
1267+ vrate.add(t);
1268+ t = new TextValueSet();
1269+ t.setText(ITEM_VIDEO_TYPE_AVC+"AN");
1270+ t.setValue("2:9");
1271+ vrate.add(t);
1272+ t = new TextValueSet();
1273+ t.setText(ITEM_VIDEO_TYPE_AVC+"AS");
1274+ t.setValue("2:18");
1275+ vrate.add(t);
1276+ t = new TextValueSet();
1277+ t.setText(ITEM_VIDEO_TYPE_AVC+"AL");
1278+ t.setValue("2:19");
1279+ vrate.add(t);
1280+ t = new TextValueSet();
1281+ t.setText(ITEM_VIDEO_TYPE_AVC+"AE");
1282+ t.setValue("2:10");
1283+ vrate.add(t);
1284+
1285+ t = new TextValueSet();
1286+ t.setText(ITEM_VIDEO_TYPE_AVC+"AT 4.7GB");
1287+ t.setValue("2:22");
1288+ vrate.add(t);
1289+ t = new TextValueSet();
1290+ t.setText(ITEM_VIDEO_TYPE_AVC+"AT 8.5GB");
1291+ t.setValue("2:23");
1292+ vrate.add(t);
1293+ t = new TextValueSet();
1294+ t.setText(ITEM_VIDEO_TYPE_AVC+"AT 25GB");
1295+ t.setValue("2:11");
1296+ vrate.add(t);
1297+ t = new TextValueSet();
1298+ t.setText(ITEM_VIDEO_TYPE_AVC+"AT 50GB");
1299+ t.setValue("2:12");
1300+ vrate.add(t);
1301+
1302+ t = new TextValueSet();
1303+ t.setText(ITEM_VIDEO_TYPE_VR+"XP");
1304+ t.setValue("1:20");
1305+ vrate.add(t);
1306+ t = new TextValueSet();
1307+ t.setText(ITEM_VIDEO_TYPE_VR+"SP");
1308+ t.setValue("1:1");
1309+ vrate.add(t);
1310+ t = new TextValueSet();
1311+ t.setText(ITEM_VIDEO_TYPE_VR+"LP");
1312+ t.setValue("1:2");
1313+ vrate.add(t);
1314+ t = new TextValueSet();
1315+ t.setText(ITEM_VIDEO_TYPE_VR+"EP");
1316+ t.setValue("1:21");
1317+ vrate.add(t);
1318+ t = new TextValueSet();
1319+ t.setText(ITEM_VIDEO_TYPE_VR+"AT 4.7GB");
1320+ t.setValue("1:4");
1321+ vrate.add(t);
1322+ }
1323+
1324+ private void setSettingEncoder(ArrayList<TextValueSet> enc) {
1325+ enc.clear();
1326+ if ( getTunerNum() >= 2 ) {
1327+ for ( int i=1; i<=getTunerNum(); i++ ) {
1328+ TextValueSet t = new TextValueSet();
1329+ t.setText("D"+i);
1330+ t.setValue("D"+i);
1331+ enc.add(t);
1332+ }
1333+ }
1334+ }
1335+
1336+ private void setSettingChCodeValue(ArrayList<TextValueSet> chvalue, ArrayList<TextValueSet> chtype, String res) {
1337+ chvalue.clear();
1338+ chtype.clear();
1339+ for ( String typ : new String[] { "uvd","bsd","csd","l1","l2","l3" } ) {
1340+ String txtkey = typ+"_ch_text";
1341+ String valkey = typ+"_ch_value";
1342+ Matcher mc = Pattern.compile("var "+txtkey+"\\s*= new Array\\((.+?)\\);",Pattern.DOTALL).matcher(res);
1343+ Matcher md = Pattern.compile("var "+valkey+"\\s*= new Array\\((.+?)\\);",Pattern.DOTALL).matcher(res);
1344+ if ( mc.find() && md.find() ) {
1345+ Matcher me = Pattern.compile("\"(.+?)\",?").matcher(mc.group(1));
1346+ Matcher mf = Pattern.compile("\"([^\"]+?)\",").matcher(md.group(1));
1347+ //System.out.println(txtkey+" "+mc.group(1));
1348+ //System.out.println(valkey+" "+md.group(1));
1349+ while ( me.find() && mf.find() ) {
1350+ TextValueSet t = new TextValueSet();
1351+ t.setText(me.group(1));
1352+ t.setValue(mf.group(1));
1353+ chvalue.add(t);
1354+
1355+ TextValueSet x = new TextValueSet();
1356+ x.setText(mf.group(1));
1357+ x.setValue(typ);
1358+ chtype.add(x);
1359+ }
1360+ }
1361+ }
1362+ }
1363+
1364+ private void setSettingApps(ArrayList<TextValueSet> tvs) {
1365+ tvs.clear();
1366+ TextValueSet t = null;
1367+
1368+ t = new TextValueSet();
1369+ t.setText(ITEM_APPS_RSV_TYPE_NOMAL);
1370+ t.setValue("");
1371+ tvs.add(t);
1372+
1373+ t = new TextValueSet();
1374+ t.setText(ITEM_APPS_RSV_TYPE_BRING);
1375+ t.setValue("0");
1376+ tvs.add(t);
1377+
1378+ t = new TextValueSet();
1379+ t.setText(ITEM_APPS_RSV_TYPE_BOTH);
1380+ t.setValue("1");
1381+ tvs.add(t);
1382+ }
1383+
1384+ private void setSettingEtc(ArrayList<TextValueSet> tvs, String key, int typ, String res) {
1385+ tvs.clear();
1386+ String valExpr = "(\\d+),?";
1387+ if (typ == 1) {
1388+ valExpr = "\"(.+?)\",?";
1389+ }
1390+ Matcher mc = Pattern.compile("var "+key+"_text\\s*= new Array\\(([\\s\\S]+?)\\);").matcher(res);
1391+ Matcher md = Pattern.compile("var "+key+"_value\\s*= new Array\\(([\\s\\S]+?)\\);").matcher(res);
1392+ if (mc.find() && md.find()) {
1393+ Matcher me = Pattern.compile("\"(.+?)\",?").matcher(mc.group(1));
1394+ Matcher mf = Pattern.compile(valExpr).matcher(md.group(1));
1395+ while (me.find() && mf.find()) {
1396+ TextValueSet t = new TextValueSet();
1397+ t.setText(me.group(1));
1398+ t.setValue(mf.group(1));
1399+ tvs.add(t);
1400+ }
1401+ }
1402+ }
1403+
1404+
1405+
1406+ //
1407+
1408+
1409+
1410+ /***
1411+ * RDデジタル系の予約一覧の解読
1412+ */
1413+ protected ArrayList<ReserveList> decodeReservedList(String response) {
1414+
1415+ ArrayList<ReserveList> newReserveList = new ArrayList<ReserveList>();
1416+
1417+ Matcher ma = Pattern.compile("(c1\\[\\d+?\\]=[\\s\\S]+?\";)\\n").matcher(response);
1418+ while ( ma.find() ) {
1419+
1420+ // 個々のデータを取り出す
1421+ ReserveList entry = new ReserveList();
1422+
1423+ Matcher mb = null;
1424+
1425+ String[] d = new String[18];
1426+ for ( int n=0; n < d.length; n++ ) {
1427+ d[n] = "";
1428+ }
1429+ mb = Pattern.compile("c(\\d+?)\\[\\d+?\\]=\"(.*?)\";").matcher(ma.group(1));
1430+ while ( mb.find() ) {
1431+ int n = Integer.valueOf(mb.group(1));
1432+ if ( n >= d.length ) {
1433+ continue;
1434+ }
1435+
1436+ d[n] = mb.group(2);
1437+ //System.out.println(n+") "+d[n]);
1438+ }
1439+
1440+ // 予約ID
1441+ entry.setId(d[1]);
1442+
1443+ // 実行ON/OFF
1444+ if (d[2].equals("2")) {
1445+ entry.setExec(false);
1446+ }
1447+
1448+ // 予約名
1449+ String title = CommonUtils.unEscape(d[3]).replaceAll("<BR>","");
1450+ entry.setTitle(title);
1451+ entry.setTitlePop(TraceProgram.replacePop(title));
1452+
1453+ // チャンネル
1454+ //entry.setCh_name(getChCode().getCH_NO2NAME(d[4])); // 機種固有領域に移動
1455+ entry.setChannel(d[5]);
1456+ entry.setCh_name(getChCode().getCH_REC2WEB(entry.getChannel()));
1457+
1458+ // 開始・終了日時
1459+ entry.setRec_pattern(d[6]);
1460+ entry.setRec_pattern_id(getRec_pattern_Id(entry.getRec_pattern()));
1461+ mb = Pattern.compile("(\\d\\d):(\\d\\d).*?(\\d\\d):(\\d\\d)").matcher(d[7]+"-"+d[8]);
1462+ if (mb.find()) {
1463+ entry.setAhh(mb.group(1));
1464+ entry.setAmm(mb.group(2));
1465+ entry.setZhh(mb.group(3));
1466+ entry.setZmm(mb.group(4));
1467+ }
1468+ entry.setRec_nextdate(CommonUtils.getNextDate(entry));
1469+ //entry.setRec_nextdate(getNextDate(entry.getRec_pattern(), entry.getZhh()+":"+entry.getZmm()));
1470+ entry.setRec_min(CommonUtils.getRecMin(entry.getAhh(), entry.getAmm(), entry.getZhh(), entry.getZmm()));
1471+ getStartEndDateTime(entry);
1472+
1473+ // 記録先デバイス
1474+ entry.setRec_device(d[9]);
1475+
1476+ // 画質・音質(取得できない)
1477+ //entry.setRec_mode(d[10]);
1478+ //entry.setRec_audio(d[11]);
1479+
1480+ // 番組追跡
1481+ if ( d[15].matches("^(1|2|3|4)$") ) {
1482+ entry.setPursues(true);
1483+ }
1484+
1485+ // 持出用フラグ
1486+ if (d[16].equals("1")) {
1487+ entry.setAppsRsv(true);
1488+ entry.setRec_mschapter(ITEM_APPS_RSV_TYPE_BRING);
1489+ }
1490+ else {
1491+ entry.setAppsRsv(false);
1492+ entry.setRec_mschapter(ITEM_APPS_RSV_TYPE_NOMAL);
1493+ }
1494+
1495+ // タイトル自動補完フラグなど本体からは取得できない情報を引き継ぐ
1496+ copyAttributes(entry, getReserves());
1497+
1498+ // 予約情報を保存
1499+ newReserveList.add(entry);
1500+ }
1501+ return(newReserveList);
1502+ }
1503+
1504+ // レコーダーから取得できない情報は直接コピー
1505+ @Override
1506+ protected void copyAttributes(ReserveList entry, ArrayList<ReserveList> reserves) {
1507+ for ( ReserveList e : reserves ) {
1508+ if ( e.getId().equals(entry.getId()) ) {
1509+ // 鯛ナビの内部フラグ
1510+ entry.setAutocomplete(e.getAutocomplete());
1511+
1512+ // 予約一覧からは取得できない情報
1513+ entry.setDetail(e.getDetail());
1514+ entry.setRec_genre(e.getRec_genre());
1515+ //entry.setRec_device(e.getRec_device());
1516+ entry.setRec_folder(e.getRec_folder());
1517+ //entry.setRec_mschapter(e.getRec_mschapter());
1518+ entry.setRec_mvchapter(e.getRec_mvchapter());
1519+ //
1520+ entry.setRec_aspect(e.getRec_aspect());
1521+ entry.setRec_mode(e.getRec_mode());
1522+
1523+ return;
1524+ }
1525+ }
1526+ }
1527+
1528+ private ArrayList<String[]> getIds(String response) {
1529+ ArrayList<String[]> ids = new ArrayList<String[]>();
1530+ Matcher ma = Pattern.compile("c1\\[\\d+?\\]=\"(\\d+?)\";.+?c16\\[\\d+?\\]=\"(\\d+?)\";").matcher(response);
1531+ while (ma.find()) {
1532+ String data[] = { ma.group(1), ma.group(2) };
1533+ ids.add(data);
1534+ }
1535+ return(ids);
1536+ }
1537+
1538+ private int getLineNo(String response, String id) {
1539+ Matcher ma = Pattern.compile("c1\\[(\\d+?)\\]=\""+id+"\";").matcher(response);
1540+ if ( ma.find() ) {
1541+ return(Integer.valueOf(ma.group(1))+1);
1542+ }
1543+ return(0);
1544+ }
1545+}
Show on old repository browser