OSDN Git Service

improve installer.
[rec10/rec10-git.git] / rec10 / trunk / src / install.py
index 1ce5dcc..9374f37 100644 (file)
@@ -12,7 +12,7 @@ import shutil
 
 import recdblist
 def install():
-    version = 93
+    version = recdblist.version
     recdblist.printutf8(u"rec10の環境インストールを開始します。")
     time.sleep(1)
     recdblist.printutf8(u"環境インストール処理中・・・")
@@ -81,10 +81,11 @@ def getpath(cmd):
             txt=txt.splitlines()[0]
         return txt.strip()
 def move():
+    useB=0
     path = str(os.path.dirname(os.path.abspath(__file__)))
     recdblist.printutf8(u"rec10 ver 0.9.3 installer.")
     recdblist.printutf8(u"rec10のインストールを開始します。")
-    maxn=12
+    maxn=14
     configwriter.setpath(u"wine", getpath(u"wine"))
     configwriter.setpath(u"recpt1", getpath(u"recpt1"))
     configwriter.setpath(u"x264", getpath(u"x264"))
@@ -96,25 +97,34 @@ def move():
     configwriter.setpath(u"b25", getpath(u"b25"))
     recdblist.printutf8(u"必須環境の設定が完了しました")
     recdblist.printutf8(u"個人設定に入ります")
+    if os.path.exists("/etc/rec10.conf"):
+        recdblist.printutf8(u"以前の設定ファイルが見つかりました。")
+        recdblist.printutf8(u"インポートしますか?")
+        useB=raw_input("[Y/n]:")
+        if useB=="N" or useB == "n":
+            useB=0
+        else:
+            useB=1
+            recdblist.printutf8(u"設定ファイルのインポーを行います。")
     recdblist.printutf8(u"rec10の録画ファイルが置かれる場所を入力してください(1/"+str(maxn)+")")
     recdblist.printutf8(u"100GB程度は確保されている必要があります")
-    recpath=raw_input("path : ")
+    recpath=getConf(useB,"/etc/rec10.conf","path","recpath","path : ")
     configwriter.setpath(u"recpath",recpath)
     recdblist.printutf8(u"DBの設定に入ります。")
     recdblist.printutf8(u"rec10が使用するMySQLのユーザーを設定してください。(2/"+str(maxn)+")")
-    mysql_user=raw_input("mysql_user : ")
+    mysql_user=getConf(useB,"/etc/rec10.conf","db","mysql_user","mysql_user : ")
     configwriter.setdbpath("mysql_user", mysql_user)
     recdblist.printutf8(u"パスワードを設定してください(3/"+str(maxn)+")")
-    mysql_passwd=raw_input("mysql_passwd : ")
+    mysql_passwd=getConf(useB,"/etc/rec10.conf","db","mysql_passwd","mysql_passwd : ")
     configwriter.setdbpath("mysql_passwd", mysql_passwd)
     recdblist.printutf8(u"同時録画可能数の設定に入ります")
     recdblist.printutf8(u"TE(地デジ)録画可能数(PT*だと2 白Friioだと1)(4/"+str(maxn)+")")
     te_max=raw_input("te_max : ")
-    te_max=str(int(te_max))
+    te_max=str(int(getConf(useB,"/etc/rec10.conf","env","te_max","te_max : ")))
     configwriter.setenv("te_max", te_max)
     recdblist.printutf8(u"BS/CS110録画可能数(PT*だと2 黒Friioだと1)(5/"+str(maxn)+")")
     bscs_max=raw_input("bscs_max : ")
-    bscs_max=str(int(bscs_max))
+    bscs_max=str(int(getConf(useB,"/etc/rec10.conf","env","bscs_max","bscs_max : ")))
     configwriter.setenv("bscs_max", bscs_max)
     recdblist.printutf8(u"同時エンコード最大数を設定してください(6/"+str(maxn)+")")
     recdblist.printutf8(u"CPUのコア数が目安です")
