|
|
(58 intermediate revisions by 8 users not shown) |
Line 1: |
Line 1: |
| | {{TOCright}} |
| | |
| ==Introduction== | | ==Introduction== |
| {{Avdump-gui}} | | {{eyecatch|Note|You have to set an API key in your profile before auto-creqing with Avdump GUI.}} |
|
| |
|
| ==Changelog== | | A simple GUI for [[Avdump2]] is available for CLI skeptics. The GUI package includes the most recent version of Avdump2 as well. |
| <pre>
| | [[File:Avd2gui.png|thumb|Screenshot of the GUI]] |
| v1.05 - 13.11.2007
| | ===Usage=== |
| thx to rar for fixing dumping of files with characters in non local codepage
| | # Download the GUI [https://cdn-eu.anidb.net/client/avdump2-gui/avdump-gui-2.4.2.win32.zip here]. |
| | # Set your AniDB user name and API password in the options menu. |
| | ## API password is set on your user settings page: http://anidb.net/perl-bin/animedb.pl?show=profile |
| | ## Under the "Account" tab, create a UDP API key; it can be anything you want. It is used for Avdump2 to connect to AniDB. |
| | # Save the options. |
| | # Select what you want to scan from the main menu; files or folders. |
| | # Select the stuff you want to scan (... Button) (you can select multiple files at once). |
| | # Click ''Start''. |
|
| |
|
| v1.04 - 10.11.2007
| | For further Assistance join [[IRC:anidb]] and bug [[User:Der Idiot|Der Idiot]].<noinclude>[[Category:Text Module]]</noinclude> |
| fix for not being able to dump files with japanese characters in the filename
| |
| avdump 0.32 added and changes implemented
| |
|
| |
|
| v1.03 - 13.05.2007
| | ===For Vista and Windows 7 permission issues on installation:=== |
| added the console again
| | *Create a blank .bat file. |
| fix for log, export and done pathes with spaces
| | *Insert this text into it and modify it to your situation:<br> <tt>"C:\Windows\System32\msiExec.exe" -i "C:\Directory\Where\Located\avdump-gui.msi"</tt> |
| added parents for the dialogs so they die with the program and can't stay open anymore
| | *Right click and run the .bat file as administrator. |
| option 9 added (experimental mp3 hashing for ostdb)
| |
|
| |
| v1.02 - 13.05.2007
| |
| added error and warning dialog boxes to prevent a couple problems
| |
| added some exceptionhandling for a few fields
| |
|
| |
| v1.01 - 12.05.2007
| |
| killed a nasty bug with trailing \ in the scanpath | |
|
| |
| v1.00 - 12.05.2007
| |
| Initial release
| |
| </pre> | |
|
| |
|
| ==Source==
| |
| This gui was coded purely in python using wxpython for the framework.
| |
|
| |
|
| <pre style="font-size: 60%;"> | | ==Changelog== |
| import wx,os,subprocessw,sys
| | <pre> |
| | v2.42 - 08.01.2019 *available as auto update* |
| | * Avdump2 Build 7080 added |
|
| |
|
| class mainFrame(wx.Frame):
| | v2.41 - 05.01.2019 *available as auto update* |
| __simple = ['p','z','r','m','c','o','9']
| | * show error message about too long paths |
| __options = {'avdump':'avdump.exe','user':'','pass':'','ext':'','misc':'','bsize':'2048:1','port':'','tout':'30','retries':'6','exp':'export.txt','log':'log.txt','done':'done.txt'}
| | * fallback to cp437 in case shell encoding fails which i guess should work? |
| __configfile='config.ini'
| |
|
| |
|
| def read_config(self,newconfig=''):
| | v2.40 - 03.01.2019 *available as auto update* |
| '''read the config file and return the content'''
| | * Avdump2 Build 7070 added |
| if not os.path.exists(self.__configfile):
| | * show errors in filelist if we encounter one while processing a file instead of endless retrying |
| for elem in self.__options:
| |
| newconfig += ('%s=%s\n') %(elem,self.__options[elem])
| |
| file(self.__configfile,"w").write(newconfig)
| |
| for line in file(self.__configfile,"r").readlines():
| |
| if not line.endswith('='):
| |
| temp,val = line.rstrip('\n').split('=',1)
| |
| else:
| |
| val = ''
| |
| for elem in self.__options:
| |
| if temp == elem:
| |
| self.__options[temp] = val
| |
|
| |
|
| def __init__(self, parent, title):
| | v2.33 - 09.11.2016 *available as auto update* |
| wx.Frame.__init__(self, parent, -1, u'Avdump GUI', wx.DefaultPosition, (350, 140), style=wx.CLOSE_BOX | wx.SYSTEM_MENU | wx.CAPTION | 0 | 0 | wx.MINIMIZE_BOX)
| | * new icon |
| self.panel = wx.Panel(self, -1)
| | * progressbar and status not updating |
| self.filepath = wx.TextCtrl(self.panel, -1, '', (95, 25), size=(190, 24))
| |
| self.start = wx.Button(self.panel, -1, 'Start', (90,75), (-1, -1))
| |
| self.options = wx.Button(self.panel, -1, 'Options', (185,75), (-1, -1))
| |
| self.select = wx.Button(self.panel, -1, '...', (295, 25), (25, -1))
| |
| self.scantype = wx.RadioBox(self.panel,-1,pos=(5,5),size=(-1, 59),style=wx.RA_VERTICAL,label='scantype',choices = ['Files','Folder'])
| |
| self.Bind(wx.EVT_BUTTON, self.selectClick, self.select)
| |
| self.Bind(wx.EVT_BUTTON, self.optionsClick, self.options)
| |
| self.Bind(wx.EVT_BUTTON, self.startClick, self.start)
| |
| self.child = OptionsFrame(self, 'App')
| |
|
| |
|
| def selectClick(self, event,path=''):
| | v2.32 - 09.11.2016 *available as auto update* |
| if self.scantype.GetStringSelection() == 'Files':
| | * options not being stored on initial start |
| dialog = wx.FileDialog ( self, message = 'Pick a directory.', style= wx.FD_MULTIPLE)
| |
| if dialog.ShowModal() == wx.ID_OK:
| |
| temp = dialog.GetPaths()
| |
| if len(temp)>1:
| |
| for elem in temp:
| |
| path += '"' + elem + '" '
| |
| else:
| |
| path = '"' + temp[0].rstrip("\\") + '"'
| |
| else:
| |
| dialog = wx.DirDialog ( self, message = 'Pick a directory.' )
| |
| if dialog.ShowModal() == wx.ID_OK:
| |
| path = '"' + dialog.GetPath().rstrip("\\") + '"'
| |
| self.filepath.Clear()
| |
| dialog.Destroy()
| |
| self.filepath.write(path)
| |
| self.__options['scanpath'] = path
| |
|
| |
|
| def startClick(self, event):
| | v2.31 - 09.11.2016 *available as auto update* |
| self.read_config()
| | * fixed drag and drop |
| self.__options['param'] = ''
| |
| if self.filepath.GetValue() == '':
| |
| self.child.error('You have to select some files or folder to scan!')
| |
| elif (self.__options['user'] == '' or self.__options['pass'] == ''):
| |
| self.child.error("You didn't enter your username and/or password in the options menu.")
| |
| elif self.__options['avdump'] == '':
| |
| self.child.error('You must specify the path to avdump.exe!')
| |
| elif self.__options['avdump'] == 'avdump.exe':
| |
| self.child.info('You should set the _absolute_ path to avdump.exe.\nOtherwise complications might arise.')
| |
| else:
| |
| if self.__options['misc'].lstrip(',') > 0:
| |
| for elem in self.__options['misc'].split(','):
| |
| if elem not in ['retries','']:
| |
| if elem in self.__simple:
| |
| self.__options['param'] += ' -' + elem
| |
| elif elem == 'tout':
| |
| self.__options['param'] += ' -' + elem + ':' + self.__options[elem] + ':' + self.__options['retries']
| |
| else:
| |
| self.__options['param'] += ' -' + elem + ':' + self.__options[elem]
| |
| '''debug option to see what avdump actually get's fed'''
| |
| #self.child.info(('%s%s -ac:%s:%s %s') %(self.__options['avdump'], self.__options['param'], self.__options['user'], self.__options['pass'], self.__options['scanpath']))
| |
| arg = (u'%s%s -ac:%s:%s %s') %(self.__options['avdump'], self.__options['param'], self.__options['user'], self.__options['pass'], self.__options['scanpath'])
| |
| subprocessw.Popen(arg)
| |
|
| |
|
| def optionsClick(self, event):
| | v2.30 - 03.11.2016 *available as auto update* |
| self.child.refresh()
| | * ported from python 2.7 to 3.4 |
| self.child.Show(True)
| | * path/filename encoding woes fixed(?) |
| | * export option removed and made implicit to be always enabled |
|
| |
|
| class OptionsFrame(wx.Frame):
| | v2.20 - 18.08.2015 *available as auto update* |
| __box = {'ext':False,'log':False,'exp':False,'port':False,'done':False,'bsize':False,'tout':False,'c':False,'m':False,'p':False,'r':False,'z':False,'o':False,'9':False}
| | * Avdump2 Build 6714 added |
| __options = {'avdump':'avdump.exe','user':'','pass':'','ext':'','misc':'','bsize':'2048:1','port':'','tout':'30','retries':'6','exp':'export.txt','log':'log.txt','done':'done.txt'}
| | * dependencies updated |
| __configfile='config.ini'
| |
|
| |
|
| def read_config(self):
| | v2.19 - 11.11.2012 *available as msi installer & auto update* |
| '''read the config file and return the content'''
| | * Avdump2 Build 6525 added |
| if not os.path.exists(self.__configfile):
| | * recompiled with updated dependencies which may or may not fix some issues or cause new ones |
| self.write_config()
| |
| for line in file(self.__configfile,"r").readlines():
| |
| if not line.endswith('='):
| |
| temp,val = line.rstrip('\n').split('=',1)
| |
| else:
| |
| val = ''
| |
| for elem in self.__options:
| |
| if temp == elem:
| |
| self.__options[temp] = val
| |
|
| |
|
| def write_config(self,newconfig=''):
| | v2.18 - 31.07.2012 *available as auto update* |
| for elem in self.__options:
| | * Avdump2 Build 5290 added |
| newconfig += ('%s=%s\n') %(elem,self.__options[elem])
| |
| file(self.__configfile,"w").write(newconfig)
| |
|
| |
|
| def set_misc(self,misc=''):
| | v2.17 - 21.09.2011 *available as auto update* |
| for elem in self.__box:
| | * filename encoding issue fixed |
| if self.__box[elem] is True:
| |
| misc += elem + ','
| |
| self.__options['misc'] = misc
| |
|
| |
|
| def get_checkboxes(self,misc):
| | v2.15 - 13.09.2011 |
| if misc is not None:
| | * Avdump2 Build 5028 added |
| misc = misc.rstrip(',').lstrip(',')
| | * text fix (Optionen instead of Options. watch out for da evil germanz ja) |
| if misc.find(',') > 0:
| | * can now drop files into the table to process |
| for elem in misc.split(','):
| | * speed improvement when adding lots of files at once (really only noticeable > 500) |
| self.__box[elem] = True
| | * potentially fixing some issue with the last filehash not being shown in the export box |
| else:
| |
| self.__box[misc] = True
| |
|
| |
|
| def __init__(self, parent, title):
| | v2.14 - 11.09.2011 |
| wx.Frame.__init__(self, parent, -1, 'options', wx.DefaultPosition, (301, 691), style=wx.CLOSE_BOX | wx.SYSTEM_MENU | wx.CAPTION | 0 | 0 | wx.MINIMIZE_BOX)
| | * Avdump2 Build 5000 added |
| self.panel = wx.Panel(self, -1)
| |
| self.adoptions = wx.StaticBox(self.panel, -1, "advanced options", (5,170), (275, 290))
| |
| self.groupbox3 = wx.StaticBox(self.panel, -1, "Path to Avdump", (5,0), (275, 55))
| |
| self.groupbox4 = wx.StaticBox(self.panel, -1, "UDP API Username/Password", (5,55), (275, 115))
| |
| self.groupbox5 = wx.StaticBox(self.panel, -1, "logs", (5,460), (275, 170))
| |
| self.filepath = wx.TextCtrl(self.panel, -1, '', (15,20), size=(220, 25))
| |
| self.selectavdump = wx.Button(self.panel, -1, '...', (245,20), (25, 25))
| |
| self.username = wx.TextCtrl(self.panel, -1, '', (15,90), size=(255, 25))
| |
| self.password = wx.TextCtrl(self.panel, -1, '', (15,135), size=(255, 25))
| |
| self.delete = wx.CheckBox(self.panel, -1, 'delete files after parsing', (15,190), (240, 17))
| |
| self.recursive = wx.CheckBox(self.panel, -1, 'do _not_ recurse into subfolders', (15,205), (240, 17))
| |
| self.monitor = wx.CheckBox(self.panel, -1, 'Monitor folder(s)', (15,220), (240, 17))
| |
| self.mp3 = wx.CheckBox(self.panel, -1, 'ostdb mp3 test (experimental)', (15,235), (240, 17))
| |
| self.bsize = wx.CheckBox(self.panel, -1, 'overwrite the default setting for buffersize', (15,250), (240, 17))
| |
| self.ext = wx.CheckBox(self.panel, -1, 'overwrite the default setting for extentions', (15,265), (240, 17))
| |
| self.port = wx.CheckBox(self.panel, -1, 'overwrite the default setting for port', (15,280), (240, 17))
| |
| self.tout = wx.CheckBox(self.panel, -1, 'overwrite the default setting for timeouts', (15,295), (240, 17))
| |
| self.pause = wx.CheckBox(self.panel, -1, 'Pause when done (hold cmd window)', (15,310), (240, 17))
| |
| self.random = wx.CheckBox(self.panel, -1, 'Random file order', (15,325), (240, 17))
| |
| self.wait = wx.CheckBox(self.panel, -1, 'wait for response when sending dumps', (15,340), (240, 17))
| |
| self.extention = wx.TextCtrl(self.panel, -1, '', (15,375), size=(255, 25))
| |
| self.buffersize = wx.TextCtrl(self.panel, -1, '', (15,420), size=(55, 25))
| |
| self.portnumber = wx.TextCtrl(self.panel, -1, '', (81,420), size=(55, 25))
| |
| self.timeout = wx.TextCtrl(self.panel, -1, '', (149,420), size=(55, 25))
| |
| self.retries = wx.TextCtrl(self.panel, -1, '', (215,420), size=(55, 25))
| |
| self.exp = wx.CheckBox(self.panel, -1, '', (15,493), (17, 17))
| |
| self.exppath = wx.TextCtrl(self.panel, -1, '', (35,490), size=(200, 25))
| |
| self.selectexp = wx.Button(self.panel, -1, '...', (245,490), (25, 23))
| |
| self.done = wx.CheckBox(self.panel, -1, '', (15,553), (17, 17))
| |
| self.donepath = wx.TextCtrl(self.panel, -1, '', (35,550), size=(200, 25))
| |
| self.selectdone = wx.Button(self.panel, -1, '...', (245,550), (25, 23))
| |
| self.log = wx.CheckBox(self.panel, -1, '', (15,598), (17, 17))
| |
| self.logpath = wx.TextCtrl(self.panel, -1, '', (35,595), size=(200, 25))
| |
| self.selectlog = wx.Button(self.panel, -1, '...', (245,595), (25, 23))
| |
| self.save = wx.Button(self.panel, -1, 'Save', (65,635), (75, 23))
| |
| self.cancel = wx.Button(self.panel, -1, 'Cancel', (150,635), (75, 23))
| |
| self.Retries = wx.StaticText(self.panel, -1, 'Retries:', (220,402), (44, 17))
| |
| self.Timeout = wx.StaticText(self.panel, -1, 'Timeout:', (152,402), (50, 17))
| |
| self.Buffersize = wx.StaticText(self.panel, -1, 'Buffersize:', (16,402), (60, 17))
| |
| self.Port = wx.StaticText(self.panel, -1, 'Port:', (86,402), (44, 17))
| |
| self.donelog = wx.StaticText(self.panel, -1, 'save processed-file-paths to file and exlude existing from proc', (40,520), (200, 25))
| |
| self.exported2k = wx.StaticText(self.panel, -1, 'export ed2k-links to file', (40,472), (150, 17))
| |
| self.writelog = wx.StaticText(self.panel, -1, 'write output to log', (40,578), (150, 17))
| |
| self.apiuser = wx.StaticText(self.panel, -1, 'Username:', (20,73), (150, 17))
| |
| self.apipass = wx.StaticText(self.panel, -1, 'Password:', (20,118), (150, 17))
| |
| self.extentionlist = wx.StaticText(self.panel, -1, 'comma seperated extension list', (20,358), (170, 17))
| |
| self.Bind(wx.EVT_BUTTON, self.selectavdClick, self.selectavdump)
| |
| self.Bind(wx.EVT_BUTTON, self.selectlogClick, self.selectlog)
| |
| self.Bind(wx.EVT_BUTTON, self.selectexpClick, self.selectexp)
| |
| self.Bind(wx.EVT_BUTTON, self.selectdoneClick, self.selectdone)
| |
| self.Bind(wx.EVT_BUTTON, self.saveClick, self.save)
| |
| self.Bind(wx.EVT_BUTTON, self.cancelClick, self.cancel)
| |
| self.Bind(wx.EVT_CLOSE, self.onclose)
| |
| self.refresh()
| |
|
| |
|
| def selectavdClick(self, event):
| | v2.13 - 06.09.2011 |
| dialog = wx.FileDialog ( self, message = 'Pick a directory.')
| | * Avdump2 Build 4991 added |
| if dialog.ShowModal() == wx.ID_OK:
| | * fixes to be compatible to the new Avdump2 CLI |
| self.filepath.Clear()
| |
| self.filepath.write(dialog.GetPath().rstrip("\\"))
| |
|
| |
|
| def selectlogClick(self, event):
| | v2.12 - 05.09.2011 *pulled* |
| dialog = wx.FileDialog ( self, message = 'Pick a directory.')
| | * Avdump2 Build 4964 added |
| if dialog.ShowModal() == wx.ID_OK:
| |
| self.logpath.Clear()
| |
| self.logpath.write(dialog.GetPath().rstrip("\\"))
| |
|
| |
|
| def selectexpClick(self, event):
| | v2.11 - 01.07.2011 |
| dialog = wx.FileDialog ( self, message = 'Pick a directory.')
| | * trying to scan files without having provided a username/password -> BOOM (trying to kill the subprocess without it running) |
| if dialog.ShowModal() == wx.ID_OK:
| | * removing already scanned files form the list and readding them will process them again even if "done" is set |
| self.exppath.Clear()
| | (from frontend at least. avdump itself would ignore them. this would leave a couple "new" entries in the list) |
| self.exppath.write(dialog.GetPath().rstrip("\\"))
| |
|
| |
|
| def selectdoneClick(self, event):
| | v2.10 - 01.07.2011 |
| dialog = wx.FileDialog ( self, message = 'Pick a directory.')
| | * Avdump2 Build 4334 added |
| if dialog.ShowModal() == wx.ID_OK:
| | * Autoupdater implemented |
| self.donepath.Clear()
| | * last scanned dir stored in config |
| self.donepath.write(dialog.GetPath().rstrip("\\"))
| | * window size stored in config (unless it's maximized) |
| | * use stderr to catch errors instead of stdout |
| | * lots of rewriting |
|
| |
|
| def saveClick(self,event):
| | v2.02 - 09.06.2011 |
| self.update()
| | * Avdump2 Build 4320 added |
| if self.__options['avdump'] == '':
| | * ditched subprocess module in favour of qprocess |
| self.error('You must specify the path to avdump.exe!')
| | * peek into console output and notice the user when an error happened (outdated version or wrong password/username) |
| elif self.__options['avdump'] == 'avdump.exe':
| |
| self.info('You should set the _absolute_ path to avdump.exe.\nOtherwise complications might arise.')
| |
| else:
| |
| self.Show(False)
| |
|
| |
|
| def cancelClick(self,event):
| | v2.01 - 06.06.2011 |
| self.refresh()
| | * various nasty bugs removed |
| self.Show(False)
| | * windows can be enlarged on demand |
|
| |
|
| def onclose(self,event):
| | v2.00 - 03.06.2011 |
| self.Show(False)
| | * Avdump2 Build 4260 added |
| | * rewrote the whole lot and simplified it |
|
| |
|
| def refresh(self):
| | v1.07 - 06.04.2008 |
| self.read_config()
| | * Avdump 0.34 added |
| self.get_checkboxes(self.__options['misc'])
| | * fixed a bug with the bufferfield not allowing 16 buffer while that being the default |
| self.filepath.Clear()
| | * made option o default when no profile exists |
| self.filepath.write(self.__options['avdump'].rstrip('"').lstrip('"'))
| |
| self.username.Clear()
| |
| self.username.write(self.__options['user'])
| |
| self.password.Clear()
| |
| self.password.write(self.__options['pass'])
| |
| self.extention.Clear()
| |
| self.extention.write(self.__options['ext'])
| |
| self.buffersize.Clear()
| |
| self.buffersize.write(self.__options['bsize'])
| |
| self.portnumber.Clear()
| |
| self.portnumber.write(self.__options['port'])
| |
| self.timeout.Clear()
| |
| self.timeout.write(self.__options['tout'])
| |
| self.retries.Clear()
| |
| self.retries.write(self.__options['retries'])
| |
| self.exppath.Clear()
| |
| self.exppath.write(self.__options['exp'].rstrip('"').lstrip('"'))
| |
| self.logpath.Clear()
| |
| self.logpath.write(self.__options['log'].rstrip('"').lstrip('"'))
| |
| self.donepath.Clear()
| |
| self.donepath.write(self.__options['done'].rstrip('"').lstrip('"'))
| |
| self.ext.SetValue(self.__box['ext'])
| |
| self.log.SetValue(self.__box['log'])
| |
| self.exp.SetValue(self.__box['exp'])
| |
| self.port.SetValue(self.__box['port'])
| |
| self.done.SetValue(self.__box['done'])
| |
| self.bsize.SetValue(self.__box['bsize'])
| |
| self.tout.SetValue(self.__box['tout'])
| |
| self.recursive.SetValue(self.__box['c'])
| |
| self.monitor.SetValue(self.__box['m'])
| |
| self.mp3.SetValue(self.__box['9'])
| |
| self.pause.SetValue(self.__box['p'])
| |
| self.random.SetValue(self.__box['r'])
| |
| self.delete.SetValue(self.__box['z'])
| |
| self.wait.SetValue(self.__box['o'])
| |
|
| |
|
| def update(self):
| | v1.06 - 12.02.2008 |
| self.__options['avdump'] = '"' + self.filepath.GetValue() + '"'
| | * Avdump 0.33 added |
| self.__options['user'] = self.username.GetValue()
| |
| self.__options['pass'] = self.password.GetValue()
| |
| self.__options['ext'] = self.extention.GetValue()
| |
| try:
| |
| temp,temp2 = self.buffersize.GetValue().split(":")
| |
| temp = int(temp)
| |
| temp2 = int(temp2)
| |
| '''make sure it's mod 8 and at least 256kb'''
| |
| if temp < 256:
| |
| temp = 256
| |
| if not temp % 8:
| |
| temp = temp - (temp%8)
| |
| '''make sure the buffernumber is between 1 and 8'''
| |
| if temp2 > 8 or temp2 <1:
| |
| temp2 = 1
| |
| temp = ("%s:%s") %(temp, temp2)
| |
| except:
| |
| temp = "2048:1"
| |
| self.__options['bsize'] = unicode(temp)
| |
| try:
| |
| int(self.portnumber.GetValue())
| |
| self.__options['port'] = self.portnumber.GetValue()
| |
| except:
| |
| self.__options['port'] = ''
| |
| self.__options['tout'] = self.timeout.GetValue()
| |
| temp = int(self.timeout.GetValue())
| |
| '''make sure it's at least 20'''
| |
| try:
| |
| if int(temp) < 20:
| |
| temp = 20
| |
| except:
| |
| temp = 30
| |
| self.__options['tout'] = unicode(temp)
| |
| try:
| |
| int(self.retries.GetValue())
| |
| self.__options['retries'] = self.retries.GetValue()
| |
| except:
| |
| self.__options['retries'] = 6
| |
| self.__options['exp'] = '"' + self.exppath.GetValue() + '"'
| |
| self.__options['log'] = '"' + self.logpath.GetValue() + '"'
| |
| self.__options['done'] = '"' + self.donepath.GetValue() + '"'
| |
| self.__box['ext'] = self.ext.GetValue()
| |
| self.__box['log'] = self.log.GetValue()
| |
| self.__box['exp'] = self.exp.GetValue()
| |
| self.__box['port'] = self.port.GetValue()
| |
| self.__box['done'] = self.done.GetValue()
| |
| self.__box['bsize'] = self.bsize.GetValue()
| |
| self.__box['tout'] = self.tout.GetValue()
| |
| self.__box['c'] = self.recursive.GetValue()
| |
| self.__box['m'] = self.monitor.GetValue()
| |
| self.__box['9'] = self.mp3.GetValue()
| |
| self.__box['p'] = self.pause.GetValue()
| |
| self.__box['r'] = self.random.GetValue()
| |
| self.__box['z'] = self.delete.GetValue()
| |
| self.__box['o'] = self.wait.GetValue()
| |
| self.set_misc()
| |
| self.write_config()
| |
|
| |
|
| def error(self,text):
| | v1.05 - 13.11.2007 |
| message = wx.MessageDialog(self,text,style=wx.ICON_ERROR | wx.OK)
| | * thx to rar for fixing dumping of files with characters in non local codepage |
| message.ShowModal()
| |
|
| |
|
| def info(self,text):
| | v1.04 - 10.11.2007 |
| message = wx.MessageDialog(self,text,style=wx.ICON_INFORMATION | wx.OK)
| | * fix for not being able to dump files with Japanese characters in the filename |
| message.ShowModal()
| | * Avdump 0.32 added and changes implemented |
|
| |
| class App(wx.App):
| |
| def OnInit(self):
| |
| frame = mainFrame(None, 'App')
| |
| frame.Show(True)
| |
| self.SetTopWindow(frame)
| |
| return True
| |
|
| |
|
| if __name__ == '__main__':
| | v1.03 - 13.05.2007 |
| app = App(True)
| | * added the console again |
| app.MainLoop()
| | * fix for log, export and done paths with spaces |
| </pre>
| | * added parents for the dialogues so they die with the program and can't stay open any more |
| | | * option 9 added (experimental mp3 hashing for ostdb) |
| ===wrapper module for subprocess by rar===
| | |
| <pre style="font-size: 60%;">
| | v1.02 - 13.05.2007 |
| import subprocess
| | * added error and warning dialogue boxes to prevent a couple problems |
| from subprocess import call, PIPE, STDOUT, list2cmdline, mswindows
| | * added some exception handling for a few fields |
| import ctypes
| | |
| import ctypes.wintypes
| | v1.01 - 12.05.2007 |
| CreateProcessW = ctypes.windll.kernel32.CreateProcessW
| | * killed a nasty bug with trailing \ in the scanpath |
| CloseHandle = ctypes.windll.kernel32.CloseHandle
| | |
| | | v1.00 - 12.05.2007 |
| __all__ = ["Popen", "PIPE", "STDOUT", "call"]
| | * Initial release |
| | |
| class STARTUPINFOW(ctypes.Structure):
| |
| _fields_ = (("cb", ctypes.wintypes.DWORD), # should init to 17*4 maybe?
| |
| ("lpReserved", ctypes.wintypes.LPWSTR),
| |
| ("lpDesktop", ctypes.wintypes.LPWSTR),
| |
| ("lpTitle", ctypes.wintypes.LPWSTR),
| |
| ("dwX", ctypes.wintypes.DWORD),
| |
| ("dwY", ctypes.wintypes.DWORD),
| |
| ("dwXSize", ctypes.wintypes.DWORD),
| |
| ("dwYSize", ctypes.wintypes.DWORD),
| |
| ("dwXCountChars", ctypes.wintypes.DWORD),
| |
| ("dwYCountChars", ctypes.wintypes.DWORD),
| |
| ("dwFillAttribute", ctypes.wintypes.DWORD),
| |
| ("dwFlags", ctypes.wintypes.DWORD),
| |
| ("wShowWindow", ctypes.wintypes.WORD),
| |
| ("cbReserved2", ctypes.wintypes.WORD),
| |
| ("lpReserved2", ctypes.wintypes.LPSTR), # actually LPBYTE
| |
| ("hStdInput", ctypes.wintypes.HANDLE),
| |
| ("hStdOutput", ctypes.wintypes.HANDLE),
| |
| ("hStdError", ctypes.wintypes.HANDLE))
| |
| | |
| class PROCESS_INFORMATION(ctypes.Structure):
| |
| _fields_ = (("hProcess", ctypes.wintypes.HANDLE),
| |
| ("hThread", ctypes.wintypes.HANDLE),
| |
| ("dwProcessId", ctypes.wintypes.DWORD),
| |
| ("dwThreadId", ctypes.wintypes.DWORD))
| |
| | |
| if mswindows:
| |
| class Popen(subprocess.Popen):
| |
| def _execute_child(self, args, executable, preexec_fn, close_fds,
| |
| cwd, env, universal_newlines,
| |
| startupinfo, creationflags, shell,
| |
| p2cread, p2cwrite,
| |
| c2pread, c2pwrite,
| |
| errread, errwrite):
| |
| | |
| if not isinstance(args, basestring):
| |
| args = list2cmdline(args)
| |
|
| |
| if not isinstance(args, unicode):
| |
| subprocess.Popen._execute_child(self, args, executable,
| |
| preexec_fn, close_fds, cwd, env, universal_newlines,
| |
| startupinfo, creationflags, shell, p2cread, p2cwrite,
| |
| c2pread, c2pwrite, errread, errwrite)
| |
| return
| |
| | |
| if startupinfo == None:
| |
| startupinfo = STARTUPINFOW()
| |
| else:
| |
| raise NotImplementedError("Can't pass startup stuff")
| |
|
| |
| if not None in (p2cread, c2pwrite, errwrite):
| |
| raise NotImplementedError("Can't pass file object bits")
| |
| | |
| if shell:
| |
| raise NotImplementedError("Can't pick your own shell for unicode args")
| |
|
| |
| margs = ctypes.create_unicode_buffer(args)
| |
| processinfo = PROCESS_INFORMATION()
| |
| | |
| CreateProcessW(executable, margs,
| |
| None, None,
| |
| 1,
| |
| creationflags,
| |
| env, cwd,
| |
| ctypes.byref(startupinfo), ctypes.byref(processinfo))
| |
|
| |
| hp, ht, pid, tid = (processinfo.hProcess, processinfo.hThread,
| |
| processinfo.dwProcessId, processinfo.dwThreadId)
| |
|
| |
| # can't wrap this as a _subprocess_handle so scuppered, need sp_handle_new()
| |
| self._handle = hp
| |
| self.pid = pid
| |
| CloseHandle(ht) # ht.Close()
| |
| else:
| |
| Popen = subprocess.Popen
| |
| </pre> | | </pre> |
|
| |
|
| | [[Category:Features]] |
| | [[Category:AniDB Clients]] |
| [[Category:Avdump]] | | [[Category:Avdump]] |
| | [[Category:Development]] |