menu = wxMenu()
menu.Append(wxID_NEW, '&New\tCtrl-N', 'New file')
+ menu.AppendSeparator()
menu.Append(wxID_OPEN, '&Open...\tCtrl-O', 'Open XRC file')
+ self.recentMenu = wxMenu()
+ self.AppendRecent(self.recentMenu)
+ menu.AppendMenu(-1, 'Open Recent', self.recentMenu, 'Open a recent file')
+ menu.AppendSeparator()
menu.Append(wxID_SAVE, '&Save\tCtrl-S', 'Save XRC file')
menu.Append(wxID_SAVEAS, 'Save &As...', 'Save XRC file under different name')
menu.AppendSeparator()
menu.Append(wxID_EXIT, '&Quit\tCtrl-Q', 'Exit application')
+
menuBar.Append(menu, '&File')
menu = wxMenu()
EVT_LEFT_DOWN(self, self.OnLeftDown)
EVT_KEY_DOWN(self, tools.OnKeyDown)
EVT_KEY_UP(self, tools.OnKeyUp)
+
+ def AppendRecent(self, menu):
+ # add recently used files to the menu
+ for id,name in conf.recentfiles.iteritems():
+ menu.Append(id,name)
+ EVT_MENU(self,id,self.OnRecentFile)
+ return
+
+ def OnRecentFile(self,evt):
+ # open recently used file
+ if not self.AskSave(): return
+ wxBeginBusyCursor()
+ try:
+ path=conf.recentfiles[evt.GetId()]
+ if self.Open(path):
+ self.SetStatusText('Data loaded')
+ else:
+ self.SetStatusText('Failed')
+ except KeyError:
+ self.SetStatusText('No such file')
+ wxEndBusyCursor()
def OnNew(self, evt):
if not self.AskSave(): return
self.SetStatusText('Data loaded')
else:
self.SetStatusText('Failed')
+ self.SaveRecent(path)
wxEndBusyCursor()
dlg.Destroy()
self.Save(path)
self.dataFile = path
self.SetStatusText('Data saved')
+ self.SaveRecent(path)
except IOError:
self.SetStatusText('Failed')
- wxEndBusyCursor()
+ wxEndBusyCursor()
+
+ def SaveRecent(self,path):
+ # append to recently used files
+ if path not in conf.recentfiles.values():
+ newid = wxNewId()
+ self.recentMenu.Append(newid, path)
+ EVT_MENU(self, newid, self.OnRecentFile)
+ conf.recentfiles[newid] = path
def OnExit(self, evt):
self.Close()
pos = self.GetPosition()
sizePanel = panel.GetSize()
panel.Reparent(self.splitter)
- self.miniFrame.GetSizer().RemoveWindow(panel)
+ self.miniFrame.GetSizer().Remove(panel)
wxYield()
# Widen
self.SetDimensions(pos.x, pos.y, size.width + sizePanel.width, size.height)
def OnCloseWindow(self, evt):
if not self.AskSave(): return
if g.testWin: g.testWin.Destroy()
- # Destroy cached windows
- panel.cacheParent.Destroy()
if not panel.GetPageCount() == 2:
panel.page2.Destroy()
- conf.x, conf.y = self.GetPosition()
- conf.width, conf.height = self.GetSize()
- if conf.embedPanel:
- conf.sashPos = self.splitter.GetSashPosition()
else:
- conf.panelX, conf.panelY = self.miniFrame.GetPosition()
- conf.panelWidth, conf.panelHeight = self.miniFrame.GetSize()
+ # If we don't do this, page does not get destroyed (a bug?)
+ panel.RemovePage(1)
+ if not self.IsIconized():
+ conf.x, conf.y = self.GetPosition()
+ conf.width, conf.height = self.GetSize()
+ if conf.embedPanel:
+ conf.sashPos = self.splitter.GetSashPosition()
+ else:
+ conf.panelX, conf.panelY = self.miniFrame.GetPosition()
+ conf.panelWidth, conf.panelHeight = self.miniFrame.GetSize()
evt.Skip()
def Clear(self):
global debug
# Process comand-line
try:
+ opts = args = None
opts, args = getopt.getopt(sys.argv[1:], 'dhiv')
+ for o,a in opts:
+ if o == '-h':
+ usage()
+ sys.exit(0)
+ elif o == '-d':
+ debug = True
+ elif o == '-v':
+ print 'XRCed version', version
+ sys.exit(0)
+
except getopt.GetoptError:
if wxPlatform != '__WXMAC__': # macs have some extra parameters
print >> sys.stderr, 'Unknown option'
usage()
sys.exit(1)
- for o,a in opts:
- if o == '-h':
- usage()
- sys.exit(0)
- elif o == '-d':
- debug = True
- elif o == '-v':
- print 'XRCed version', version
- sys.exit(0)
self.SetAppName('xrced')
# Settings
conf.embedPanel = conf.ReadInt('embedPanel', True)
conf.showTools = conf.ReadInt('showTools', True)
conf.sashPos = conf.ReadInt('sashPos', 200)
+ # read recently used files
+ recentfiles=conf.Read('recentFiles','')
+ conf.recentfiles={}
+ if recentfiles:
+ for fil in recentfiles.split('|'):
+ conf.recentfiles[wxNewId()]=fil
if not conf.embedPanel:
conf.panelX = conf.ReadInt('panelX', -1)
conf.panelY = conf.ReadInt('panelY', -1)
wc.WriteInt('panelWidth', conf.panelWidth)
wc.WriteInt('panelHeight', conf.panelHeight)
wc.WriteInt('nopanic', True)
+ wc.Write('recentFiles', '|'.join(conf.recentfiles.values()[-5:]))
wc.Flush()
def main():