diff options
author | Guido van Rossum <guido@python.org> | 1997-09-29 23:24:52 (GMT) |
---|---|---|
committer | Guido van Rossum <guido@python.org> | 1997-09-29 23:24:52 (GMT) |
commit | 83bd9a9c8c5da22603e77af23d25e412282a2bb6 (patch) | |
tree | 35672aab5e5bc766c74eefb52d9436781ad84d35 | |
parent | 332e14437c6e7461e9756f75e4fac3f9d2043023 (diff) | |
download | cpython-83bd9a9c8c5da22603e77af23d25e412282a2bb6.zip cpython-83bd9a9c8c5da22603e77af23d25e412282a2bb6.tar.gz cpython-83bd9a9c8c5da22603e77af23d25e412282a2bb6.tar.bz2 |
Move Widget.config() c.s. to Misc class, so the Tk class also inherits them.
-rw-r--r-- | Lib/lib-tk/Tkinter.py | 61 |
1 files changed, 30 insertions, 31 deletions
diff --git a/Lib/lib-tk/Tkinter.py b/Lib/lib-tk/Tkinter.py index cecf107..f009afd 100644 --- a/Lib/lib-tk/Tkinter.py +++ b/Lib/lib-tk/Tkinter.py @@ -567,6 +567,36 @@ class Misc: exc, val, tb = sys.exc_type, sys.exc_value, sys.exc_traceback root = self._root() root.report_callback_exception(exc, val, tb) + # These used to be defined in Widget: + def config(self, cnf=None, **kw): + # XXX ought to generalize this so tag_config etc. can use it + if kw: + cnf = _cnfmerge((cnf, kw)) + elif cnf: + cnf = _cnfmerge(cnf) + if cnf is None: + cnf = {} + for x in self.tk.split( + self.tk.call(self._w, 'configure')): + cnf[x[0][1:]] = (x[0][1:],) + x[1:] + return cnf + if type(cnf) is StringType: + x = self.tk.split(self.tk.call( + self._w, 'configure', '-'+cnf)) + return (x[0][1:],) + x[1:] + apply(self.tk.call, (self._w, 'configure') + + self._options(cnf)) + configure = config + def cget(self, key): + return self.tk.call(self._w, 'cget', '-' + key) + __getitem__ = cget + def __setitem__(self, key, value): + Widget.config(self, {key: value}) + def keys(self): + return map(lambda x: x[0][1:], + self.tk.split(self.tk.call(self._w, 'configure'))) + def __str__(self): + return self._w class CallWrapper: def __init__(self, func, subst, widget): @@ -710,8 +740,6 @@ class Tk(Misc, Wm): global _default_root if _default_root is self: _default_root = None - def __str__(self): - return self._w def readprofile(self, baseName, className): import os if os.environ.has_key('HOME'): home = os.environ['HOME'] @@ -927,35 +955,6 @@ class Widget(Misc, Pack, Place, Grid): (widgetName, self._w) + extra + self._options(cnf)) for k, v in classes: k.config(self, v) - def config(self, cnf=None, **kw): - # XXX ought to generalize this so tag_config etc. can use it - if kw: - cnf = _cnfmerge((cnf, kw)) - elif cnf: - cnf = _cnfmerge(cnf) - if cnf is None: - cnf = {} - for x in self.tk.split( - self.tk.call(self._w, 'configure')): - cnf[x[0][1:]] = (x[0][1:],) + x[1:] - return cnf - if type(cnf) is StringType: - x = self.tk.split(self.tk.call( - self._w, 'configure', '-'+cnf)) - return (x[0][1:],) + x[1:] - apply(self.tk.call, (self._w, 'configure') - + self._options(cnf)) - configure = config - def cget(self, key): - return self.tk.call(self._w, 'cget', '-' + key) - __getitem__ = cget - def __setitem__(self, key, value): - Widget.config(self, {key: value}) - def keys(self): - return map(lambda x: x[0][1:], - self.tk.split(self.tk.call(self._w, 'configure'))) - def __str__(self): - return self._w def destroy(self): for c in self.children.values(): c.destroy() if self.master.children.has_key(self._name): |