3 # Rec10 TS Recording Tools
4 # Copyright (C) 2009-2010 Yukikaze
18 rT=re.compile("(.+)_(\d+)\Z")
20 rT2=re.compile("(.+)_(.+)_(\d*)\Z")#_(aichi)_2010-02-06T01:59:00.mkv
22 rT3=re.compile("(.+)_(.+)_\d+-\d+-\d+T\d+:\d+:\d+\Z")#_(aichi)_2010-02-06T01:59:00.mkv
24 rT4=re.compile("(.+)_(.+)_\d+-\d+-\d+T\d+-\d+-\d+\Z")#_(aichi)_2010-02-06T01-59-00.mkv
26 rT5=re.compile("(.+)_(.+)_(.+)\Z")#_(aichi)_2010-02-06T01-59-00.mkv
40 def search_file(temppath,recpath,ext):
44 avilist = glob.glob(temppath + "/*"+ext)
47 ##b25f is title.ts.b25 avi is title.avi
48 dir = os.path.split(avif)[0]
49 title = os.path.split(avif)[1]
50 title = title.replace(ext, "")
51 avipath = os.path.join(dir, title + ext)
52 if os.path.exists(avipath):
53 dtime = time.time()-os.path.getmtime(avipath)
56 if veryfySize(avipath):
59 def get_move_dest_path(title,temppath,recpath,ext):
60 dstpath=os.path.join(recpath,title+ext)
61 srcpath=os.path.join(temppath,title+ext)
62 if os.path.exists(dstpath):
63 if not os.path.getsize(dstpath) == os.path.getsize(srcpath):
64 gmtime=time.gmtime(os.path.getmtime(srcpath))
67 iff=u"("+configreader.getenv("iff")+u")_"
72 title=title+u"_"+iff+time.strftime("%Y-%m-%dT%H-%M-%S",gmtime)
74 recdblist.printutf8(u"同サイズのファイルが存在します")
77 def get_delpath(temppath,title,addfp=1):
78 delpath=[os.path.join(temppath,title+".ts")]
79 delpath.append(os.path.join(temppath,title+".avi"))
81 delpath.append(os.path.join(temppath,title+".mp4"))
82 delpath.append(os.path.join(temppath,title+".mkv"))
83 delpath.append(os.path.join(temppath,title+".m2v"))
84 delpath.append(os.path.join(temppath,title+".120.avi"))
85 delpath.append(os.path.join(temppath,title+".timecode.txt"))
86 delpath.append(os.path.join(temppath,title+".aac"))
87 delpath.append(os.path.join(temppath,title+".ts.b25"))
88 delpath.append(os.path.join(temppath,title+".ts.tsmix"))
89 delpath.append(os.path.join(temppath,title+".ts.log"))
90 delpath.append(os.path.join(temppath,title+".sa.avi"))
91 delpath.append(os.path.join(temppath,title+".sa.avi.log"))
92 delpath.append(os.path.join(temppath,title+".log"))
95 #vsize=[297,497,596,1196]#SD 30m 1h 1.5h 2h
96 vsize=[245,275,295,591,830]
97 vsize=vsize+[325,449,560,590,602,690,805,860,1014,1138,1237]
98 vsize=vsize+[261,535,540,616,740]#HD 30m 1h
99 #vsize=vsize+[381,895,447]
102 if os.path.getsize(path)>(size-10)*1024*1024 and os.path.getsize(path)<(size+10)*1024*1024:
104 if os.path.getsize(path)>270*1024*1024:
107 def execMove(title,temppath,recpath,ext,autodel):
108 srcpath=os.path.join(temppath,title+ext)
109 sf=guess.searchFolder(title, recpath)
111 destpath=os.path.join(sf,get_move_dest_path(title, temppath, sf, ext)+ext)
112 if os.path.exists(destpath):
113 if os.path.getsize(destpath) == os.path.getsize(srcpath):
114 recdblist.printutf8(u"同名同サイズのファイルが存在します。")
116 recdblist.printutf8(u"関連ファイルを削除します。")
117 delpath=get_delpath(temppath, title)
125 recdblist.printutf8("moving now..")
126 recdblist.printutf8(srcpath+" : "+destpath)
128 shutil.copy(srcpath, destpath)
129 #shutil.copy(srcpath, destpath)
131 delpath=get_delpath(temppath, title)
138 def execDelete(title,temppath):
139 delpath=get_delpath(temppath, title,0)
140 recdblist.printutf8(title+u" 関連の一時ファイルを削除します")
143 if os.path.exists(dp):
144 recdblist.printutf8(dp)
146 except Exception, inst:
149 print traceback.print_exc(file=sys.stdout)