]> git.ipfire.org Git - thirdparty/Python/cpython.git/commitdiff
Totally changed, now it is actually derived from Text
authorGuido van Rossum <guido@python.org>
Wed, 6 Jul 1994 21:54:39 +0000 (21:54 +0000)
committerGuido van Rossum <guido@python.org>
Wed, 6 Jul 1994 21:54:39 +0000 (21:54 +0000)
(This breaks something in MimeViewer.py, don't know what yet)

Lib/lib-tk/ScrolledText.py
Lib/tkinter/ScrolledText.py

index 4092d4f695f3c2c2c18e75ff8df61d7f3a34f364..2683696f72fecd4395d222d651fca1078015ca5e 100644 (file)
@@ -7,40 +7,29 @@
 # 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 passed to the Text widget; the pack command
-# is redirected to the Frame widget however.
+# 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(Pack, Place):
+class ScrolledText(Text):
        def __init__(self, master=None, cnf={}):
+               cnf = _cnfmerge(cnf)
                fcnf = {}
-               self.frame = Frame(master, {})
-               if cnf.has_key(Pack):
-                       self.frame.pack(cnf[Pack])
-                       del cnf[Pack]
-               self.vbar = Scrollbar(self.frame, {})
-               self.vbar.pack({'side': 'right', 'fill': 'y'})
+               for k in cnf.keys():
+                       if type(k) == ClassType:
+                               fcnf[k] = cnf[k]
+                               del cnf[k]
+               self.frame = Frame(master, fcnf)
+               self.vbar = Scrollbar(self.frame, {
+                       Pack: {'side': 'right', 'fill': 'y'}})
                cnf[Pack] = {'side': 'left', 'fill': 'both', 'expand': 'yes'}
-               self.text = Text(self.frame, cnf)
-               self.text['yscrollcommand'] = (self.vbar, 'set')
-               self.vbar['command'] = (self.text, 'yview')
-               self.insert = self.text.insert
-               # XXX should do all Text methods...
-               self.pack = self.frame.pack
-               self.bind = self.text.bind
-               self.forget = self.frame.forget
-               self.delete = self.text.delete
-               self.insert = self.text.insert
-               self.index = self.text.index
-               self.get = self.text.get
-               self.mark_set = self.text.mark_set
-               self.tag_add = self.text.tag_add
-               self.tag_delete = self.text.tag_delete
-               self.tag_remove = self.text.tag_remove
-               self.tag_config = self.text.tag_config
-               self.yview = self.text.yview
-               self.yview_pickplace = self.text.yview_pickplace
-               self.tk = master.tk
-       def __str__(self):
-               return str(self.frame)
+               Text.__init__(self, self.frame, cnf)
+               self['yscrollcommand'] = (self.vbar, 'set')
+               self.vbar['command'] = (self, 'yview')
+
+               # Copy Pack methods of self.frame -- hack!
+               for m in Pack.__dict__.keys():
+                       if m[0] != '_' and m != 'config':
+                               setattr(self, m, getattr(self.frame, m))
index 4092d4f695f3c2c2c18e75ff8df61d7f3a34f364..2683696f72fecd4395d222d651fca1078015ca5e 100755 (executable)
@@ -7,40 +7,29 @@
 # 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 passed to the Text widget; the pack command
-# is redirected to the Frame widget however.
+# 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(Pack, Place):
+class ScrolledText(Text):
        def __init__(self, master=None, cnf={}):
+               cnf = _cnfmerge(cnf)
                fcnf = {}
-               self.frame = Frame(master, {})
-               if cnf.has_key(Pack):
-                       self.frame.pack(cnf[Pack])
-                       del cnf[Pack]
-               self.vbar = Scrollbar(self.frame, {})
-               self.vbar.pack({'side': 'right', 'fill': 'y'})
+               for k in cnf.keys():
+                       if type(k) == ClassType:
+                               fcnf[k] = cnf[k]
+                               del cnf[k]
+               self.frame = Frame(master, fcnf)
+               self.vbar = Scrollbar(self.frame, {
+                       Pack: {'side': 'right', 'fill': 'y'}})
                cnf[Pack] = {'side': 'left', 'fill': 'both', 'expand': 'yes'}
-               self.text = Text(self.frame, cnf)
-               self.text['yscrollcommand'] = (self.vbar, 'set')
-               self.vbar['command'] = (self.text, 'yview')
-               self.insert = self.text.insert
-               # XXX should do all Text methods...
-               self.pack = self.frame.pack
-               self.bind = self.text.bind
-               self.forget = self.frame.forget
-               self.delete = self.text.delete
-               self.insert = self.text.insert
-               self.index = self.text.index
-               self.get = self.text.get
-               self.mark_set = self.text.mark_set
-               self.tag_add = self.text.tag_add
-               self.tag_delete = self.text.tag_delete
-               self.tag_remove = self.text.tag_remove
-               self.tag_config = self.text.tag_config
-               self.yview = self.text.yview
-               self.yview_pickplace = self.text.yview_pickplace
-               self.tk = master.tk
-       def __str__(self):
-               return str(self.frame)
+               Text.__init__(self, self.frame, cnf)
+               self['yscrollcommand'] = (self.vbar, 'set')
+               self.vbar['command'] = (self, 'yview')
+
+               # Copy Pack methods of self.frame -- hack!
+               for m in Pack.__dict__.keys():
+                       if m[0] != '_' and m != 'config':
+                               setattr(self, m, getattr(self.frame, m))