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'
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:
- import rec10d
- if rec10d.rec10db.select_version_in_status()==0 and rec10d.rec10db.select_installed_in_status()==1:
- recdblist.printutf8(u"既存のDBが見つかりました。0.9.1と仮定してアップデート処理を行います。")
- rec10d.rec10db.update_db_to93()
- else:
- rec10d.rec10db.drop_in_status()
- rec10d.rec10db.drop_in_settings()
- time.sleep(2)
- rec10d.rec10db.new_in_status()
- rec10d.rec10db.new_in_settings()
- rec10d.rec10db.change_version_in_status(version)
+ update_db_all()
except Exception, inst:
- recdblist.printutf8(u"DB処理中にエラーが出ました。configファイルのDB設定を見直してください。")
- print type(inst)
- print 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):
- recdblist.printutf8(cmd+u"の場所を確認中")
+ printutf8(cmd+u"の場所を確認中")
txt=commands.getoutput(u"which "+cmd)
if len(txt.split(" "))>3:
- recdblist.printutf8(cmd+u"の場所を確認できませんでした。終了します")
+ printutf8(cmd+u"の場所を確認できませんでした。終了します")
sys.exit(1)
else:
- recdblist.printutf8(cmd+u" : "+txt)
+ printutf8(cmd+u" : "+txt)
if len(txt.splitlines()):
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=14
+ printutf8(u"rec10 ver "+recdblist.version_str+" installer.")
+ printutf8(u"rec10のインストールを開始します。")
+ 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"MP4Box", getpath(u"MP4Box"))
+ #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"))
- #configwriter.setpath(u"xvfb-run", getpath(u"xvfb-run"))
configwriter.setpath(u"mkvmerge", getpath(u"mkvmerge"))
configwriter.setpath(u"b25", getpath(u"b25"))
- recdblist.printutf8(u"必須環境の設定が完了しました")
- recdblist.printutf8(u"個人設定に入ります")
+ printutf8(u"必須環境の設定が完了しました")
+ printutf8(u"個人設定に入ります")
if os.path.exists("/etc/rec10.conf"):
- recdblist.printutf8(u"以前の設定ファイルが見つかりました。")
- recdblist.printutf8(u"インポートしますか?")
+ printutf8(u"以前の設定ファイルが見つかりました。")
+ 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程度は確保されている必要があります")
+ printutf8(u"設定ファイルのインポートを行います。")
+ printutf8(u"rec10の録画ファイルが置かれる場所を入力してください(1/"+str(maxn)+")")
+ printutf8(u"100GB程度は確保されている必要があります")
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)+")")
+ printutf8(u"DBの設定に入ります。")
+ printutf8(u"rec10が使用するMySQLのユーザーを設定してください。(2/"+str(maxn)+")")
mysql_user=getConf(useB,"/etc/rec10.conf","db","mysql_user","mysql_user : ")
configwriter.setdbpath("mysql_user", mysql_user)
- recdblist.printutf8(u"パスワードを設定してください(3/"+str(maxn)+")")
+ printutf8(u"パスワードを設定してください(3/"+str(maxn)+")")
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 : ")
+ printutf8(u"同時録画可能数の設定に入ります")
+ printutf8(u"TE(地デジ)録画可能数(PT*だと2 白Friioだと1)(4/"+str(maxn)+")")
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 : ")
+ 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.setenv("bscs_max", bscs_max)
- recdblist.printutf8(u"同時エンコード最大数を設定してください(6/"+str(maxn)+")")
- recdblist.printutf8(u"CPUのコア数が目安です")
+ printutf8(u"同時エンコード最大数を設定してください(6/"+str(maxn)+")")
+ printutf8(u"CPUのコア数が目安です")
enc_max=raw_input("[2]:")
if enc_max=="":
enc_max="2"
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)+")")
+ printutf8(u"二カ国語放送/5.1ch放送の音声変換の設定です。\nNeroAACエンコーダーを使用しますか?(NeroAACEncを別途入手してtstoolsに入れてください。))")
+ 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のパスを指定してください")
+ printutf8(u"NeroAACEncのパスを指定してください")
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ほどになります")
+ printutf8(u"lameを使用します。")
+ 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)
- recdblist.printutf8(u"アニメーションを保存する画質を教えてください(8/"+str(maxn)+")")
- recdblist.printutf8(u"x264のcrfの値です。標準だと30分で800MBほどになります")
+ 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)
-
- recdblist.printutf8(u"x264の圧縮率を設定してください(8/"+str(maxn)+")")
- recdblist.printutf8(u"x264のpresetの値です。標準だとmedium、小さければ小さいほど高圧縮になります")
- preset=raw_input("[4]:")
+ 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)
- recdblist.printutf8(u"保存するコンテナの設定(9/"+str(maxn)+")")
- recdblist.printutf8(u"MP4を標準にしますか(もしくはMKVが使えます)")
+ printutf8(u"保存するコンテナの設定(11/"+str(maxn)+")")
+ printutf8(u"MP4を標準にしますか(もしくはMKVが使えます)")
useMP4=raw_input("[y/N]:")
if useMP4=="Y" or useMP4 == "y" :
useMP4="1"
else:
useMP4="0"
configwriter.setenv("make_mp4", useMP4)
-
- recdblist.printutf8(u"TSファイルの自動削除(10/"+str(maxn)+")")
- recdblist.printutf8(u"中間体のtsファイルを削除しますか")
- recdblist.printutf8(u"(削除するとやり直しができないため残しておくことを推奨します。)")
+ printutf8(u"TSファイルの自動削除(12/"+str(maxn)+")")
+ printutf8(u"中間体のtsファイルを削除しますか")
+ 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:その他")
+ printutf8(u"チャンネルの設定に入ります(13/"+str(maxn)+")")
+ printutf8(u"rec10を設置する地域を選んでください。")
+ printutf8(u"1:東京 2:神戸 3:名古屋 4:その他")
ch=raw_input()
ch=int(ch)
if ch==1:
- shutil.copy(os.path.join(path,"chlist_sample_tokyo.xml"),os.path.join(path,"chlist.xml"))
+ try:
+ shutil.copy(os.path.join(path,"chlist_sample_tokyo.xml"),os.path.join(path,"chlist.xml"))
+ except:
+ printutf8(u"既存のchlis.xmlを上書きできないため、前のものを使います。")
elif ch==2:
- shutil.copy(os.path.join(path,"chlist_sample_kobe.xml"),os.path.join(path,"chlist.xml"))
+ try:
+ shutil.copy(os.path.join(path,"chlist_sample_kobe.xml"),os.path.join(path,"chlist.xml"))
+ except:
+ printutf8(u"既存のchlis.xmlを上書きできないため、前のものを使います。")
elif ch==3:
- shutil.copy(os.path.join(path,"chlist_sample_nagoya.xml"),os.path.join(path,"chlist.xml"))
+ try:
+ shutil.copy(os.path.join(path,"chlist_sample_nagoya.xml"),os.path.join(path,"chlist.xml"))
+ except:
+ printutf8(u"既存のchlis.xmlを上書きできないため、前のものを使います。")
elif ch==4:
- recdblist.printutf8(u"チャンネルの設定が必要です。")
- recdblist.printutf8(u"chlist_sample_*を参考にchlist.xmlを作成した後に次のステップに進んでください。")
- time.sleep(5)
- recdblist.printutf8(u"BS放送は受信可能ですか?(12/"+str(maxn)+")")
+ if not os.path.exists(os.path.join(path,"chlist.xml")):
+ printutf8(u"チャンネルの設定が必要です。")
+ printutf8(u"chlist_sample_*を参考にchlist.xmlを作成した後に次のステップに進んでください。")
+ time.sleep(5)
+ 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)
- recdblist.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"
- recdblist.printutf8(u"標準パックの番組は入力してありますがそれ以外は追加でchlist_cs.xmlに追加する必要があります。")
+ printutf8(u"標準パックの番組は入力してありますがそれ以外は追加でchlist_cs.xmlに追加する必要があります。")
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")
+ printutf8(u"自機識別オプション(16/"+str(maxn)+")")
+ printutf8(u"本rec10の識別名を入力してください")
+ printutf8(u"複数台のrec10を運用する場合に効果的です。空白でもかまいません。")
+ printutf8(u"例 kobe01")
iff=getConf(useB,"/etc/rec10.conf","env","iff","[] : ")
configwriter.setenv("iff", iff)
confp = ConfigParser.SafeConfigParser()
- Bconf=confp.read("/etc/rec10.conf")
+ 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"))
+ configwriter.setpath("recorded",confp.get("path","recorded"))
+ configwriter.setpath("move_destpath",confp.get("path","move_destpath"))
+ configwriter.setpath("tmp",confp.get("path","tmp"))
try:
- configwriter.setenv("x264_addline",Bconf.get("env","x264_addline"))
+ configwriter.setenv("x264_addline",confp.get("env","x264_addline"))
except:
configwriter.setenv("x264_addline","")
+ if confp.get("path","b25_remote")=="":
+ configwriter.setpath("b25_remote", "0")
+ elif confp.get("path","b25_remote")=="1":
+ configwriter.setpath("b25_remote", confp.get("path","b25_remote"))
+ configwriter.setpath("b25", confp.get("path","b25"))
+ configwriter.setpath("b25_env", confp.get("path","b25_env"))
+ else:
+ configwriter.setpath("b25_remote", confp.get("path","b25_remote"))
+
configwriter.writeconf()
- recdblist.printutf8(u"初期設定が終了しました。")
- recdblist.printutf8(u"makeを実行した後にrootにてmake installを実行するとインストールされます。")
+ printutf8(u"初期設定が終了しました。")
+ 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"["+conf.get(dbsection,key)+u"]:"
+ 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()
- conf=confp.read("/etc/rec10.conf")
- tmpconf=conf.get(dbsection,key)
+ confp.read("/etc/rec10.conf")
+ try:
+ tmpconf=confp.get(dbsection,key)
+ except:
+ tmpconf=""
return tmpconf
+def update_db_all():
+ import rec10d
+ tversion=0
+ 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と仮定してアップデート処理を行います。",verbose_level=100)
+ update_db(0)
+ time.sleep(1)
+ else:
+ recdblist.printutf8(u"既存のDBが見つかりました。アップデート処理を行います。",verbose_level=100)
+ tversion=int(rec10d.rec10db.select_version_in_status())
+ while (recdblist.version>tversion):
+ update_db(tversion)
+ tversion=int(rec10d.rec10db.select_version_in_status())
+ else:
+ rec10d.rec10db.drop_in_status()
+ rec10d.rec10db.drop_in_settings()
+ time.sleep(2)
+ rec10d.rec10db.new_in_status()
+ rec10d.rec10db.new_in_settings()
+ rec10d.rec10db.change_version_in_status(recdblist.version)
+def update_db(version):
+ import rec10d
+ if version==0:
+ 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()
\ No newline at end of file
+ move()