diff options
author | Jeremy Hylton <jeremy@alum.mit.edu> | 2000-03-03 23:06:45 (GMT) |
---|---|---|
committer | Jeremy Hylton <jeremy@alum.mit.edu> | 2000-03-03 23:06:45 (GMT) |
commit | e81f28b630a7192207b9ac9a6813c8d29f1bed6c (patch) | |
tree | 470d5306ede24a1819eefb1fff1fb3abae7446f3 /Tools/idle/ParenMatch.py | |
parent | 583abb80277d6ab5c8ad887477c12a3139e6f5f9 (diff) | |
download | cpython-e81f28b630a7192207b9ac9a6813c8d29f1bed6c.zip cpython-e81f28b630a7192207b9ac9a6813c8d29f1bed6c.tar.gz cpython-e81f28b630a7192207b9ac9a6813c8d29f1bed6c.tar.bz2 |
migrate to use of IdleConf and config files to set options
idle.py:
Load the config files before anything else happens
XXX Need to define standard way to get files relative to the
IDLE install dir
PyShell.py:
ColorDelegator.py:
Get color defns out of IdleConf instead of IdlePrefs
EditorWindow.py:
Replace hard-coded font & window size with config options
Get extension names via IdleConf.getextensions
extend.py:
Obsolete. Extensions defined in config file.
ParenMatch.py:
Use config file for extension options.
Revise comment about parser requirements.
Simplify logic on find returning None.
Diffstat (limited to 'Tools/idle/ParenMatch.py')
-rw-r--r-- | Tools/idle/ParenMatch.py | 23 |
1 files changed, 11 insertions, 12 deletions
diff --git a/Tools/idle/ParenMatch.py b/Tools/idle/ParenMatch.py index 7500603..d8482b9 100644 --- a/Tools/idle/ParenMatch.py +++ b/Tools/idle/ParenMatch.py @@ -14,6 +14,7 @@ import string import PyParse from AutoIndent import AutoIndent, index2line +from IdleConf import IdleConf class ParenMatch: """Highlight matching parentheses @@ -55,12 +56,12 @@ class ParenMatch: windows_keydefs = {} unix_keydefs = {} - STYLE = "default" # or "expression" - FLASH_DELAY = 500 - HILITE_CONFIG = {"foreground": "black", - "background": "#43cd80", # SeaGreen3 - } - BELL = 1 # set to false for no bell + iconf = IdleConf.getsection('ParenMatch') + STYLE = iconf.get('style') + FLASH_DELAY = iconf.getint('flash-delay') + HILITE_CONFIG = iconf.getcolor('hilite') + BELL = iconf.getboolean('bell') + del iconf def __init__(self, editwin): self.editwin = editwin @@ -156,9 +157,8 @@ class LastOpenBracketFinder: startat = max(lno - context, 1) startatindex = `startat` + ".0" # rawtext needs to contain everything up to the last - # character, which was the close paren. also need to - # append "\n" to please the parser, which seems to expect - # a complete line + # character, which was the close paren. the parser also + # requires that the last line ends with "\n" rawtext = self.text.get(startatindex, "insert")[:-1] + "\n" y.set_str(rawtext) bod = y.find_good_parse_start( @@ -174,9 +174,8 @@ class LastOpenBracketFinder: """Return the location of the last open paren""" lno = index2line(self.text.index("insert")) i, buf = self._find_offset_in_buf(lno) - if i is None: - return i - if keysym_type(buf[i]) != right_keysym_type: + if i is None \ + or keysym_type(buf[i]) != right_keysym_type: return None lines_back = buf[i:].count("\n") - 1 # subtract one for the "\n" added to please the parser |