]> granicus.if.org Git - python/commitdiff
Fixed grid_columnconfigure() and grid_rowconfigure() methods of
authorSerhiy Storchaka <storchaka@gmail.com>
Wed, 19 Feb 2014 16:33:30 +0000 (18:33 +0200)
committerSerhiy Storchaka <storchaka@gmail.com>
Wed, 19 Feb 2014 16:33:30 +0000 (18:33 +0200)
Tkinter widgets to work in wantobjects=True mode.

Lib/lib-tk/Tkinter.py
Misc/NEWS

index 18b5c9674f79bc925df159978259784c77572fb6..e9e883865d2d8c0c1d62d2173e7980444d141c70 100644 (file)
@@ -1336,6 +1336,21 @@ class Misc:
         return self._getints(self.tk.call(*args)) or None
 
     bbox = grid_bbox
+
+    def _gridconvvalue(self, value):
+        if isinstance(value, (str, _tkinter.Tcl_Obj)):
+            try:
+                svalue = str(value)
+                if not svalue:
+                    return None
+                elif '.' in svalue:
+                    return getdouble(svalue)
+                else:
+                    return getint(svalue)
+            except ValueError:
+                pass
+        return value
+
     def _grid_configure(self, command, index, cnf, kw):
         """Internal function."""
         if type(cnf) is StringType and not kw:
@@ -1354,22 +1369,14 @@ class Misc:
             for i in range(0, len(words), 2):
                 key = words[i][1:]
                 value = words[i+1]
-                if not value:
-                    value = None
-                elif '.' in str(value):
-                    value = getdouble(value)
-                else:
-                    value = getint(value)
-                dict[key] = value
+                dict[key] = self._gridconvvalue(value)
             return dict
         res = self.tk.call(
                   ('grid', command, self._w, index)
                   + options)
         if len(options) == 1:
-            if not res: return None
-            # In Tk 7.5, -width can be a float
-            if '.' in res: return getdouble(res)
-            return getint(res)
+            return self._gridconvvalue(res)
+
     def grid_columnconfigure(self, index, cnf={}, **kw):
         """Configure column INDEX of a grid.
 
index 47e40afc3aa10caf85c68724224463a47ec4c625..b66f945fe132ae86ae28596294919f2a8a625793 100644 (file)
--- a/Misc/NEWS
+++ b/Misc/NEWS
@@ -39,6 +39,9 @@ Core and Builtins
 Library
 -------
 
+- Issue #20635: Fixed grid_columnconfigure() and grid_rowconfigure() methods of
+  Tkinter widgets to work in wantobjects=True mode.
+
 - Issue #17671: Fixed a crash when use non-initialized io.BufferedRWPair.
   Based on patch by Stephen Tu.