mirror of
				https://github.com/python/cpython.git
				synced 2025-10-24 18:33:49 +00:00 
			
		
		
		
	Issue #19020: Tkinter now uses splitlist() instead of split() in configure
methods.
This commit is contained in:
		
							parent
							
								
									0fd557647d
								
							
						
					
					
						commit
						848972cac1
					
				
					 4 changed files with 34 additions and 54 deletions
				
			
		|  | @ -1235,6 +1235,19 @@ def _report_exception(self): | ||||||
|         exc, val, tb = sys.exc_info() |         exc, val, tb = sys.exc_info() | ||||||
|         root = self._root() |         root = self._root() | ||||||
|         root.report_callback_exception(exc, val, tb) |         root.report_callback_exception(exc, val, tb) | ||||||
|  | 
 | ||||||
|  |     def _getconfigure(self, *args): | ||||||
|  |         """Call Tcl configure command and return the result as a dict.""" | ||||||
|  |         cnf = {} | ||||||
|  |         for x in self.tk.splitlist(self.tk.call(*args)): | ||||||
|  |             x = self.tk.splitlist(x) | ||||||
|  |             cnf[x[0][1:]] = (x[0][1:],) + x[1:] | ||||||
|  |         return cnf | ||||||
|  | 
 | ||||||
|  |     def _getconfigure1(self, *args): | ||||||
|  |         x = self.tk.splitlist(self.tk.call(*args)) | ||||||
|  |         return (x[0][1:],) + x[1:] | ||||||
|  | 
 | ||||||
|     def _configure(self, cmd, cnf, kw): |     def _configure(self, cmd, cnf, kw): | ||||||
|         """Internal function.""" |         """Internal function.""" | ||||||
|         if kw: |         if kw: | ||||||
|  | @ -1242,15 +1255,9 @@ def _configure(self, cmd, cnf, kw): | ||||||
|         elif cnf: |         elif cnf: | ||||||
|             cnf = _cnfmerge(cnf) |             cnf = _cnfmerge(cnf) | ||||||
|         if cnf is None: |         if cnf is None: | ||||||
|             cnf = {} |             return self._getconfigure(_flatten((self._w, cmd))) | ||||||
|             for x in self.tk.split( |  | ||||||
|                     self.tk.call(_flatten((self._w, cmd)))): |  | ||||||
|                 cnf[x[0][1:]] = (x[0][1:],) + x[1:] |  | ||||||
|             return cnf |  | ||||||
|         if isinstance(cnf, str): |         if isinstance(cnf, str): | ||||||
|             x = self.tk.split( |             return self._getconfigure1(_flatten((self._w, cmd, '-'+cnf))) | ||||||
|                     self.tk.call(_flatten((self._w, cmd, '-'+cnf)))) |  | ||||||
|             return (x[0][1:],) + x[1:] |  | ||||||
|         self.tk.call(_flatten((self._w, cmd)) + self._options(cnf)) |         self.tk.call(_flatten((self._w, cmd)) + self._options(cnf)) | ||||||
|     # These used to be defined in Widget: |     # These used to be defined in Widget: | ||||||
|     def configure(self, cnf=None, **kw): |     def configure(self, cnf=None, **kw): | ||||||
|  | @ -1271,7 +1278,7 @@ def __setitem__(self, key, value): | ||||||
|     def keys(self): |     def keys(self): | ||||||
|         """Return a list of all resource names of this widget.""" |         """Return a list of all resource names of this widget.""" | ||||||
|         return [x[0][1:] for x in |         return [x[0][1:] for x in | ||||||
|                 self.tk.split(self.tk.call(self._w, 'configure'))] |                 self.tk.splitlist(self.tk.call(self._w, 'configure'))] | ||||||
|     def __str__(self): |     def __str__(self): | ||||||
|         """Return the window path name of this widget.""" |         """Return the window path name of this widget.""" | ||||||
|         return self._w |         return self._w | ||||||
|  | @ -3825,16 +3832,10 @@ def paneconfigure(self, tagOrId, cnf=None, **kw): | ||||||
| 
 | 
 | ||||||
