X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/02b800ce7c2bb1c1f08075f22be2e7412124b47f..e5d3d8ad459facd397afef9f1889f932c8a2f474:/wxPython/samples/ide/activegrid/tool/CodeEditor.py diff --git a/wxPython/samples/ide/activegrid/tool/CodeEditor.py b/wxPython/samples/ide/activegrid/tool/CodeEditor.py index 7e245bcd1f..72a5dd2c4f 100644 --- a/wxPython/samples/ide/activegrid/tool/CodeEditor.py +++ b/wxPython/samples/ide/activegrid/tool/CodeEditor.py @@ -19,7 +19,6 @@ import os import re import string import sys -import DebuggerService import MarkerService from UICommon import CaseInsensitiveCompare _ = wx.GetTranslation @@ -120,16 +119,27 @@ class CodeView(STCTextEditor.TextView): return False id = event.GetId() if id == EXPAND_TEXT_ID: - event.Enable(self.GetCtrl().CanLineExpand(self.GetCtrl().GetCurrentLine())) + if self.GetCtrl().GetViewFolding(): + event.Enable(self.GetCtrl().CanLineExpand(self.GetCtrl().GetCurrentLine())) + else: + event.Enable(False) return True elif id == COLLAPSE_TEXT_ID: - event.Enable(self.GetCtrl().CanLineCollapse(self.GetCtrl().GetCurrentLine())) + if self.GetCtrl().GetViewFolding(): + event.Enable(self.GetCtrl().CanLineCollapse(self.GetCtrl().GetCurrentLine())) + else: + event.Enable(False) return True elif (id == EXPAND_TOP_ID or id == COLLAPSE_TOP_ID or id == EXPAND_ALL_ID - or id == COLLAPSE_ALL_ID - or id == AUTO_COMPLETE_ID + or id == COLLAPSE_ALL_ID): + if self.GetCtrl().GetViewFolding(): + event.Enable(self.GetCtrl().GetTextLength() > 0) + else: + event.Enable(False) + return True + elif (id == AUTO_COMPLETE_ID or id == CLEAN_WHITESPACE or id == INDENT_LINES_ID or id == DEDENT_LINES_ID @@ -140,10 +150,12 @@ class CodeView(STCTextEditor.TextView): elif id == CHECK_CODE_ID: event.Enable(False) return True - elif (id == SET_INDENT_WIDTH_ID - or id == FOLDING_ID): + elif id == SET_INDENT_WIDTH_ID: event.Enable(True) return True + elif id == FOLDING_ID: + event.Enable(self.GetCtrl().GetViewFolding()) + return True elif id == USE_TABS_ID: event.Enable(True) event.Check(self.GetCtrl().GetUseTabs()) @@ -210,7 +222,7 @@ class CodeView(STCTextEditor.TextView): filename = document.GetFilename() if filename: rootItem = treeCtrl.AddRoot(os.path.basename(filename)) - treeCtrl.SetDoSelectCallback(rootItem, self, None) + treeCtrl.SetDoSelectCallback(rootItem, self, (0,0)) else: return True @@ -232,11 +244,13 @@ class CodeView(STCTextEditor.TextView): if classLine: indent = classLine.start(0) itemStr = classLine.string[classLine.start(0):classLine.end(0)-1] # don't take the closing ':' + itemStr = itemStr.replace("\n", "").replace("\r", "").replace(",\\", ",").replace(" ", "") # remove line continuations and spaces from outline view else: defLine = defPat.search(line) if defLine: indent = defLine.start(0) itemStr = defLine.string[defLine.start(0):defLine.end(0)] + itemStr = itemStr.replace("\n", "").replace("\r", "").replace(",\\", ",").replace(" ", "") # remove line continuations and spaces from outline view if indent == 0: parentItem = rootItem @@ -467,6 +481,9 @@ class CodeView(STCTextEditor.TextView): def OnUpdate(self, sender = None, hint = None): + if wx.lib.docview.View.OnUpdate(self, sender, hint): + return + if hint == "ViewStuff": self.GetCtrl().SetViewDefaults() elif hint == "Font": @@ -474,6 +491,7 @@ class CodeView(STCTextEditor.TextView): self.GetCtrl().SetFont(font) self.GetCtrl().SetFontColor(color) else: + import DebuggerService dbg_service = wx.GetApp().GetService(DebuggerService.DebuggerService) if dbg_service: dbg_service.SetCurrentBreakpointMarkers(self) @@ -623,7 +641,7 @@ class CodeCtrl(STCTextEditor.TextCtrl): BREAKPOINT_MARKER_MASK = 0x2 - def __init__(self, parent, id=-1, style = wx.NO_FULL_REPAINT_ON_RESIZE): + def __init__(self, parent, id=-1, style = wx.NO_FULL_REPAINT_ON_RESIZE, clearTab=True): STCTextEditor.TextCtrl.__init__(self, parent, id, style) self.UsePopUp(False) @@ -635,7 +653,6 @@ class CodeCtrl(STCTextEditor.TextCtrl): self.SetMarginType(2, wx.stc.STC_MARGIN_SYMBOL) self.SetMarginMask(2, wx.stc.STC_MASK_FOLDERS) self.SetMarginSensitive(2, True) - self.SetMarginWidth(2, 12) self.SetMarginSensitive(1, False) self.SetMarginMask(1, 0x4) @@ -657,7 +674,7 @@ class CodeCtrl(STCTextEditor.TextCtrl): # Define the breakpoint marker self.MarkerDefine(CodeCtrl.BREAKPOINT_MARKER_NUM, wx.stc.STC_MARK_CIRCLE, wx.BLACK, (255,0,0)) - if _WINDOWS: # should test to see if menu item exists, if it does, add this workaround + if _WINDOWS and clearTab: # should test to see if menu item exists, if it does, add this workaround self.CmdKeyClear(wx.stc.STC_KEY_TAB, 0) # menu item "Indent Lines" from CodeService.InstallControls() generates another INDENT_LINES_ID event, so we'll explicitly disable the tab processing in the editor wx.stc.EVT_STC_MARGINCLICK(self, self.GetId(), self.OnMarginClick) @@ -693,7 +710,7 @@ class CodeCtrl(STCTextEditor.TextCtrl): item = wx.MenuItem(menu, TOGGLEBREAKPOINT_ID, _("Toggle Breakpoint")) menu.AppendItem(item) self.Bind(wx.EVT_MENU, self.OnPopToggleMarker, id=TOGGLEMARKER_ID) - item = wx.MenuItem(menu, TOGGLEMARKER_ID, _("Toggle Marker")) + item = wx.MenuItem(menu, TOGGLEMARKER_ID, _("Toggle Bookmark")) menu.AppendItem(item) menu.AppendSeparator() @@ -715,6 +732,7 @@ class CodeCtrl(STCTextEditor.TextCtrl): def OnPopToggleBP(self, event): """ Toggle break point on right click line, not current line """ + import DebuggerService wx.GetApp().GetService(DebuggerService.DebuggerService).OnToggleBreakpoint(event, line=self._rightClickLine) @@ -859,6 +877,7 @@ class CodeCtrl(STCTextEditor.TextCtrl): elif evt.GetMargin() == 0: #This is used to toggle breakpoints via the debugger service. + import DebuggerService db_service = wx.GetApp().GetService(DebuggerService.DebuggerService) if db_service: db_service.OnToggleBreakpoint(evt, line=self.LineFromPosition(evt.GetPosition()))