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()
+ else:
+ # 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()
try:
f = open(path)
self.Clear()
- # Parse first line to get encoding (!! hack, I don't know a better way)
- line = f.readline()
- mo = re.match(r'^<\?xml ([^<>]* )?encoding="(?P<encd>[^<>].*)"\?>', line)
- # Build wx tree
- f.seek(0)
dom = minidom.parse(f)
- # Set encoding global variable and document encoding property
- if mo:
- dom.encoding = g.currentEncoding = mo.group('encd')
- if dom.encoding not in ['ascii', sys.getdefaultencoding()]:
- wxLogWarning('Encoding is different from system default')
- else:
- g.currentEncoding = 'ascii'
- dom.encoding = ''
f.close()
+ # Set encoding global variable
+ g.currentEncoding = dom.encoding
# Change dir
dir = os.path.dirname(path)
if dir: os.chdir(dir)
def Save(self, path):
try:
+ import codecs
# Apply changes
if tree.selection and panel.IsModified():
self.OnRefresh(wxCommandEvent())
- f = open(path, 'w')
+ f = codecs.open(path, 'w', g.currentEncoding)
# Make temporary copy for formatting it
# !!! We can't clone dom node, it works only once
#self.domCopy = tree.dom.cloneNode(True)
self.domCopy = MyDocument()
mainNode = self.domCopy.appendChild(tree.mainNode.cloneNode(True))
self.Indent(mainNode)
- self.domCopy.writexml(f, encoding=tree.rootObj.params['encoding'].value())
+ self.domCopy.writexml(f, encoding = g.currentEncoding)
f.close()
self.domCopy.unlink()
self.domCopy = None
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():