]> git.ipfire.org Git - thirdparty/Python/cpython.git/commitdiff
minsize --> getminsize; new implementation of getminsize
authorGuido van Rossum <guido@python.org>
Fri, 16 Aug 1991 13:17:07 +0000 (13:17 +0000)
committerGuido van Rossum <guido@python.org>
Fri, 16 Aug 1991 13:17:07 +0000 (13:17 +0000)
Lib/lib-stdwin/HVSplit.py
Lib/lib-stdwin/Sliders.py
Lib/stdwin/HVSplit.py
Lib/stdwin/Sliders.py

index 36192a707d8032bd99044e9bd71deb037b2f6d71..c35ce4c6fc6ed5d5002e6310e70288aebe9f4136 100644 (file)
@@ -10,16 +10,19 @@ from Split import Split
 class HVSplit() = Split():
        #
        def create(self, (parent, hv)):
-               # hv is 0 or 1 for HSplit or VSplit
+               # hv is 0 for HSplit, 1 for VSplit
                self = Split.create(self, parent)
                self.hv = hv
                return self
        #
-       def minsize(self, m):
+       def getminsize(self, (m, sugg_size)):
                hv, vh = self.hv, 1 - self.hv
                size = [0, 0]
+               sugg_size = [sugg_size[0], sugg_size[1]]
+               sugg_size[hv] = 0
+               sugg_size = sugg_size[0], sugg_size[1] # Make a tuple
                for c in self.children:
-                       csize = c.minsize(m)
+                       csize = c.getminsize(m, sugg_size)
                        if csize[vh] > size[vh]: size[vh] = csize[vh]
                        size[hv] = size[hv] + csize[hv]
                return size[0], size[1]
@@ -31,14 +34,17 @@ class HVSplit() = Split():
                self.bounds = bounds
                hv, vh = self.hv, 1 - self.hv
                mf = self.parent.beginmeasuring
-               size = self.minsize(mf())
-               # XXX not yet used!  Later for stretching
-               maxsize_hv = bounds[1][hv] - bounds[0][hv]
-               origin = [self.bounds[0][0], self.bounds[0][1]]
+               begin, end = bounds
+               sugg_size = end[0] - begin[0], end[1] - begin[1]
+               size = self.getminsize(mf(), sugg_size)
+               origin = [begin[0], begin[1]]
+               sugg_size = [sugg_size[0], sugg_size[1]] # Make a list
+               sugg_size[hv] = 0
+               sugg_size = sugg_size[0], sugg_size[1] # Make a tuple
                for c in self.children:
-                       size = c.minsize(mf())
+                       size = c.getminsize(mf(), sugg_size)
                        corner = [0, 0]
-                       corner[vh] = bounds[1][vh]
+                       corner[vh] = end[vh]
                        corner[hv] = origin[hv] + size[hv]
                        c.setbounds((origin[0], origin[1]), \
                                        (corner[0], corner[1]))
index f655e77b678ba30f2a4f4abcb3acf691c1f68aa6..a07c3c4b19eee56e00f7c9ffdd663151320f9ed2 100644 (file)
@@ -145,14 +145,13 @@ class ComplexSlider() = HSplit():
        #
        # Override HSplit methods
        #
-       def minsize(self, m):
-               w1, h1 = self.downbutton.minsize(m)
-               w2, h2 = self.dragbutton.minsize(m)
-               w3, h3 = self.upbutton.minsize(m)
-               height = max(h1, h2, h3)
-               w1 = max(w1, height)
-               w3 = max(w3, height)
-               return w1+w2+w3, height
+       def getminsize(self, (m, (width, height))):
+               w1, h1 = self.downbutton.getminsize(m, (0, height))
+               w3, h3 = self.upbutton.getminsize(m, (0, height))
+               w1 = max(w1, h1)
+               w3 = max(w3, h3)
+               w2, h2 = self.dragbutton.getminsize(m, (width-w1-w3, height))
+               return w1+w2+w3, max(h1, h2, h3)
        #
        def setbounds(self, bounds):
                (left, top), (right, bottom) = self.bounds = bounds
index 36192a707d8032bd99044e9bd71deb037b2f6d71..c35ce4c6fc6ed5d5002e6310e70288aebe9f4136 100755 (executable)
@@ -10,16 +10,19 @@ from Split import Split
 class HVSplit() = Split():
        #
        def create(self, (parent, hv)):
-               # hv is 0 or 1 for HSplit or VSplit
+               # hv is 0 for HSplit, 1 for VSplit
                self = Split.create(self, parent)
                self.hv = hv
                return self
        #
-       def minsize(self, m):
+       def getminsize(self, (m, sugg_size)):
                hv, vh = self.hv, 1 - self.hv
                size = [0, 0]
+               sugg_size = [sugg_size[0], sugg_size[1]]
+               sugg_size[hv] = 0
+               sugg_size = sugg_size[0], sugg_size[1] # Make a tuple
                for c in self.children:
-                       csize = c.minsize(m)
+                       csize = c.getminsize(m, sugg_size)
                        if csize[vh] > size[vh]: size[vh] = csize[vh]
                        size[hv] = size[hv] + csize[hv]
                return size[0], size[1]
@@ -31,14 +34,17 @@ class HVSplit() = Split():
                self.bounds = bounds
                hv, vh = self.hv, 1 - self.hv
                mf = self.parent.beginmeasuring
-               size = self.minsize(mf())
-               # XXX not yet used!  Later for stretching
-               maxsize_hv = bounds[1][hv] - bounds[0][hv]
-               origin = [self.bounds[0][0], self.bounds[0][1]]
+               begin, end = bounds
+               sugg_size = end[0] - begin[0], end[1] - begin[1]
+               size = self.getminsize(mf(), sugg_size)
+               origin = [begin[0], begin[1]]
+               sugg_size = [sugg_size[0], sugg_size[1]] # Make a list
+               sugg_size[hv] = 0
+               sugg_size = sugg_size[0], sugg_size[1] # Make a tuple
                for c in self.children:
-                       size = c.minsize(mf())
+                       size = c.getminsize(mf(), sugg_size)
                        corner = [0, 0]
-                       corner[vh] = bounds[1][vh]
+                       corner[vh] = end[vh]
                        corner[hv] = origin[hv] + size[hv]
                        c.setbounds((origin[0], origin[1]), \
                                        (corner[0], corner[1]))
index f655e77b678ba30f2a4f4abcb3acf691c1f68aa6..a07c3c4b19eee56e00f7c9ffdd663151320f9ed2 100755 (executable)
@@ -145,14 +145,13 @@ class ComplexSlider() = HSplit():
        #
        # Override HSplit methods
        #
-       def minsize(self, m):
-               w1, h1 = self.downbutton.minsize(m)
-               w2, h2 = self.dragbutton.minsize(m)
-               w3, h3 = self.upbutton.minsize(m)
-               height = max(h1, h2, h3)
-               w1 = max(w1, height)
-               w3 = max(w3, height)
-               return w1+w2+w3, height
+       def getminsize(self, (m, (width, height))):
+               w1, h1 = self.downbutton.getminsize(m, (0, height))
+               w3, h3 = self.upbutton.getminsize(m, (0, height))
+               w1 = max(w1, h1)
+               w3 = max(w3, h3)
+               w2, h2 = self.dragbutton.getminsize(m, (width-w1-w3, height))
+               return w1+w2+w3, max(h1, h2, h3)
        #
        def setbounds(self, bounds):
                (left, top), (right, bottom) = self.bounds = bounds