@@ -124,50 +134,39 @@ def move():
     else:
         enc_max=str(int(enc_max))
     configwriter.setenv("enc_max", enc_max)
-
     recdblist.printutf8(u"二カ国語放送/5.1ch放送の音声変換の設定です。\nNeroAACエンコーダーを使用しますか?(NeroAACEncを別途入手してtstoolsに入れてください。))")
     recdblist.printutf8(u"入手先:http://www.nero.com/jpn/technologies-aac-codec.html\n (7/"+str(maxn)+")")
     audioenc=raw_input("[y/N]:  ")
     if audioenc=="y" or audioenc=="Y":
         configwriter.setpath("useNeroAAC", "1")
         recdblist.printutf8(u"NeroAACEncのパスを指定してください")
-        aacpath=raw_input("[/usr/local/bin/neroAacEnc] : ")
-        if aacpath.replace(" ","")!="" and os.path.isfile(aacpath):
-            configwriter.setpath("NeroAAC", aacpath)
-        else:
-            recdblist.printutf8(u"実行可能ファイルが見つかりませんでした。")
-            configwriter.setpath("useNeroAAC", "0")
-            recdblist.printutf8(u"lameを使用します。")
+        aacpath=getConf(useB,"/etc/rec10.conf","path","NeroAAC","[/usr/local/bin/neroAacEnc] : ")
+        if aacpath.replace(" ","")=="":
+            aacpath="/usr/local/bin/neroAacEnc"
+        configwriter.setpath("NeroAAC",aacpath)
     else:
+        configwriter.setpath("useNeroAAC", "0")
         recdblist.printutf8(u"lameを使用します。")
-
     recdblist.printutf8(u"保存する画質を教えてください(7/"+str(maxn)+")")
     recdblist.printutf8(u"x264のcrfの値です。標準だと30分で800MBほどになります")
-    crf=raw_input("[20]:")
-    if crf=="":
-        crf="20"
-    else:
-        crf=str(int(crf))
+    crf=getConf(useB,"/etc/rec10.conf","env","crf","[24] : ")
+    if crf.replace(" ","")=="":
+        crf="24"
     configwriter.setenv("crf", crf)
-
     recdblist.printutf8(u"アニメーションを保存する画質を教えてください(8/"+str(maxn)+")")
     recdblist.printutf8(u"x264のcrfの値です。標準だと30分で800MBほどになります")
-    a_crf=raw_input("[18]:")
-    if a_crf=="":
-        a_crf="18"
-    else:
-        a_crf=str(int(a_crf))
+    a_crf=getConf(useB,"/etc/rec10.conf","env","animation_crf","[20] : ")
+    if a_crf.replace(" ","")=="":
+        a_crf="20"
     configwriter.setenv("animation_crf", a_crf)
     
     recdblist.printutf8(u"x264の圧縮率を設定してください(8/"+str(maxn)+")")
     recdblist.printutf8(u"x264のpresetの値です。標準だとmedium、小さければ小さいほど高圧縮になります")
     preset=raw_input("[4]:")
-    if preset=="":
-        preset="18"
-    else:
-        preset=str(int(preset))
+    preset=getConf(useB,"/etc/rec10.conf","env","x264_preset","[4] : ")
+    if preset.replace(" ","")=="":
+        preset="4"
     configwriter.setenv("x264_preset", preset)
-
     recdblist.printutf8(u"保存するコンテナの設定(9/"+str(maxn)+")")
     recdblist.printutf8(u"MP4を標準にしますか(もしくはMKVが使えます)")
     useMP4=raw_input("[y/N]:")
@@ -177,8 +176,16 @@ def move():
         useMP4="0"
     configwriter.setenv("make_mp4", useMP4)
 
