OSDN Git Service

implement update(to 0.9.10)
[rec10/rec10-git.git] / rec10 / trunk / src / install.py
index ec974e6..d6430ea 100644 (file)
@@ -9,15 +9,16 @@ import sys
 import commands
 import configwriter
 import shutil
+import traceback
 
 import recdblist
 def printutf8(str):
     print str.encode('utf-8')
 def install():
     version = recdblist.version
-    recdblist.printutf8(u"rec10の環境インストールを開始します。")
+    recdblist.printutf8(u"rec10の環境インストールを開始します。",verbose_level=100)
     time.sleep(1)
-    recdblist.printutf8(u"環境インストール処理中・・・")
+    recdblist.printutf8(u"環境インストール処理中・・・",verbose_level=100)
     path = str(os.path.dirname(os.path.abspath(__file__)))
     confp = ConfigParser.SafeConfigParser()
     Conf = 'rec10.conf'
@@ -31,36 +32,42 @@ def install():
     if confpath!="":
         confp.read(confpath)
     else:
-        recdblist.printutf8(u"rec10.confが見つかりません。")
-        recdblist.printutf8(u"このinstall.pyと同じフォルダに置くか、/etc/rec10.confもしくは/etc/rec10/rec10.confにおいてください。")
+        recdblist.printutf8(u"rec10.confが見つかりません。",verbose_level=100)
+        recdblist.printutf8(u"このinstall.pyと同じフォルダに置くか、/etc/rec10.confもしくは/etc/rec10/rec10.confにおいてください。",verbose_level=100)
         sys.exit(1)
-    recdblist.printutf8(u"設定ファイルの読み込みを確認//設定ファイルのパスは"+confpath)
+    recdblist.printutf8(u"設定ファイルの読み込みを確認//設定ファイルのパスは"+confpath,verbose_level=100)
     if confp.get('path',"recpath")=="/path of /recording":
-        recdblist.printutf8(u"録画先のフォルダを設定してください(recpath=)")
+        recdblist.printutf8(u"録画先のフォルダを設定してください(recpath=)",verbose_level=100)
         sys.exit(1)
-    recdblist.printutf8(u"DB処理に入ります")
+    recdblist.printutf8(u"DB処理に入ります",verbose_level=100)
     if os.path.exists(os.path.join(path,"rec10d.py")):
         try:
             update_db_all()
         except Exception, inst:
-            recdblist.printutf8(u"DB処理中にエラーが出ました。configファイルのDB設定を見直してください。")
-            recdblist.printutf8(str(type(inst)))
-            recdblist.printutf8(str(inst))
-    recdblist.printutf8(u"チャンネル設定に入ります")
-    if os.path.exists(os.path.join(path,"chlist.xml")):
-        recdblist.printutf8(u"チャンネルリストが見つかりました。||chlist.xml")
-    else:
-        recdblist.printutf8(u"チャンネルリストが見つかりません。"+os.path.join(path,"chlist.xml")+u"を作成してください。")
-        recdblist.printutf8(u"東京/名古屋/神戸のサンプルがchlist_sample_*.xmlにあるため、参考にしてください。")
-        sys.exit(1)
-    bsok=int(confp.get('env',"bs"))
-    csok=int(confp.get('env',"cs"))
-    import chdata
-    chdata.new_chdata(bsok,csok)
-    recdblist.printutf8(u"おめでとうございます 初期設定は完了しました。")
-    recdblist.printutf8(u"rec10を実行するユーザーのcrontabに"+os.path.join(path,"rec10")+u"を追加してください(5分周期が目安)")
+            recdblist.printutf8(u"DB処理中にエラーが出ました。configファイルのDB設定を見直してください。",verbose_level=100)
+            recdblist.printutf8(str(type(inst)),verbose_level=100)
+            recdblist.printutf8(str(inst)+"\n"+traceback.format_exc(),verbose_level=100)
     import rec10d
     rec10d.rec10db.change_installed_in_status()