|         """ |         """ | ||||||
|         if cnf is None and not kw: |         if cnf is None and not kw: | ||||||
|             cnf = {} |             return self._getconfigure(self._w, 'paneconfigure', tagOrId) | ||||||
|             for x in self.tk.split( |  | ||||||
|                 self.tk.call(self._w, |  | ||||||
|                          'paneconfigure', tagOrId)): |  | ||||||
|                 cnf[x[0][1:]] = (x[0][1:],) + x[1:] |  | ||||||
|             return cnf |  | ||||||
|         if isinstance(cnf, str) and not kw: |         if isinstance(cnf, str) and not kw: | ||||||
|             x = self.tk.split(self.tk.call( |             return self._getconfigure1( | ||||||
|                 self._w, 'paneconfigure', tagOrId, '-'+cnf)) |                 self._w, 'paneconfigure', tagOrId, '-'+cnf) | ||||||
|             return (x[0][1:],) + x[1:] |  | ||||||
|         self.tk.call((self._w, 'paneconfigure', tagOrId) + |         self.tk.call((self._w, 'paneconfigure', tagOrId) + | ||||||
|                  self._options(cnf, kw)) |                  self._options(cnf, kw)) | ||||||
|     paneconfig = paneconfigure |     paneconfig = paneconfigure | ||||||
|  |  | ||||||
|  | @ -62,8 +62,6 @@ def checkParam(self, widget, name, value, *, expected=_sentinel, | ||||||
|         if not isinstance(widget, Scale): |         if not isinstance(widget, Scale): | ||||||
|             t = widget.configure(name) |             t = widget.configure(name) | ||||||
|             self.assertEqual(len(t), 5) |             self.assertEqual(len(t), 5) | ||||||
|             ## XXX |  | ||||||
|             if not isinstance(t[4], tuple): |  | ||||||
|             self.assertEqual2(t[4], expected, eq=eq) |             self.assertEqual2(t[4], expected, eq=eq) | ||||||
| 
 | 
 | ||||||
|     def checkInvalidParam(self, widget, name, value, errmsg=None, *, |     def checkInvalidParam(self, widget, name, value, errmsg=None, *, | ||||||
|  |  | ||||||
|  | @ -122,13 +122,9 @@ def tix_configure(self, cnf=None, **kw): | ||||||
|         elif cnf: |         elif cnf: | ||||||
|             cnf = _cnfmerge(cnf) |             cnf = _cnfmerge(cnf) | ||||||
|         if cnf is None: |         if cnf is None: | ||||||
|             cnf = {} |             return self._getconfigure('tix', 'configure') | ||||||
|             for x in self.tk.split(self.tk.call('tix', 'configure')): |  | ||||||
|                 cnf[x[0][1:]] = (x[0][1:],) + x[1:] |  | ||||||
|             return cnf |  | ||||||
|         if isinstance(cnf, str): |         if isinstance(cnf, str): | ||||||
|             x = self.tk.split(self.tk.call('tix', 'configure', '-'+cnf)) |             return self._getconfigure1('tix', 'configure', '-'+cnf) | ||||||
|             return (x[0][1:],) + x[1:] |  | ||||||
|         return self.tk.call(('tix', 'configure') + self._options(cnf)) |         return self.tk.call(('tix', 'configure') + self._options(cnf)) | ||||||
| 
 | 
 | ||||||
|     def tix_filedialog(self, dlgclass=None): |     def tix_filedialog(self, dlgclass=None): | ||||||
|  | @ -380,7 +376,7 @@ def _subwidget_names(self): | ||||||
|         """Return the name of all subwidgets.""" |         """Return the name of all subwidgets.""" | ||||||
|         try: |         try: | ||||||
|             x = self.tk.call(self._w, 'subwidgets', '-all') |             x = self.tk.call(self._w, 'subwidgets', '-all') | ||||||
|             return self.tk.split(x) |             return self.tk.splitlist(x) | ||||||
|         except TclError: |         except TclError: | ||||||
|             return None |             return None | ||||||
| 
 | 
 | ||||||
|  | @ -473,13 +469,6 @@ def destroy(self): | ||||||
|             self.tk.call('destroy', self._w) |             self.tk.call('destroy', self._w) | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
| # Useful func. to split Tcl lists and return as a dict. From Tkinter.py |  | ||||||
| def _lst2dict(lst): |  | ||||||
|     dict = {} |  | ||||||
|     for x in lst: |  | ||||||
|         dict[x[0][1:]] = (x[0][1:],) + x[1:] |  | ||||||
|     return dict |  | ||||||
| 
 |  | ||||||
| # Useful class to create a display style - later shared by many items. | # Useful class to create a display style - later shared by many items. | ||||||
| # Contributed by Steffen Kremser | # Contributed by Steffen Kremser | ||||||
| class DisplayStyle: | class DisplayStyle: | ||||||
|  | @ -515,10 +504,8 @@ def __setitem__(self,key,value): | ||||||
|         self.tk.call(self.stylename, 'configure', '-%s'%key, value) |         self.tk.call(self.stylename, 'configure', '-%s'%key, value) | ||||||
| 
 | 
 | ||||||
|     def config(self, cnf={}, **kw): |     def config(self, cnf={}, **kw): | ||||||
|         return _lst2dict( |         return self._getconfigure( | ||||||
|             self.tk.split( |             self.stylename, 'configure', *self._options(cnf,kw)) | ||||||
|             self.tk.call( |  | ||||||
|                   self.stylename, 'configure', *self._options(cnf,kw)))) |  | ||||||
| 
 | 
 | ||||||
|     def __getitem__(self,key): |     def __getitem__(self,key): | ||||||
|         return self.tk.call(self.stylename, 'cget', '-%s'%key) |         return self.tk.call(self.stylename, 'cget', '-%s'%key) | ||||||
|  | @ -928,9 +915,7 @@ def header_create(self, col, cnf={}, **kw): | ||||||
| 
 | 
 | ||||||
|     def header_configure(self, col, cnf={}, **kw): |     def header_configure(self, col, cnf={}, **kw): | ||||||
|         if cnf is None: |         if cnf is None: | ||||||
|             return _lst2dict( |             return self._getconfigure(self._w, 'header', 'configure', col) | ||||||
|                 self.tk.split( |  | ||||||
|                 self.tk.call(self._w, 'header', 'configure', col))) |  | ||||||
|         self.tk.call(self._w, 'header', 'configure', col, |         self.tk.call(self._w, 'header', 'configure', col, | ||||||
|                      *self._options(cnf, kw)) |                      *self._options(cnf, kw)) | ||||||
| 
 | 
 | ||||||
|  | @ -955,9 +940,8 @@ def indicator_create(self, entry, cnf={}, **kw): | ||||||
| 
 | 
 | ||||||
|     def indicator_configure(self, entry, cnf={}, **kw): |     def indicator_configure(self, entry, cnf={}, **kw): | ||||||
|         if cnf is None: |         if cnf is None: | ||||||
|             return _lst2dict( |             return self._getconfigure( | ||||||
|                 self.tk.split( |                 self._w, 'indicator', 'configure', entry) | ||||||
|                 self.tk.call(self._w, 'indicator', 'configure', entry))) |  | ||||||
|         self.tk.call( |         self.tk.call( | ||||||
|               self._w, 'indicator', 'configure', entry, *self._options(cnf, kw)) |               self._w, 'indicator', 'configure', entry, *self._options(cnf, kw)) | ||||||
| 
 | 
 | ||||||
|  | @ -1017,9 +1001,7 @@ def item_cget(self, entry, col, opt): | ||||||
| 
 | 
 | ||||||
|     def item_configure(self, entry, col, cnf={}, **kw): |     def item_configure(self, entry, col, cnf={}, **kw): | ||||||
|         if cnf is None: |         if cnf is None: | ||||||
|             return _lst2dict( |             return self._getconfigure(self._w, 'item', 'configure', entry, col) | ||||||
|                 self.tk.split( |  | ||||||
|                 self.tk.call(self._w, 'item', 'configure', entry, col))) |  | ||||||
|         self.tk.call(self._w, 'item', 'configure', entry, col, |         self.tk.call(self._w, 'item', 'configure', entry, col, | ||||||
|               *self._options(cnf, kw)) |               *self._options(cnf, kw)) | ||||||
| 
 | 
 | ||||||
|  | @ -1038,9 +1020,7 @@ def entrycget(self, entry, opt): | ||||||
| 
 | 
 | ||||||
|     def entryconfigure(self, entry, cnf={}, **kw): |     def entryconfigure(self, entry, cnf={}, **kw): | ||||||
|         if cnf is None: |         if cnf is None: | ||||||
|             return _lst2dict( |             return self._getconfigure(self._w, 'entryconfigure', entry) | ||||||
|                 self.tk.split( |  | ||||||
|                 self.tk.call(self._w, 'entryconfigure', entry))) |  | ||||||
|         self.tk.call(self._w, 'entryconfigure', entry, |         self.tk.call(self._w, 'entryconfigure', entry, | ||||||
|               *self._options(cnf, kw)) |               *self._options(cnf, kw)) | ||||||
| 
 | 
 | ||||||
|  | @ -1254,9 +1234,7 @@ def panecget(self,  entry, opt): | ||||||
| 
 | 
 | ||||||
|     def paneconfigure(self, entry, cnf={}, **kw): |     def paneconfigure(self, entry, cnf={}, **kw): | ||||||
|         if cnf is None: |         if cnf is None: | ||||||
|             return _lst2dict( |             return self._getconfigure(self._w, 'paneconfigure', entry) | ||||||
|                 self.tk.split( |  | ||||||
|                 self.tk.call(self._w, 'paneconfigure', entry))) |  | ||||||
|         self.tk.call(self._w, 'paneconfigure', entry, *self._options(cnf, kw)) |         self.tk.call(self._w, 'paneconfigure', entry, *self._options(cnf, kw)) | ||||||
| 
 | 
 | ||||||
|     def panes(self): |     def panes(self): | ||||||
|  |  | ||||||
|  | @ -29,6 +29,9 @@ Core and Builtins | ||||||
| Library | Library | ||||||
| ------- | ------- | ||||||
| 
 | 
 | ||||||
|  | - Issue #19020: Tkinter now uses splitlist() instead of split() in configure | ||||||
|  |   methods. | ||||||
|  | 
 | ||||||
| - Fix TypeError on "setup.py upload --show-response". | - Fix TypeError on "setup.py upload --show-response". | ||||||
| 
 | 
 | ||||||
| - Issue #12226: HTTPS is now used by default when connecting to PyPI. | - Issue #12226: HTTPS is now used by default when connecting to PyPI. | ||||||
|  |  | ||||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 Serhiy Storchaka
						Serhiy Storchaka