-
-    recdblist.printutf8(u"チャンネルの設定に入ります(10/"+str(maxn)+")")
+    recdblist.printutf8(u"TSファイルの自動削除(10/"+str(maxn)+")")
+    recdblist.printutf8(u"中間体のtsファイルを削除しますか")
+    recdblist.printutf8(u"(削除するとやり直しができないため残しておくことを推奨します。)")
+    removeTS=raw_input("[y/N]:")
+    if removeTS=="Y" or removeTS == "y" :
+        removeTS="1"
+    else:
+        removeTS="0"
+    configwriter.setenv("remove_ts", removeTS)
+    recdblist.printutf8(u"チャンネルの設定に入ります(11/"+str(maxn)+")")
     recdblist.printutf8(u"rec10を設置する地域を選んでください。")
     recdblist.printutf8(u"1:東京 2:神戸 3:名古屋 4:その他")
     ch=raw_input()
@@ -193,14 +200,14 @@ def move():
         recdblist.printutf8(u"チャンネルの設定が必要です。")
         recdblist.printutf8(u"chlist_sample_*を参考にchlist.xmlを作成した後に次のステップに進んでください。")
         time.sleep(5)
-    recdblist.printutf8(u"BS放送は受信可能ですか?(11/"+str(maxn)+")")
+    recdblist.printutf8(u"BS放送は受信可能ですか?(12/"+str(maxn)+")")
     bsok=raw_input("y/N:")
     if bsok=="Y" or bsok == "y" :
         bsok="1"
     else:
         bsok="0"
     configwriter.setenv("bs", bsok)
-    recdblist.printutf8(u"CS放送(スカパーe2)は受信可能ですか?(12/"+str(maxn)+")")
+    recdblist.printutf8(u"CS放送(スカパーe2)は受信可能ですか?(13/"+str(maxn)+")")
     csok=raw_input("y/N:")
     if csok=="Y" or csok == "y" :
         csok="1"
@@ -208,8 +215,40 @@ def move():
     else:
         csok="0"
     configwriter.setenv("cs", csok)
+
+    recdblist.printutf8(u"自機識別オプション(14/"+str(maxn)+")")
+    recdblist.printutf8(u"本rec10の識別名を入力してください")
+    recdblist.printutf8(u"複数台のrec10を運用する場合に効果的です。空白でもかまいません。")
+    recdblist.printutf8(u"例 kobe01")
+    iff=getConf(useB,"/etc/rec10.conf","env","iff","[] : ")
+    configwriter.setenv("iff", iff)
+    confp = ConfigParser.SafeConfigParser()
+    Bconf=confp.read("/etc/rec10.conf")
+    if useB:
+        configwriter.setpath("recorded",Bconf.get("path","recorded"))
+        configwriter.setpath("move_destpath",Bconf.get("path","move_destpath"))
+        configwriter.setpath("tmp",Bconf.get("path","tmp"))
+        try:
+            configwriter.setenv("x264_addline",Bconf.get("env","x264_addline"))
+        except:
+            configwriter.setenv("x264_addline","")
     configwriter.writeconf()
     recdblist.printutf8(u"初期設定が終了しました。")
     recdblist.printutf8(u"makeを実行した後にrootにてmake installを実行するとインストールされます。")
+def getConf(useBeforeConf,Confpath,dbsection,key,defaultstr):
+    tstr=defaultstr
+    if os.path.exists(Confpath) and useBeforeConf==1:
+        try:
+            confp = ConfigParser.SafeConfigParser()
+            confp.read("/etc/rec10.conf")
+            tstr=u"["+confp.get(dbsection,key)+u"]:"
+        except:
+            tstr=defaultstr
+    tmpconf=raw_input(tstr)
+    if tmpconf.replace(" ","")=="" and os.path.exists(Confpath) and useBeforeConf==1 :
+        confp = ConfigParser.SafeConfigParser()
+        confp.read("/etc/rec10.conf")
+        tmpconf=confp.get(dbsection,key)
+    return tmpconf
 if __name__ == "__main__":
     move()
\ No newline at end of file