diff options
author | Georg Brandl <georg@python.org> | 2008-05-20 06:58:21 +0000 |
---|---|---|
committer | Georg Brandl <georg@python.org> | 2008-05-20 06:58:21 +0000 |
commit | 33cece05b918dff706a4298e33f84d8e8a0391d2 (patch) | |
tree | c78da9213928978586e3e5259195a6be2d580648 /Lib/lib-tk/ScrolledText.py | |
parent | 248e3a8b7f7868e72a056609605bc1e7d84b1393 (diff) | |
download | cpython-git-33cece05b918dff706a4298e33f84d8e8a0391d2.tar.gz |
Tkinter renaming reversal: move modules back in their place.
Diffstat (limited to 'Lib/lib-tk/ScrolledText.py')
-rw-r--r-- | Lib/lib-tk/ScrolledText.py | 43 |
1 files changed, 43 insertions, 0 deletions
diff --git a/Lib/lib-tk/ScrolledText.py b/Lib/lib-tk/ScrolledText.py new file mode 100644 index 0000000000..c96bc3b502 --- /dev/null +++ b/Lib/lib-tk/ScrolledText.py @@ -0,0 +1,43 @@ +# A ScrolledText widget feels like a text widget but also has a +# vertical scroll bar on its right. (Later, options may be added to +# add a horizontal bar as well, to make the bars disappear +# automatically when not needed, to move them to the other side of the +# window, etc.) +# +# Configuration options are passed to the Text widget. +# A Frame widget is inserted between the master and the text, to hold +# the Scrollbar widget. +# Most methods calls are inherited from the Text widget; Pack methods +# are redirected to the Frame widget however. + +from tkinter import * +from tkinter import _cnfmerge + +class ScrolledText(Text): + def __init__(self, master=None, cnf=None, **kw): + if cnf is None: + cnf = {} + if kw: + cnf = _cnfmerge((cnf, kw)) + fcnf = {} + for k in cnf.keys(): + if type(k) == ClassType or k == 'name': + fcnf[k] = cnf[k] + del cnf[k] + self.frame = Frame(master, **fcnf) + self.vbar = Scrollbar(self.frame, name='vbar') + self.vbar.pack(side=RIGHT, fill=Y) + cnf['name'] = 'text' + Text.__init__(self, self.frame, **cnf) + self.pack(side=LEFT, fill=BOTH, expand=1) + self['yscrollcommand'] = self.vbar.set + self.vbar['command'] = self.yview + + # Copy geometry methods of self.frame -- hack! + methods = Pack.__dict__.keys() + methods = methods + Grid.__dict__.keys() + methods = methods + Place.__dict__.keys() + + for m in methods: + if m[0] != '_' and m != 'config' and m != 'configure': + setattr(self, m, getattr(self.frame, m)) |