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:
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)
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"))
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 : ")
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" :
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]:")
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()
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"
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")
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)
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()