diff options
| author | Guido van Rossum <guido@python.org> | 2007-08-05 15:29:28 +0000 | 
|---|---|---|
| committer | Guido van Rossum <guido@python.org> | 2007-08-05 15:29:28 +0000 | 
| commit | 33d2689fc900a814f0a7d2f846abe0c34024ae17 (patch) | |
| tree | 1ecddf8b9e18933d1fd90d5eda510908ec71695b /Lib/idlelib/PyShell.py | |
| parent | 77553ab531c6a98c3d06b7ba4158b06ed0af8c69 (diff) | |
| download | cpython-git-33d2689fc900a814f0a7d2f846abe0c34024ae17.tar.gz | |
Merged revisions 56492-56752 via svnmerge from
svn+ssh://pythondev@svn.python.org/python/branches/p3yk
........
  r56497 | kurt.kaiser | 2007-07-22 14:55:16 -0700 (Sun, 22 Jul 2007) | 4 lines
  In the case of syntax errors, in py3k format_exception_only()
  was including line number and position in the final line of the
  exception notification, duplicating info in previous lines.
........
  r56501 | kurt.kaiser | 2007-07-22 19:35:50 -0700 (Sun, 22 Jul 2007) | 2 lines
  Hum, needed a newline in the last change.
........
  r56536 | kurt.kaiser | 2007-07-24 19:06:48 -0700 (Tue, 24 Jul 2007) | 5 lines
  Not all instantiations of SyntaxError set the args attribute.
  e.g. symtable.c
  Modify format_exception_only() to get SyntaxError attributes directly
  instead of unpacking 'args'.
........
  r56537 | kurt.kaiser | 2007-07-24 19:13:03 -0700 (Tue, 24 Jul 2007) | 3 lines
  Update doctest strings: traceback.py no longer prints redundant location
  information in the last line of the exception display.
........
  r56627 | kurt.kaiser | 2007-07-29 21:06:57 -0700 (Sun, 29 Jul 2007) | 2 lines
  Interactive interpreter emulator (code.py) failing to print exceptions.
........
  r56628 | kurt.kaiser | 2007-07-29 21:41:02 -0700 (Sun, 29 Jul 2007) | 2 lines
  Eliminate extra lines before and after tracebacks.
........
  r56638 | kurt.kaiser | 2007-07-31 19:36:45 -0700 (Tue, 31 Jul 2007) | 3 lines
  Refactor syntax error display in shell and edit windows; move
  colorize_syntax_error() to EditorWindow; update to py3k.
........
  r56685 | neal.norwitz | 2007-08-02 22:20:23 -0700 (Thu, 02 Aug 2007) | 10 lines
  Remove several h/w and o/s specific modules that are undocumented, obsolete,
  and/or not widely used:
   linuxaudiodev.c, sunaudiodev.c Lib/plat-sunos5/SUNAUDIODEV.py
   Lib/audiodev.py Tools/audiopy/audiopy
  Move Lib/toaiff.py to Demo.
  See PEP 3108 for most of the details.
........
  r56686 | neal.norwitz | 2007-08-02 22:21:48 -0700 (Thu, 02 Aug 2007) | 4 lines
  Missed one module that should have been removed since it relied
  on audiodev which was removed.
........
  r56748 | neal.norwitz | 2007-08-04 19:19:04 -0700 (Sat, 04 Aug 2007) | 1 line
  Make from X import * outside module scope an error.
........
  r56750 | neal.norwitz | 2007-08-04 19:35:01 -0700 (Sat, 04 Aug 2007) | 1 line
  Use READONLY consistently instead of RO
........
Diffstat (limited to 'Lib/idlelib/PyShell.py')
| -rw-r--r-- | Lib/idlelib/PyShell.py | 53 | 
1 files changed, 17 insertions, 36 deletions
| diff --git a/Lib/idlelib/PyShell.py b/Lib/idlelib/PyShell.py index 567994e7b1..70c36fc8a4 100644 --- a/Lib/idlelib/PyShell.py +++ b/Lib/idlelib/PyShell.py @@ -3,7 +3,6 @@  import os  import os.path  import sys -import string  import getopt  import re  import socket @@ -35,7 +34,6 @@ from . import Debugger  from . import RemoteDebugger  from . import macosxSupport -IDENTCHARS = string.ascii_letters + string.digits + "_"  LOCALHOST = '127.0.0.1'  try: @@ -624,47 +622,30 @@ class ModifiedInterpreter(InteractiveInterpreter):              \n""" % (filename,))      def showsyntaxerror(self, filename=None): -        """Extend base class method: Add Colorizing +        """Override Interactive Interpreter method: Use Colorizing          Color the offending position instead of printing it and pointing at it          with a caret.          """ -        text = self.tkconsole.text -        stuff = self.unpackerror() -        if stuff: -            msg, lineno, offset, line = stuff -            if lineno == 1: -                pos = "iomark + %d chars" % (offset-1) -            else: -                pos = "iomark linestart + %d lines + %d chars" % \ -                      (lineno-1, offset-1) -            text.tag_add("ERROR", pos) -            text.see(pos) -            char = text.get(pos) -            if char and char in IDENTCHARS: -                text.tag_add("ERROR", pos + " wordstart", pos) -            self.tkconsole.resetoutput() -            self.write("SyntaxError: %s\n" % str(msg)) -        else: -            self.tkconsole.resetoutput() -            InteractiveInterpreter.showsyntaxerror(self, filename) -        self.tkconsole.showprompt() - -    def unpackerror(self): +        tkconsole = self.tkconsole +        text = tkconsole.text +        text.tag_remove("ERROR", "1.0", "end")          type, value, tb = sys.exc_info() -        ok = type is SyntaxError -        if ok: -            try: -                msg, (dummy_filename, lineno, offset, line) = value -                if not offset: -                    offset = 0 -            except: -                ok = 0 -        if ok: -            return msg, lineno, offset, line +        msg = value.msg or "<no detail available>" +        lineno = value.lineno or 1 +        offset = value.offset or 0 +        if offset == 0: +            lineno += 1 #mark end of offending line +        if lineno == 1: +            pos = "iomark + %d chars" % (offset-1)          else: -            return None +            pos = "iomark linestart + %d lines + %d chars" % \ +                  (lineno-1, offset-1) +        tkconsole.colorize_syntax_error(text, pos) +        tkconsole.resetoutput() +        self.write("SyntaxError: %s\n" % msg) +        tkconsole.showprompt()      def showtraceback(self):          "Extend base class method to reset output properly" | 
