[GRASS-SVN] r46487 - in grass/branches/develbranch_6/gui/wxpython: . gui_modules

svn_grass at osgeo.org svn_grass at osgeo.org
Wed Jun 1 15:44:06 EDT 2011


Author: martinl
Date: 2011-06-01 12:44:06 -0700 (Wed, 01 Jun 2011)
New Revision: 46487

Added:
   grass/branches/develbranch_6/gui/wxpython/gui_modules/gpyshell.py
Modified:
   grass/branches/develbranch_6/gui/wxpython/gui_modules/goutput.py
   grass/branches/develbranch_6/gui/wxpython/wxgui.py
Log:
wxGUI: implement interactive python shell
       (merge r46485 & r46486 from trunk)


Modified: grass/branches/develbranch_6/gui/wxpython/gui_modules/goutput.py
===================================================================
--- grass/branches/develbranch_6/gui/wxpython/gui_modules/goutput.py	2011-06-01 19:42:43 UTC (rev 46486)
+++ grass/branches/develbranch_6/gui/wxpython/gui_modules/goutput.py	2011-06-01 19:44:06 UTC (rev 46487)
@@ -601,10 +601,9 @@
             self.history += '\n'
 
         wildcard = "Text file (*.txt)|*.txt"
-        dlg = wx.FileDialog(
-            self, message=_("Save file as..."), defaultDir=os.getcwd(),
-            defaultFile="grass_cmd_history.txt", wildcard=wildcard,
-            style=wx.SAVE|wx.FD_OVERWRITE_PROMPT)
+        dlg = wx.FileDialog(self, message = _("Save file as..."), defaultDir = os.getcwd(),
+            defaultFile = "grass_cmd_history.txt", wildcard = wildcard,
+            style = wx.SAVE | wx.FD_OVERWRITE_PROMPT)
 
         # Show the dialog and retrieve the user response. If it is the OK response,
         # process the data.

Copied: grass/branches/develbranch_6/gui/wxpython/gui_modules/gpyshell.py (from rev 46485, grass/trunk/gui/wxpython/gui_modules/gpyshell.py)
===================================================================
--- grass/branches/develbranch_6/gui/wxpython/gui_modules/gpyshell.py	                        (rev 0)
+++ grass/branches/develbranch_6/gui/wxpython/gui_modules/gpyshell.py	2011-06-01 19:44:06 UTC (rev 46487)
@@ -0,0 +1,75 @@
+"""!
+ at package gpyshell.py
+
+ at brief wxGUI Interactive Python Shell
+
+Classes:
+ - PyShellWindow
+
+(C) 2011 by the GRASS Development Team
+This program is free software under the GNU General Public
+License (>=v2). Read the file COPYING that comes with GRASS
+for details.
+
+ at author Martin Landa <landa.martin gmail.com>
+"""
+
+import os
+import sys
+
+import wx
+from wx.py.shell import Shell as PyShell
+from wx.py.version import VERSION
+
+import grass.script as grass
+
+class PyShellWindow(wx.Panel):
+    """!Python Shell Window"""
+    def __init__(self, parent, id = wx.ID_ANY, **kwargs):
+        self.parent = parent
+        
+        wx.Panel.__init__(self, parent = parent, id = id, **kwargs)
+        
+        self.intro = _("Welcome to wxGUI Interactive Python Shell %s") % VERSION + "\n\n" + \
+            _("Type %s for more GRASS scripting related information.") % "\"help(grass)\"" + "\n\n"
+        self.shell = PyShell(parent = self, id = wx.ID_ANY,
+                             introText = self.intro, locals = {'grass' : grass})
+        
+        sys.displayhook = self._displayhook
+        
+        self.btnClear = wx.Button(self, wx.ID_CLEAR)
+        self.btnClear.Bind(wx.EVT_BUTTON, self.OnClear)
+        self.btnClear.SetToolTipString(_("Delete all text from the shell"))
+                
+        self._layout()
+        
+    def _displayhook(self, value):
+        print value # do not modify __builtin__._
+        
+    def _layout(self):
+        sizer = wx.BoxSizer(wx.VERTICAL)
+        
+        sizer.Add(item = self.shell, proportion = 1,
+                  flag = wx.EXPAND)
+        
+        btnSizer = wx.BoxSizer(wx.HORIZONTAL)
+        btnSizer.Add(item = self.btnClear, proportion = 0,
+                     flag = wx.EXPAND | wx.RIGHT, border = 5)
+        sizer.Add(item = btnSizer, proportion = 0,
+                  flag = wx.ALIGN_RIGHT | wx.ALL, border = 5)
+        
+        sizer.Fit(self)
+        sizer.SetSizeHints(self)
+        
+        self.SetSizer(sizer)
+        
+        self.Fit()
+        self.SetAutoLayout(True)        
+        self.Layout()
+
+    def OnClear(self, event):
+        """!Delete all text from the shell
+        """
+        self.shell.clear()
+        self.shell.showIntro(self.intro)
+        self.shell.prompt()

