Merge pull request #5813 from PySimpleGUI/Dev-latest

Updated the Output Element's docstring
This commit is contained in:
PySimpleGUI 2022-08-25 19:47:01 -04:00 committed by GitHub
commit c3f937b294
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
1 changed files with 14 additions and 210 deletions

View File

@ -1,6 +1,6 @@
#!/usr/bin/python3
version = __version__ = "4.60.3.83 Unreleased"
version = __version__ = "4.60.3.84 Unreleased"
_change_log = """
Changelog since 4.60.0 released to PyPI on 8-May-2022
@ -220,6 +220,8 @@ _change_log = """
4.60.3.83
Output element - now automatically rereoutes cprint to here as well. Assumption is that you want stuff to go here without
needing to specify each thing. If want more control, then use the Multline directly
4.60.3.84
Output element - updated docstring
"""
__version__ = version.split()[0] # For PEP 396 and PEP 345
@ -4513,110 +4515,6 @@ class TKProgressBar():
return False
return True
#
# # ---------------------------------------------------------------------- #
# # TKOutput #
# # New Type of TK Widget that's a Text Widget in disguise #
# # Note that it's inherited from the TKFrame class so that the #
# # Scroll bar will span the length of the frame #
# # ---------------------------------------------------------------------- #
# class TKOutput(tk.Frame):
# """
# tkinter style class. Inherits Frame class from tkinter. Adds a tk.Text and a scrollbar together.
# Note - This is NOT a user controlled class. Users should NOT be directly using it unless making an extention
# to PySimpleGUI by directly manipulating tkinter.
# """
#
# def __init__(self, parent, width, height, bd, background_color=None, text_color=None, echo_stdout_stderr=False, font=None, pad=None):
# """
# :param parent: The "Root" that the Widget will be in
# :type parent: tk.Tk | tk.Toplevel
# :param width: Width in characters
# :type width: (int)
# :param height: height in rows
# :type height: (int)
# :param bd: Border Depth. How many pixels of border to show
# :type bd: (int)
# :param background_color: color of background
# :type background_color: (str)
# :param text_color: color of the text
# :type text_color: (str)
# :param echo_stdout_stderr: If True then output to stdout will be output to this element AND also to the normal console location
# :type echo_stdout_stderr: (bool)
# :param font: specifies the font family, size, etc. Tuple or Single string format 'name size styles'. Styles: italic * roman bold normal underline overstrike
# :type font: (str or (str, int[, str]) or None)
# :param pad: Amount of padding to put around element in pixels (left/right, top/bottom) or ((left, right), (top, bottom)) or an int. If an int, then it's converted into a tuple (int, int)
# :type pad: (int, int) or ((int, int),(int,int)) or (int,(int,int)) or ((int, int),int) | int
# """
# self.frame = tk.Frame(parent)
# tk.Frame.__init__(self, self.frame)
# self.output = tk.Text(self.frame, width=width, height=height, bd=bd, font=font)
# if background_color and background_color != COLOR_SYSTEM_DEFAULT:
# self.output.configure(background=background_color)
# self.frame.configure(background=background_color)
# if text_color and text_color != COLOR_SYSTEM_DEFAULT:
# self.output.configure(fg=text_color)
# self.output.configure(insertbackground=text_color)
# self.vsb = tk.Scrollbar(self.frame, orient="vertical", command=self.output.yview)
# self.output.configure(yscrollcommand=self.vsb.set)
# self.output.pack(side="left", fill="both", expand=True)
# self.vsb.pack(side="left", fill="y", expand=False)
# self.frame.pack(side="left", padx=pad[0], pady=pad[1], expand=True, fill='y')
# self.previous_stdout = sys.stdout
# self.previous_stderr = sys.stderr
# self.parent = parent
# self.echo_stdout_stderr = echo_stdout_stderr
#
# sys.stdout = self
# sys.stderr = self
# self.pack()
#
# def write(self, txt):
# """
# Called by Python (not tkinter?) when stdout or stderr wants to write
# Refreshes the window after the write so that the change is immediately displayed
#
# :param txt: text of output
# :type txt: (str)
# """
# try:
# self.output.insert(tk.END, str(txt))
# self.output.see(tk.END)
# self.parent.update()
# except:
# pass
#
# try:
# if self.echo_stdout_stderr:
# self.previous_stdout.write(txt)
# except:
# pass
#
# def Close(self):
# """
# Called when wanting to restore the old stdout/stderr
# """
# sys.stdout = self.previous_stdout
# sys.stderr = self.previous_stderr
#
# def flush(self):
# """
# Flush parameter was passed into a print statement.
# For now doing nothing. Not sure what action should be taken to ensure a flush happens regardless.
# """
# try:
# if self.echo_stdout_stderr:
# self.previous_stdout.flush()
# except:
# pass
#
# def __del__(self):
# """
# If this Widget is deleted, be sure and restore the old stdout, stderr
# """
# sys.stdout = self.previous_stdout
# sys.stderr = self.previous_stderr
# ---------------------------------------------------------------------- #
# Output #
@ -4624,19 +4522,19 @@ class TKProgressBar():
# ---------------------------------------------------------------------- #
class Output(Multiline):
"""
** NOTE - It's recommended to use Multiline Element instead **
Output Element - a multi-lined text area to where stdout, stderr, cprint are rerouted.
Output Element - a multi-lined text area where stdout and stderr are re-routed to.
The Output Element is now based on the Multiline Element. When you make an Output Element, you're
creating a Multiline Element with some specific settings set:
auto_refresh = True
auto_scroll = True
reroute_stdout = True
reroute_stderr = True
reroute_cprint = True
write_only = True
The Multiline Element is the superior and recommended method for showing the output of stdout.
The Multiline Element has been added to significantly while the Output element has not.
If you choose to use a Multiline element to replace an Output element, be sure an turn on the write_only paramter in the Multline
Of course, Output Element continues to operate and be backwards compatible, but you're missing out on
features such as routing the cprint output to the element.
In Apr 2022, the Output Element was switched to be a subclass of the Multiline so that more code will be in common. Nowever
you will not get all of the parms unless you switch to the Multline Specifically
If you choose to use a Multiline element to replace an Output element, be sure an turn on the write_only paramter in the Multiline
so that an item is not included in the values dictionary on every window.read call
"""
def __init__(self, size=(None, None), s=(None, None), background_color=None, text_color=None, pad=None, p=None, echo_stdout_stderr=False, font=None, tooltip=None,
@ -4696,102 +4594,8 @@ class Output(Multiline):
"""
# self._TKOut = self.Widget = None # type: TKOutput
# bg = background_color if background_color else DEFAULT_INPUT_ELEMENTS_COLOR
# fg = text_color if text_color is not None else DEFAULT_INPUT_TEXT_COLOR
# self.RightClickMenu = right_click_menu
# key = key if key is not None else k
# self.echo_stdout_stderr = echo_stdout_stderr
# sz = size if size != (None, None) else s
# pad = pad if pad is not None else p
# self.expand_x = expand_x
# self.expand_y = expand_y
super().__init__(size=size, s=s, background_color=background_color, text_color=text_color, pad=pad, p=p, echo_stdout_stderr=echo_stdout_stderr, font=font, tooltip=tooltip, wrap_lines=wrap_lines, horizontal_scroll=horizontal_scroll, key=key, k=k, right_click_menu=right_click_menu, write_only=True, reroute_stdout=True, reroute_stderr=True, reroute_cprint=True, autoscroll=True, auto_refresh=True, expand_x=expand_x, expand_y=expand_y, visible=visible, metadata=metadata, sbar_trough_color=sbar_trough_color, sbar_background_color=sbar_background_color, sbar_arrow_color=sbar_arrow_color, sbar_width=sbar_width, sbar_arrow_width=sbar_arrow_width, sbar_frame_color=sbar_frame_color, sbar_relief=sbar_relief)
#
# @property
# def tk_out(self):
# """
# Returns the TKOutput object used to create the element
#
# :return: The TKOutput object
# :rtype: (TKOutput)
# """
# if self._TKOut is None:
# print('*** Did you forget to call Finalize()? Your code should look something like: ***')
# print('*** form = sg.Window("My Form").Layout(layout).Finalize() ***')
# return self._TKOut
#
# def update(self, value=None, visible=None):
# """
# Changes some of the settings for the Output Element. Must call `Window.Read` or `Window.Finalize` prior
#
# Changes will not be visible in your window until you call window.read or window.refresh.
#
# If you change visibility, your element may MOVE. If you want it to remain stationary, use the "layout helper"
# function "pin" to ensure your element is "pinned" to that location in your layout so that it returns there
# when made visible.
#
# :param value: string that will replace current contents of the output area
# :type value: (str)
# :param visible: control visibility of element
# :type visible: (bool)
# """
# if not self._widget_was_created(): # if widget hasn't been created yet, then don't allow
# return
#
# if value is not None:
# self._TKOut.output.delete('1.0', tk.END)
# self._TKOut.output.insert(tk.END, value)
# if visible is False:
# self._pack_forget_save_settings(self._TKOut.frame)
# elif visible is True:
# self._pack_restore_settings(self._TKOut.frame)
#
# if visible is not None:
# self._visible = visible
#
# def get(self):
# """
# Returns the current contents of the output. Similar to Get method other Elements
# :return: the current value of the output
# :rtype: (str)
# """
# return self._TKOut.output.get(1.0, tk.END)
#
# def expand(self, expand_x=False, expand_y=False, expand_row=True):
# """
# Causes the Element to expand to fill available space in the X and Y directions. Can specify which or both directions
#
# :param expand_x: If True Element will expand in the Horizontal directions
# :type expand_x: (bool)
# :param expand_y: If True Element will expand in the Vertical directions
# :type expand_y: (bool)
# """
#
# if expand_x and expand_y:
# fill = tk.BOTH
# elif expand_x:
# fill = tk.X
# elif expand_y:
# fill = tk.Y
# else:
# return
#
# self._TKOut.output.pack(expand=True, fill=fill)
# self._TKOut.frame.pack(expand=True, fill=fill)
# self.ParentRowFrame.pack(expand=expand_row, fill=fill)
#
# def __del__(self):
# """
# Delete this element. Normally Elements do not have their delete method specified, but for this one
# it's important that the underlying TKOut object get deleted so that the stdout will get restored properly
# """
# self._TKOut.__del__()
# TKOut = tk_out
# Update = update
# Get = get
# ---------------------------------------------------------------------- #