summaryrefslogtreecommitdiffstats
path: root/Tools/idle/ParenMatch.py
diff options
context:
space:
mode:
authorJeremy Hylton <jeremy@alum.mit.edu>2000-03-03 23:06:45 (GMT)
committerJeremy Hylton <jeremy@alum.mit.edu>2000-03-03 23:06:45 (GMT)
commite81f28b630a7192207b9ac9a6813c8d29f1bed6c (patch)
tree470d5306ede24a1819eefb1fff1fb3abae7446f3 /Tools/idle/ParenMatch.py
parent583abb80277d6ab5c8ad887477c12a3139e6f5f9 (diff)
downloadcpython-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.py23
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