Modified: grass/branches/develbranch_6/gui/wxpython/wxgui.py
===================================================================
--- grass/branches/develbranch_6/gui/wxpython/wxgui.py	2011-06-01 19:42:43 UTC (rev 46486)
+++ grass/branches/develbranch_6/gui/wxpython/wxgui.py	2011-06-01 19:44:06 UTC (rev 46487)
@@ -81,10 +81,11 @@
 from gui_modules import gmodeler
 from gui_modules import vclean
 from gui_modules import nviz_tools
-from gui_modules.debug import Debug
-from gui_modules.ghelp import MenuTreeWindow, AboutWindow, InstallExtensionWindow
+from gui_modules.debug    import Debug
+from gui_modules.ghelp    import MenuTreeWindow, AboutWindow, InstallExtensionWindow
 from gui_modules.toolbars import LayerManagerToolbar, ToolsToolbar
-from icons.icon import Icons
+from gui_modules.gpyshell import PyShellWindow
+from icons.icon           import Icons
 
 UserSettings = preferences.globalSettings
 
@@ -220,7 +221,7 @@
             self.notebook = FN.FlatNotebook(parent = self, id = wx.ID_ANY, agwStyle = globalvar.FNPageDStyle)
         else:
             self.notebook = FN.FlatNotebook(parent = self, id = wx.ID_ANY, style = globalvar.FNPageDStyle)
-
+        
         # create displays notebook widget and add it to main notebook page
         cbStyle = globalvar.FNPageStyle
         if globalvar.hasAgw:
@@ -230,7 +231,7 @@
         self.gm_cb.SetTabAreaColour(globalvar.FNPageColor)
         self.notebook.AddPage(self.gm_cb, text = _("Map layers"))
         
-        # create command output text area and add it to main notebook page
+        # create 'command output' text area
         self.goutput = goutput.GMConsole(self, pageid = 1)
         self.notebook.AddPage(self.goutput, text = _("Command console"))
         
@@ -238,10 +239,14 @@
         self.search = MenuTreeWindow(parent = self)
         self.notebook.AddPage(self.search, text = _("Search module"))
         
+        # create 'python shell' notebook page
+        self.pyshell = PyShellWindow(parent = self)
+        self.notebook.AddPage(self.pyshell, text = _("Python shell"))
+        
         # bindings
-        self.gm_cb.Bind(FN.EVT_FLATNOTEBOOK_PAGE_CHANGED, self.OnCBPageChanged)
+        self.gm_cb.Bind(FN.EVT_FLATNOTEBOOK_PAGE_CHANGED,    self.OnCBPageChanged)
         self.notebook.Bind(FN.EVT_FLATNOTEBOOK_PAGE_CHANGED, self.OnPageChanged)
-        self.gm_cb.Bind(FN.EVT_FLATNOTEBOOK_PAGE_CLOSING, self.OnCBPageClosed)
+        self.gm_cb.Bind(FN.EVT_FLATNOTEBOOK_PAGE_CLOSING,    self.OnCBPageClosed)
         
         return self.notebook
 



More information about the grass-commit mailing list