+    recdblist.printutf8(u"チャンネル設定に入ります",verbose_level=100)
+    import scan_ch
+    rec10d.rec10db.new_epg_ch()
+    recdblist.printutf8(u"チャンネルスキャンの開始",verbose_level=100)
+    scan_ch.searchCh()
+    rec10d.rec10db.change_chscaned_in_status()
+    #if os.path.exists(os.path.join(path,"chlist.xml")):
+    #    recdblist.printutf8(u"チャンネルリストが見つかりました。||chlist.xml",verbose_level=100)
+    #else:
+    #    recdblist.printutf8(u"チャンネルリストが見つかりません。"+os.path.join(path,"chlist.xml")+u"を作成してください。",verbose_level=100)
+    #    recdblist.printutf8(u"東京/名古屋/神戸のサンプルがchlist_sample_*.xmlにあるため、参考にしてください。",verbose_level=100)
+    #    sys.exit(1)
+    #bsok=int(confp.get('env',"bs"))
+    #csok=int(confp.get('env',"cs"))
+    #import chdata
+    #chdata.new_chdata(bsok,csok)
+    recdblist.printutf8(u"おめでとうございます 初期設定は完了しました。",verbose_level=100)
+    recdblist.printutf8(u"rec10を実行するユーザーのcrontabに"+os.path.join(path,"rec10")+u"を追加してください(5分周期が目安)",verbose_level=100)
+    
 def getpath(cmd):
     printutf8(cmd+u"の場所を確認中")
     txt=commands.getoutput(u"which "+cmd)
@@ -75,12 +82,12 @@ def getpath(cmd):
 def move():
     useB=0
     path = str(os.path.dirname(os.path.abspath(__file__)))
-    printutf8(u"rec10 ver 0.9.4 installer.")
+    printutf8(u"rec10 ver "+recdblist.version_str+" installer.")
     printutf8(u"rec10のインストールを開始します。")
-    maxn=14
+    maxn=16
     configwriter.setpath(u"wine", getpath(u"wine"))
     configwriter.setpath(u"recpt1", getpath(u"recpt1"))
-    configwriter.setpath(u"x264", getpath(u"x264"))
+    #configwriter.setpath(u"x264", getpath(u"x264"))
     configwriter.setpath(u"mp4box", getpath(u"MP4Box"))
     configwriter.setpath(u"mencoder", getpath(u"mencoder"))
     configwriter.setpath(u"ffmpeg", getpath(u"ffmpeg"))
@@ -96,7 +103,7 @@ def move():
             useB=0
         else:
             useB=1
-            printutf8(u"設定ファイルのインポーを行います。")
+            printutf8(u"設å®\9aã\83\95ã\82¡ã\82¤ã\83«ã\81®ã\82¤ã\83³ã\83\9dã\83¼ã\83\88ã\82\92è¡\8cã\81\84ã\81¾ã\81\99ã\80\82")
     printutf8(u"rec10の録画ファイルが置かれる場所を入力してください(1/"+str(maxn)+")")
     printutf8(u"100GB程度は確保されている必要があります")
     recpath=getConf(useB,"/etc/rec10.conf","path","recpath","path : ")
@@ -136,25 +143,30 @@ def move():
     else:
         configwriter.setpath("useNeroAAC", "0")
         printutf8(u"lameを使用します。")
-    printutf8(u"保存する画質を教えてください(7/"+str(maxn)+")")
+    printutf8(u"x264のパスを指定してください(7/"+str(maxn)+")")
+    x264path=getConf(useB,"/etc/rec10.conf","path","x264","x264 path : ")
+    if x264path.replace(" ","")=="" or not os.path.isfile(x264path):
+        x264path=getpath(u"x264")
+    configwriter.setpath("x264",x264path)
+    printutf8(u"保存する画質を教えてください(8/"+str(maxn)+")")
     printutf8(u"x264のcrfの値です。標準だと30分で800MBほどになります")
     crf=getConf(useB,"/etc/rec10.conf","env","crf","[24] : ")
     if crf.replace(" ","")=="":
         crf="24"
     configwriter.setenv("crf", crf)
-    printutf8(u"アニメーションを保存する画質を教えてください(8/"+str(maxn)+")")
+    printutf8(u"アニメーションを保存する画質を教えてください(9/"+str(maxn)+")")
     printutf8(u"x264のcrfの値です。標準だと30分で800MBほどになります")
     a_crf=getConf(useB,"/etc/rec10.conf","env","animation_crf","[20] : ")
     if a_crf.replace(" ","")=="":
         a_crf="20"
     configwriter.setenv("animation_crf", a_crf)
