X-Git-Url: http://git.osdn.net/view?p=rec10%2Frec10-git.git;a=blobdiff_plain;f=rec10%2Ftrunk%2Fsrc%2Finstall.py;h=25477bd91f83cee03ee57f612a24c44d9a223011;hp=d10ec47da0a9e912674f31fe06120dd176a57474;hb=12414a3ba81d93316e351ab51aa49bb71cf42f60;hpb=da6b8533a60a5c1c4530523cdc23f48f4a351767 diff --git a/rec10/trunk/src/install.py b/rec10/trunk/src/install.py index d10ec47..25477bd 100644 --- a/rec10/trunk/src/install.py +++ b/rec10/trunk/src/install.py @@ -54,26 +54,19 @@ def install(): 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) + rec10d.rec10db.change_installed_in_status(100) recdblist.printutf8(u"おめでとうございます 初期設定は完了しました。",verbose_level=100) recdblist.printutf8(u"rec10を実行するユーザーのcrontabに"+os.path.join(path,"rec10")+u"を追加してください(5分周期が目安)",verbose_level=100) - -def getLocalPath(cmd): + sys.exit(1) +def getLocalPath(cmd,exit=1): printutf8(cmd+u"の場所を確認中") txt=commands.getoutput(u"which "+cmd) if len(txt.split(" "))>3: - printutf8(cmd+u"の場所を確認できませんでした。終了します") - sys.exit(1) + if exit==1: + printutf8(cmd+u"の場所を確認できませんでした。終了します") + sys.exit(1) + else: + return "" else: printutf8(cmd+u" : "+txt) if len(txt.splitlines()): @@ -84,16 +77,19 @@ def move(): path = str(os.path.dirname(os.path.abspath(__file__))) printutf8(u"rec10 ver "+recdblist.version_str+" installer.") printutf8(u"rec10のインストールを開始します。") - maxn=13 + maxn=16 configwriter.setTempConfPath(u"wine", getLocalPath(u"wine")) - configwriter.setTempConfPath(u"recpt1", getLocalPath(u"recpt1")) + configwriter.setTempConfPath(u"recpt1", getLocalPath(u"recpt1",exit=0)) #configwriter.setpath(u"x264", getLocalPath(u"x264")) - configwriter.setTempConfPath(u"mp4box", getLocalPath(u"MP4Box")) + configwriter.setTempConfPath(u"mp4box", getLocalPath(u"MP4Box",exit=0)) configwriter.setTempConfPath(u"mencoder", getLocalPath(u"mencoder")) configwriter.setTempConfPath(u"ffmpeg", getLocalPath(u"ffmpeg")) - configwriter.setTempConfPath(u"mkvmerge", getLocalPath(u"mkvmerge")) + configwriter.setTempConfPath(u"mkvmerge", getLocalPath(u"mkvmerge",exit=0)) + configwriter.setTempConfPath(u"lame", getLocalPath(u"lame",exit=0)) configwriter.setTempConfPath(u"b25", getLocalPath(u"b25")) configwriter.setTempConfPath(u"tee", getLocalPath(u"tee")) + configwriter.setTempConfPath(u"java", getLocalPath(u"java")) + try: configwriter.setTempConfPath(u"lame", getLocalPath(u"lame")) except: @@ -120,14 +116,44 @@ def move(): printutf8(u"パスワードを設定してください(3/"+str(maxn)+")") mysql_passwd=getConf(useB,"/etc/rec10.conf","db","mysql_passwd","mysql_passwd : ") configwriter.setTempConfDB("mysql_passwd", mysql_passwd) + printutf8(u"BS/CSの設定に入ります") + printutf8(u"BS/CS(110度CS,スカパーe2)を受信しますか(4/"+str(maxn)+")") + useBSCS=raw_input("[Y/n]:") + if useBSCS=="N" or useBSCS=="n" or useBSCS=="no" or useBSCS=="NO": + useBSCS="0" + else: + useBSCS="1" + printutf8(u"ドライバの設定に入ります") + printutf8(u"DVB版のドライバを使用しますか(earth_pt1など。chardev版を使う場合はNo)(5/"+str(maxn)+")") + useDVB=raw_input("[y/N]:") + if useDVB=="Y" or useDVB=="y" or useDVB=="yes" or useDVB=="YES": + useDVB="1" + else: + useDVB="0" + configwriter.setTempConfDVB("useDVB", useDVB) + if useDVB=="1": + printutf8(u"DVBの設定に入ります") + printutf8(u"DVBAdapterの場所を設定して下さい") + printutf8(u"/dev/dvb/adapterなどdvr0の上のフォルダ(番号の前まで)を指定して下さい。") + getConf(useB,"/etc/rec10.conf","dvb","DVBadapter","/dev/dvb/adapter") + printutf8(u"地デジを受信可能なアダプタ番号を入力して下さい(1,3のように','で区切って下さい)") + getConf(useB,"/etc/rec10.conf","dvb","DVBTE","1,3") + if useBSCS=="1": + printutf8(u"BS/CSを受信可能なアダプタ番号を入力して下さい(0,2のように','で区切って下さい)") + getConf(useB,"/etc/rec10.conf","dvb","DVBBSCS","0,2") + else: + configwriter.setTempConfDVB("DVBBSCS","") printutf8(u"同時録画可能数の設定に入ります") - printutf8(u"TE(地デジ)録画可能数(PT*だと2 白Friioだと1)(4/"+str(maxn)+")") + printutf8(u"TE(地デジ)録画可能数(PT*だと2 白Friioだと1)(6/"+str(maxn)+")") te_max=str(int(getConf(useB,"/etc/rec10.conf","env","te_max","te_max : "))) configwriter.setTempConfEnv("te_max", te_max) - printutf8(u"BS/CS110録画可能数(PT*だと2 黒Friioだと1)(5/"+str(maxn)+")") - bscs_max=str(int(getConf(useB,"/etc/rec10.conf","env","bscs_max","bscs_max : "))) - configwriter.setTempConfEnv("bscs_max", bscs_max) - printutf8(u"同時エンコード最大数を設定してください(6/"+str(maxn)+")") + if useBSCS=="1": + printutf8(u"BS/CS110録画可能数(PT*だと2 黒Friioだと1)(7/"+str(maxn)+")") + bscs_max=str(int(getConf(useB,"/etc/rec10.conf","env","bscs_max","bscs_max : "))) + configwriter.setTempConfEnv("bscs_max", bscs_max) + else: + configwriter.setTempConfEnv("bscs_max", "0") + printutf8(u"同時エンコード最大数を設定してください(8/"+str(maxn)+")") printutf8(u"CPUのコア数が目安です") enc_max=raw_input("[2]:") if enc_max=="": @@ -136,12 +162,14 @@ def move(): enc_max=str(int(enc_max)) configwriter.setTempConfEnv("enc_max", enc_max) printutf8(u"二カ国語放送/5.1ch放送の音声変換の設定です。\nNeroAACエンコーダーを使用しますか?(NeroAACEncを別途入手してtstoolsに入れてください。))") - printutf8(u"入手先:http://www.nero.com/jpn/technologies-aac-codec.html\n (7/"+str(maxn)+")") + printutf8(u"入手先:http://www.nero.com/jpn/technologies-aac-codec.html\n (9/"+str(maxn)+")") audioenc=raw_input("[y/N]: ") if audioenc=="y" or audioenc=="Y": configwriter.setTempConfPath("useNeroAAC", "1") - printutf8(u"NeroAACEncのパスを指定してください") - aacpath=getConf(useB,"/etc/rec10.conf","path","NeroAAC","[/usr/local/bin/neroAacEnc] : ") + aacpath=getLocalPath(u"neroAacEnc",exit=0) + if len(aacpath)<2: + printutf8(u"NeroAACEncのパスを指定してください") + aacpath=getConf(useB,"/etc/rec10.conf","path","NeroAAC","[/usr/local/bin/neroAacEnc] : ") if aacpath.replace(" ","")=="": aacpath="/usr/local/bin/neroAacEnc" configwriter.setTempConfPath("NeroAAC",aacpath) @@ -150,38 +178,38 @@ def move(): aacpath="/usr/local/bin/neroAacEnc" configwriter.setTempConfPath("NeroAAC",aacpath) printutf8(u"lameを使用します。") - printutf8(u"x264のパスを指定してください(7/"+str(maxn)+")") + printutf8(u"x264のパスを指定してください(10/"+str(maxn)+")") x264path=getConf(useB,"/etc/rec10.conf","path","x264","x264 path : ") if x264path.replace(" ","")=="" or not os.path.isfile(x264path): x264path=getLocalPath(u"x264") configwriter.setTempConfPath("x264",x264path) - printutf8(u"保存する画質を教えてください(8/"+str(maxn)+")") + printutf8(u"保存する画質を教えてください(11/"+str(maxn)+")") printutf8(u"x264のcrfの値です。標準だと30分で800MBほどになります") crf=getConf(useB,"/etc/rec10.conf","env","crf","[24] : ") if crf.replace(" ","")=="": crf="24" configwriter.setTempConfEnv("crf", crf) - printutf8(u"アニメーションを保存する画質を教えてください(9/"+str(maxn)+")") + printutf8(u"アニメーションを保存する画質を教えてください(12/"+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.setTempConfEnv("animation_crf", a_crf) - printutf8(u"x264の圧縮率を設定してください(10/"+str(maxn)+")") + printutf8(u"x264の圧縮率を設定してください(13/"+str(maxn)+")") printutf8(u"x264のpresetの値です。標準だとmedium、小さければ小さいほど高圧縮になります") preset=getConf(useB,"/etc/rec10.conf","env","x264_preset","[4] : ") if preset.replace(" ","")=="": preset="4" configwriter.setTempConfEnv("x264_preset", preset) - printutf8(u"保存するコンテナの設定(11/"+str(maxn)+")") + printutf8(u"保存するコンテナの設定(14/"+str(maxn)+")") printutf8(u"MP4を標準にしますか(もしくはMKVが使えます)") - useMP4=raw_input("[y/N]:") - if useMP4=="Y" or useMP4 == "y" : - useMP4="1" - else: + useMP4=raw_input("[Y/n]:") + if useMP4=="N" or useMP4 == "n" : useMP4="0" + else: + useMP4="1" configwriter.setTempConfEnv("make_mp4", useMP4) - printutf8(u"TSファイルの自動削除(12/"+str(maxn)+")") + printutf8(u"TSファイルの自動削除(15/"+str(maxn)+")") printutf8(u"中間体のtsファイルを削除しますか") printutf8(u"(削除するとやり直しができないため残しておくことを推奨します。)") removeTS=raw_input("[y/N]:") @@ -190,7 +218,7 @@ def move(): else: removeTS="0" configwriter.setTempConfEnv("remove_ts", removeTS) - printutf8(u"自機識別オプション(13/"+str(maxn)+")") + printutf8(u"自機識別オプション(16/"+str(maxn)+")") printutf8(u"本rec10の識別名を入力してください") printutf8(u"複数台のrec10を運用する場合に効果的です。空白でもかまいません。") printutf8(u"例 kobe01")