Skip to content

Commit

Permalink
Eliminated the need to use ttk.__loadtk__ and the problems related it.
Browse files Browse the repository at this point in the history
git-svn-id: http://svn.python.org/projects/python/trunk@69404 6015fed2-1504-0410-9fe1-9d1591cc4771
  • Loading branch information
guilherme.polo committed Feb 7, 2009
1 parent 91f2950 commit 2747972
Show file tree
Hide file tree
Showing 2 changed files with 42 additions and 36 deletions.
70 changes: 41 additions & 29 deletions Lib/lib-tk/ttk.py
Original file line number Diff line number Diff line change
Expand Up @@ -29,32 +29,41 @@

_flatten = Tkinter._flatten

# Verify if Tk is new enough to not need Tile checking
# Verify if Tk is new enough to not need the Tile package
_REQUIRE_TILE = True if Tkinter.TkVersion < 8.5 else False

def _loadttk(loadtk):
# This extends the default Tkinter.Tk._loadtk method so we can be
# sure that ttk is available for use, or not.
def _wrapper(self):
loadtk(self)

if _REQUIRE_TILE:
import os
tilelib = os.environ.get('TILE_LIBRARY')
if tilelib:
# append custom tile path to the the list of directories that
# Tcl uses when attempting to resolve packages with the package
# command
self.tk.eval('global auto_path; '
'lappend auto_path {%s}' % tilelib)
self.tk.eval('package require tile') # TclError may be raised here

return _wrapper
def _load_tile(master):
if _REQUIRE_TILE:
import os
tilelib = os.environ.get('TILE_LIBRARY')
if tilelib:
# append custom tile path to the the list of directories that
# Tcl uses when attempting to resolve packages with the package
# command
master.tk.eval(
'global auto_path; '
'lappend auto_path {%s}' % tilelib)

master.tk.eval('package require tile') # TclError may be raised here
master._tile_loaded = True


def _setup_master(master=None):
"""If master is not None, itself is returned. If master is None,
the default master is returned if there is one, otherwise a new
master is created and returned.
If it is not allowed to use the default root and master is None,
RuntimeError is raised."""
if master is None:
if Tkinter._support_default_root:
master = Tkinter._default_root or Tkinter.Tk()
else:
raise RuntimeError(
"No master specified and Tkinter is "
"configured to not support default root")
return master

# Store the original Tkinter.Tk._loadtk before replacing it just in case
# someone wants to restore it.
__loadtk__ = Tkinter.Tk._loadtk
Tkinter.Tk._loadtk = _loadttk(Tkinter.Tk._loadtk)


def _format_optdict(optdict, script=False, ignore=None):
Expand Down Expand Up @@ -366,12 +375,11 @@ class Style(object):
_name = "ttk::style"

def __init__(self, master=None):
if master is None:
if Tkinter._support_default_root:
master = Tkinter._default_root or Tkinter.Tk()
else:
raise RuntimeError("No master specified and Tkinter is "
"configured to not support default master")
master = _setup_master(master)

if not getattr(master, '_tile_loaded', False):
# Load tile now, if needed
_load_tile(master)

self.master = master
self.tk = self.master.tk
Expand Down Expand Up @@ -548,6 +556,10 @@ def __init__(self, master, widgetname, kw=None):
active, disabled, focus, pressed, selected, background,
readonly, alternate, invalid
"""
master = _setup_master(master)
if not getattr(master, '_tile_loaded', False):
# Load tile now, if needed
_load_tile(master)
Tkinter.Widget.__init__(self, master, widgetname, kw=kw)


Expand Down
8 changes: 1 addition & 7 deletions Lib/test/test_tcl.py
Original file line number Diff line number Diff line change
Expand Up @@ -4,15 +4,9 @@
import os
import _tkinter
from test import test_support
from Tkinter import Tk, Tcl
from Tkinter import Tcl
from _tkinter import TclError

# Restore Tkinter.Tk._loadtk that may have been overridden by ttk.
# If this is not done then this test may fail for reasons related
# to ttk only (like failing to load the tile package).
from ttk import __loadtk__
Tk._loadtk = __loadtk__


class TkinterTest(unittest.TestCase):

Expand Down

0 comments on commit 2747972

Please sign in to comment.