-    printutf8(u"x264の圧縮率を設定してください(8/"+str(maxn)+")")
+    printutf8(u"x264の圧縮率を設定してください(10/"+str(maxn)+")")
     printutf8(u"x264のpresetの値です。標準だとmedium、小さければ小さいほど高圧縮になります")
     preset=getConf(useB,"/etc/rec10.conf","env","x264_preset","[4] : ")
     if preset.replace(" ","")=="":
         preset="4"
     configwriter.setenv("x264_preset", preset)
-    printutf8(u"保存するコンテナの設定(9/"+str(maxn)+")")
+    printutf8(u"保存するコンテナの設定(11/"+str(maxn)+")")
     printutf8(u"MP4を標準にしますか(もしくはMKVが使えます)")
     useMP4=raw_input("[y/N]:")
     if useMP4=="Y" or useMP4 == "y" :
@@ -162,7 +174,7 @@ def move():
     else:
         useMP4="0"
     configwriter.setenv("make_mp4", useMP4)
-    printutf8(u"TSファイルの自動削除(10/"+str(maxn)+")")
+    printutf8(u"TSファイルの自動削除(12/"+str(maxn)+")")
     printutf8(u"中間体のtsファイルを削除しますか")
     printutf8(u"(削除するとやり直しができないため残しておくことを推奨します。)")
     removeTS=raw_input("[y/N]:")
@@ -171,7 +183,7 @@ def move():
     else:
         removeTS="0"
     configwriter.setenv("remove_ts", removeTS)
-    printutf8(u"チャンネルの設定に入ります(11/"+str(maxn)+")")
+    printutf8(u"チャンネルの設定に入ります(13/"+str(maxn)+")")
     printutf8(u"rec10を設置する地域を選んでください。")
     printutf8(u"1:東京 2:神戸 3:名古屋 4:その他")
     ch=raw_input()
@@ -196,14 +208,14 @@ def move():
             printutf8(u"チャンネルの設定が必要です。")
             printutf8(u"chlist_sample_*を参考にchlist.xmlを作成した後に次のステップに進んでください。")
             time.sleep(5)
-    printutf8(u"BS放送は受信可能ですか?(12/"+str(maxn)+")")
+    printutf8(u"BS放送は受信可能ですか?(14/"+str(maxn)+")")
     bsok=raw_input("y/N:")
     if bsok=="Y" or bsok == "y" :
         bsok="1"
     else:
         bsok="0"
     configwriter.setenv("bs", bsok)
-    printutf8(u"CS放送(スカパーe2)は受信可能ですか?(13/"+str(maxn)+")")
+    printutf8(u"CS放送(スカパーe2)は受信可能ですか?(15/"+str(maxn)+")")
     csok=raw_input("y/N:")
     if csok=="Y" or csok == "y" :
         csok="1"
@@ -212,7 +224,7 @@ def move():
         csok="0"
     configwriter.setenv("cs", csok)
 
-    printutf8(u"自機識別オプション(14/"+str(maxn)+")")
+    printutf8(u"自機識別オプション(16/"+str(maxn)+")")
     printutf8(u"本rec10の識別名を入力してください")
     printutf8(u"複数台のrec10を運用する場合に効果的です。空白でもかまいません。")
     printutf8(u"例 kobe01")
@@ -264,11 +276,11 @@ def update_db_all():
     if rec10d.rec10db.select_installed_in_status()==1:
         if rec10d.rec10db.select_version_in_status()==0:
             tversion=0
-            recdblist.printutf8(u"既存のDBが見つかりました。0.9.1と仮定してアップデート処理を行います。")
+            recdblist.printutf8(u"既存のDBが見つかりました。0.9.1と仮定してアップデート処理を行います。",verbose_level=100)
             update_db(0)
             time.sleep(1)
         else:
-            recdblist.printutf8(u"既存のDBが見つかりました。アップデート処理を行います。")
+            recdblist.printutf8(u"既存のDBが見つかりました。アップデート処理を行います。",verbose_level=100)
         tversion=int(rec10d.rec10db.select_version_in_status())
         while (recdblist.version>tversion):
             update_db(tversion)
@@ -286,5 +298,13 @@ def update_db(version):
         rec10d.rec10db.update_db_to93()
     elif version==93:
         rec10d.rec10db.update_db_93to94()
+    elif version==94:
+        rec10d.rec10db.update_db_94to95()
+    elif version==95:
+        rec10d.rec10db.update_db_95to96()
+    elif version==96:
+        rec10d.rec10db.update_db_96to98()
+    elif version==98:
+        rec10d.rec10db.update_db_98to100()
 if __name__ == "__main__":
     move()