[GRASS-SVN] r38031 - grass/trunk/gui/wxpython/gui_modules

svn_grass at osgeo.org svn_grass at osgeo.org
Tue Jun 23 03:22:02 EDT 2009


Author: martinl
Date: 2009-06-23 03:22:01 -0400 (Tue, 23 Jun 2009)
New Revision: 38031

Modified:
   grass/trunk/gui/wxpython/gui_modules/goutput.py
   grass/trunk/gui/wxpython/gui_modules/prompt.py
Log:
wxGUI history support for the prompt


Modified: grass/trunk/gui/wxpython/gui_modules/goutput.py
===================================================================
--- grass/trunk/gui/wxpython/gui_modules/goutput.py	2009-06-23 06:15:28 UTC (rev 38030)
+++ grass/trunk/gui/wxpython/gui_modules/goutput.py	2009-06-23 07:22:01 UTC (rev 38031)
@@ -29,6 +29,8 @@
 import wx.stc
 from wx.lib.newevent import NewEvent
 
+import grass.script as grass
+
 import globalvar
 import gcmd
 import utils
@@ -308,7 +310,24 @@
             cmdlist = command.strip().split(' ')
         except:
             cmdlist = command
+        
+        # update history file
+        env = grass.gisenv()
+        fileHistory = open(os.path.join(env['GISDBASE'], env['LOCATION_NAME'], env['MAPSET'],
+                                        '.bash_history'), 'a')
+        cmdString = ' '.join(cmdlist)
+        try:
+            fileHistory.write(cmdString + '\n')
+        finally:
+            fileHistory.close()
 
+        # update history items
+        if self.parent.GetName() == 'LayerManager':
+            try:
+                self.parent.cmdinput.SetHistoryItems()
+            except AttributeError:
+                pass
+        
         if cmdlist[0] in globalvar.grassCmd['all']:
             # send GRASS command without arguments to GUI command interface
             # except display commands (they are handled differently)
@@ -388,7 +407,7 @@
                              stderr=self.cmd_stderr)
             except gcmd.CmdError, e:
                 print >> sys.stderr, e
-
+        
         return None
 
     def ClearHistory(self, event):

Modified: grass/trunk/gui/wxpython/gui_modules/prompt.py
===================================================================
--- grass/trunk/gui/wxpython/gui_modules/prompt.py	2009-06-23 06:15:28 UTC (rev 38030)
+++ grass/trunk/gui/wxpython/gui_modules/prompt.py	2009-06-23 07:22:01 UTC (rev 38031)
@@ -19,6 +19,7 @@
 @author Martin Landa <landa.martin gmail.com>
 """
 
+import os
 import sys
 import shlex
 
@@ -218,7 +219,7 @@
         wx.ListCtrl.__init__(self, parent, id, pos, size, style)
         listmix.ListCtrlAutoWidthMixin.__init__(self)
         
-class TextCtrlAutoComplete(wx.TextCtrl, listmix.ColumnSorterMixin):
+class TextCtrlAutoComplete(wx.ComboBox, listmix.ColumnSorterMixin):
     def __init__ (self, parent, statusbar, 
                   id = wx.ID_ANY, choices = [], **kwargs):
         """!Constructor works just like wx.TextCtrl except you can pass in a
@@ -234,7 +235,7 @@
         else:
             kwargs['style'] = wx.TE_PROCESS_ENTER
         
-        wx.TextCtrl.__init__(self, parent, id, **kwargs)
+        wx.ComboBox.__init__(self, parent, id, **kwargs)
 
         # some variables
         self._choices = choices
@@ -269,6 +270,9 @@
         # first search for GRASS module
         self.SetChoices(self._choicesCmd)
 
+        # read history
+        self.SetHistoryItems()
+        
         # bindings...
         self.Bind(wx.EVT_KILL_FOCUS, self.OnControlChanged, self)
         self.Bind(wx.EVT_TEXT, self.OnEnteredText, self)
@@ -279,6 +283,8 @@
         self.dropdownlistbox.Bind(wx.EVT_LEFT_DOWN, self.OnListClick)
         self.dropdownlistbox.Bind(wx.EVT_LEFT_DCLICK, self.OnListDClick)
         self.dropdownlistbox.Bind(wx.EVT_LIST_COL_CLICK, self.OnListColClick)
+
+        self.Bind(wx.EVT_COMBOBOX, self.OnCommandSelect)
         
     def _updateDataList(self, choices):
         """!Update data list"""
@@ -376,6 +382,23 @@
         """!Method required by listmix.ColumnSorterMixin"""
         return self.dropdownlistbox
     
+    def SetHistoryItems(self):
+        """!Read history file and update combobox items"""
+        env = grass.gisenv()
+        fileHistory = open(os.path.join(env['GISDBASE'], env['LOCATION_NAME'], env['MAPSET'],
+                                        '.bash_history'), 'r')
+        try:
+            hist = []
+            for line in fileHistory.readlines():
+                hist.append(line.replace('\n', ''))
+            
+            self.SetItems(hist)
+        finally:
+            fileHistory.close()
+            return
+        
+        self.SetItems([])
+        
     def SetChoices(self, choices, type = 'module'):
         """!Sets the choices available in the popup wx.ListBox.
         The items will be sorted case insensitively.
@@ -403,6 +426,10 @@
         # there is only one choice for both search and fetch if setting a single column:
         self._colSearch = 0
         self._colFetch = -1
+
+    def OnCommandSelect(self, event):
+        """!Command selected from history"""
+        self.SetFocus()
         
     def OnListClick(self, evt):
         """!Left mouse button pressed"""



More information about the grass-commit mailing list