3 # Rec10 TS Recording Tools
4 # Copyright (C) 2009-2011 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 searchFile(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 getMoveDestpath(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.getConfEnv("iff")+u")_"
72 title=title+u"_"+iff+time.strftime("%Y-%m-%dT%H-%M-%S",gmtime)
74 recdblist.printutf8(u"同サイズのファイルが存在します")
77 def getDelpath(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"))
93 delpath.append(os.path.join(temppath,title+".log.zip"))
96 #vsize=[297,497,596,1196]#SD 30m 1h 1.5h 2h
97 vsize=[245,275,295,591,830]
98 vsize=vsize+[325,449,560,590,602,690,805,860,1014,1138,1237]
99 vsize=vsize+[261,535,540,616,740]#HD 30m 1h
100 #vsize=vsize+[381,895,447]
103 if os.path.getsize(path)>(size-10)*1024*1024 and os.path.getsize(path)<(size+10)*1024*1024:
105 if os.path.getsize(path)>270*1024*1024:
108 def execMove(title,temppath,recpath,ext,autodel):
109 srcpath=os.path.join(temppath,title+ext)
110 # patched. orig: searchFolder(title, recpath)
111 sf=guess.searchFolder(title, recpath,200)
113 destpath=os.path.join(sf,getMoveDestpath(title, temppath, sf, ext)+ext)
114 if os.path.exists(destpath):
115 if os.path.getsize(destpath) == os.path.getsize(srcpath):
116 recdblist.printutf8(u"同名同サイズのファイルが存在します。")
118 recdblist.printutf8(u"関連ファイルを削除します。")
119 delpath=getDelpath(temppath, title)
127 recdblist.printutf8("moving now..")
128 recdblist.printutf8(srcpath+" : "+destpath)
130 shutil.copy(srcpath, destpath)
131 #shutil.copy(srcpath, destpath)
133 delpath=getDelpath(temppath, title)
141 recdblist.printutf8("sf not fonud @ execMove",verbose_level=100)
143 def execDelete(title,temppath):
144 delpath=getDelpath(temppath, title,0)
145 recdblist.printutf8(title+u" 関連の一時ファイルを削除します")
148 if os.path.exists(dp):
149 recdblist.printutf8(dp)
151 except Exception, inst:
154 print traceback.print_exc(file=sys.stdout)