diff options
author | Georg Brandl <georg@python.org> | 2008-05-16 14:24:45 +0000 |
---|---|---|
committer | Georg Brandl <georg@python.org> | 2008-05-16 14:24:45 +0000 |
commit | bbc57d73a0f0d1476d9c23b920ecc1ef8212a554 (patch) | |
tree | 44b67b84bf3297c5feb4e58a286fd98a92af4c99 /Lib/tkinter/scrolledtext.py | |
parent | ae6b9f3cb22df80118dfe470ac2130fe0aa716a1 (diff) | |
download | cpython-git-bbc57d73a0f0d1476d9c23b920ecc1ef8212a554.tar.gz |
Step 1 of Tkinter renaming: move lib-tk modules into a new "tkinter" package.
Diffstat (limited to 'Lib/tkinter/scrolledtext.py')
-rw-r--r-- | Lib/tkinter/scrolledtext.py | 43 |
1 files changed, 43 insertions, 0 deletions
diff --git a/Lib/tkinter/scrolledtext.py b/Lib/tkinter/scrolledtext.py new file mode 100644 index 0000000000..c96bc3b502 --- /dev/null +++ b/Lib/tkinter/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)) |