Merge pull request #5266 from PySimpleGUI/Dev-latest
ButtonMenu.Click aliased added. Debugger - automatically adds a time…
This commit is contained in:
commit
c59db9b5c0
|
@ -1,5 +1,5 @@
|
||||||
#!/usr/bin/python3
|
#!/usr/bin/python3
|
||||||
version = __version__ = "4.57.0.6 Unreleased"
|
version = __version__ = "4.57.0.8 Unreleased"
|
||||||
|
|
||||||
_change_log = """
|
_change_log = """
|
||||||
Changelog since 4.57.0 released to PyPI on 13-Feb-2022
|
Changelog since 4.57.0 released to PyPI on 13-Feb-2022
|
||||||
|
@ -16,6 +16,10 @@ _change_log = """
|
||||||
Open GitHub Issue GUI - Tabs use 2 lines now. Added tab asking where found PSG.
|
Open GitHub Issue GUI - Tabs use 2 lines now. Added tab asking where found PSG.
|
||||||
4.57.0.6
|
4.57.0.6
|
||||||
New symbols SYMBOL_CHECKMARK_SMALL & SYMBOL_X_SMALL
|
New symbols SYMBOL_CHECKMARK_SMALL & SYMBOL_X_SMALL
|
||||||
|
4.57.0.7
|
||||||
|
Added click - PEP8 alias for ButtonMenu.Click
|
||||||
|
4.57.0.8
|
||||||
|
Automatically add timeouts to user reads if a debugger window is opened. Need to add support for multi-window applications still.
|
||||||
"""
|
"""
|
||||||
|
|
||||||
__version__ = version.split()[0] # For PEP 396 and PEP 345
|
__version__ = version.split()[0] # For PEP 396 and PEP 345
|
||||||
|
@ -4820,6 +4824,7 @@ class ButtonMenu(Element):
|
||||||
text_color=self.TextColor, background_color=self.BackgroundColor, visible=visible, metadata=metadata)
|
text_color=self.TextColor, background_color=self.BackgroundColor, visible=visible, metadata=metadata)
|
||||||
self.Tearoff = tearoff
|
self.Tearoff = tearoff
|
||||||
|
|
||||||
|
|
||||||
def _MenuItemChosenCallback(self, item_chosen): # ButtonMenu Menu Item Chosen Callback
|
def _MenuItemChosenCallback(self, item_chosen): # ButtonMenu Menu Item Chosen Callback
|
||||||
"""
|
"""
|
||||||
Not a user callable function. Called by tkinter when an item is chosen from the menu.
|
Not a user callable function. Called by tkinter when an item is chosen from the menu.
|
||||||
|
@ -4835,6 +4840,7 @@ class ButtonMenu(Element):
|
||||||
# self.ParentForm.TKroot.quit() # kick the users out of the mainloop
|
# self.ParentForm.TKroot.quit() # kick the users out of the mainloop
|
||||||
_exit_mainloop(self.ParentForm)
|
_exit_mainloop(self.ParentForm)
|
||||||
|
|
||||||
|
|
||||||
def update(self, menu_definition=None, visible=None, image_source=None, image_size=(None, None), image_subsample=None, button_text=None):
|
def update(self, menu_definition=None, visible=None, image_source=None, image_size=(None, None), image_subsample=None, button_text=None):
|
||||||
"""
|
"""
|
||||||
Changes some of the settings for the ButtonMenu Element. Must call `Window.Read` or `Window.Finalize` prior
|
Changes some of the settings for the ButtonMenu Element. Must call `Window.Read` or `Window.Finalize` prior
|
||||||
|
@ -4917,7 +4923,7 @@ class ButtonMenu(Element):
|
||||||
if visible is not None:
|
if visible is not None:
|
||||||
self._visible = visible
|
self._visible = visible
|
||||||
|
|
||||||
def Click(self):
|
def click(self):
|
||||||
"""
|
"""
|
||||||
Generates a click of the button as if the user clicked the button
|
Generates a click of the button as if the user clicked the button
|
||||||
Calls the tkinter invoke method for the button
|
Calls the tkinter invoke method for the button
|
||||||
|
@ -4928,7 +4934,7 @@ class ButtonMenu(Element):
|
||||||
print('Exception clicking button')
|
print('Exception clicking button')
|
||||||
|
|
||||||
Update = update
|
Update = update
|
||||||
|
Click = click
|
||||||
|
|
||||||
BMenu = ButtonMenu
|
BMenu = ButtonMenu
|
||||||
BM = ButtonMenu
|
BM = ButtonMenu
|
||||||
|
@ -9615,6 +9621,11 @@ class Window:
|
||||||
if not Window._read_call_from_debugger:
|
if not Window._read_call_from_debugger:
|
||||||
_refresh_debugger()
|
_refresh_debugger()
|
||||||
|
|
||||||
|
# if the user has not added timeout and a debug window is open, then set a timeout for them so the debugger continuously refreshes
|
||||||
|
if _debugger_window_is_open() and not Window._read_call_from_debugger:
|
||||||
|
if timeout is None or timeout > 3000:
|
||||||
|
timeout = 200
|
||||||
|
|
||||||
Window._root_running_mainloop = self.TKroot
|
Window._root_running_mainloop = self.TKroot
|
||||||
|
|
||||||
while True:
|
while True:
|
||||||
|
@ -10831,22 +10842,28 @@ class Window:
|
||||||
def _callback_main_debugger_window_create_keystroke(self, event):
|
def _callback_main_debugger_window_create_keystroke(self, event):
|
||||||
"""
|
"""
|
||||||
Called when user presses the key that creates the main debugger window
|
Called when user presses the key that creates the main debugger window
|
||||||
|
March 2022 - now causes the user reads to return timeout events automatically
|
||||||
:param event: (event) not used. Passed in event info
|
:param event: (event) not used. Passed in event info
|
||||||
:type event:
|
:type event:
|
||||||
"""
|
"""
|
||||||
Window._main_debug_window_build_needed = True
|
Window._main_debug_window_build_needed = True
|
||||||
# _Debugger.debugger._build_main_debugger_window()
|
# exit the event loop in a way that resembles a timeout occurring
|
||||||
|
self.LastButtonClicked = self.TimeoutKey
|
||||||
|
self.FormRemainedOpen = True
|
||||||
|
self.TKroot.quit() # kick the users out of the mainloop
|
||||||
|
|
||||||
def _callback_popout_window_create_keystroke(self, event):
|
def _callback_popout_window_create_keystroke(self, event):
|
||||||
"""
|
"""
|
||||||
Called when user presses the key that creates the floating debugger window
|
Called when user presses the key that creates the floating debugger window
|
||||||
|
March 2022 - now causes the user reads to return timeout events automatically
|
||||||
:param event: (event) not used. Passed in event info
|
:param event: (event) not used. Passed in event info
|
||||||
:type event:
|
:type event:
|
||||||
"""
|
"""
|
||||||
Window._floating_debug_window_build_needed = True
|
Window._floating_debug_window_build_needed = True
|
||||||
# _Debugger.debugger._build_floating_window()
|
# exit the event loop in a way that resembles a timeout occurring
|
||||||
|
self.LastButtonClicked = self.TimeoutKey
|
||||||
|
self.FormRemainedOpen = True
|
||||||
|
self.TKroot.quit() # kick the users out of the mainloop
|
||||||
|
|
||||||
def enable_debugger(self):
|
def enable_debugger(self):
|
||||||
"""
|
"""
|
||||||
|
@ -21951,20 +21968,39 @@ def _refresh_debugger():
|
||||||
_Debugger.debugger = _Debugger()
|
_Debugger.debugger = _Debugger()
|
||||||
debugger = _Debugger.debugger
|
debugger = _Debugger.debugger
|
||||||
Window._read_call_from_debugger = True
|
Window._read_call_from_debugger = True
|
||||||
|
rc = None
|
||||||
# frame = inspect.currentframe()
|
# frame = inspect.currentframe()
|
||||||
# frame = inspect.currentframe().f_back
|
# frame = inspect.currentframe().f_back
|
||||||
|
|
||||||
frame, *others = inspect.stack()[1]
|
frame, *others = inspect.stack()[1]
|
||||||
try:
|
try:
|
||||||
debugger.locals = frame.f_back.f_locals
|
debugger.locals = frame.f_back.f_locals
|
||||||
debugger.globals = frame.f_back.f_globals
|
debugger.globals = frame.f_back.f_globals
|
||||||
finally:
|
finally:
|
||||||
del frame
|
del frame
|
||||||
debugger._refresh_floating_window() if debugger.popout_window else None
|
if debugger.popout_window:
|
||||||
rc = debugger._refresh_main_debugger_window(debugger.locals, debugger.globals) if debugger.watcher_window else False
|
rc = debugger._refresh_floating_window()
|
||||||
|
if debugger.watcher_window:
|
||||||
|
rc = debugger._refresh_main_debugger_window(debugger.locals, debugger.globals)
|
||||||
Window._read_call_from_debugger = False
|
Window._read_call_from_debugger = False
|
||||||
return rc
|
return rc
|
||||||
|
|
||||||
|
|
||||||
|
def _debugger_window_is_open():
|
||||||
|
"""
|
||||||
|
Determines if one of the debugger window is currently open
|
||||||
|
:return: returns True if the popout window or the main debug window is open
|
||||||
|
:rtype: (bool)
|
||||||
|
"""
|
||||||
|
|
||||||
|
if _Debugger.debugger is None:
|
||||||
|
return False
|
||||||
|
debugger = _Debugger.debugger
|
||||||
|
if debugger.popout_window or debugger.watcher_window:
|
||||||
|
return True
|
||||||
|
return False
|
||||||
|
|
||||||
|
|
||||||
def get_versions():
|
def get_versions():
|
||||||
"""
|
"""
|
||||||
Returns a human-readable string of version numbers for:
|
Returns a human-readable string of version numbers for:
|
||||||
|
|
Loading…
Reference in New Issue