Merge pull request #2667 from PySimpleGUI/Dev-latest
NEW Multiline.print method - same as print_to_element. More tweaks t…
This commit is contained in:
		
						commit
						79286bb5b2
					
				
					 1 changed files with 91 additions and 18 deletions
				
			
		
							
								
								
									
										109
									
								
								PySimpleGUI.py
									
										
									
									
									
								
							
							
						
						
									
										109
									
								
								PySimpleGUI.py
									
										
									
									
									
								
							|  | @ -1,6 +1,6 @@ | ||||||
| #!/usr/bin/python3 | #!/usr/bin/python3 | ||||||
| 
 | 
 | ||||||
| version = __version__ = "4.16.6  Unreleased\n update_animation_no_buffering, popup_notify, removed TRANSPARENT_BUTTON, TabGroup now autonumbers keys, Table col width better size based on font, Table measure row height, Upgrade from GitHub utility" | version = __version__ = "4.16.7  Unreleased\n update_animation_no_buffering, popup_notify, removed TRANSPARENT_BUTTON, TabGroup now autonumbers keys, Table col width better size based on font, Table measure row height, Upgrade from GitHub utility (experimental), Multiline.print" | ||||||
| 
 | 
 | ||||||
| port = 'PySimpleGUI' | port = 'PySimpleGUI' | ||||||
| 
 | 
 | ||||||
|  | @ -1968,6 +1968,22 @@ class Multiline(Element): | ||||||
| 
 | 
 | ||||||
|         return self.TKText.get(1.0, tk.END) |         return self.TKText.get(1.0, tk.END) | ||||||
| 
 | 
 | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  |     def print(self, *args, end=None, sep=None, text_color=None, background_color=None): | ||||||
|  |         """ | ||||||
|  |         Print like Python normally prints except route the output to a multline element and also add colors if desired | ||||||
|  | 
 | ||||||
|  |         :param args: List[Any] The arguments to print | ||||||
|  |         :param end: (str) The end char to use just like print uses | ||||||
|  |         :param sep: (str) The separation character like print uses | ||||||
|  |         :param text_color: The color of the text | ||||||
|  |         :param background_color: The background color of the line | ||||||
|  |         """ | ||||||
|  |         print_to_element(self, *args, end=end, sep=sep, text_color=text_color, background_color=background_color) | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|     get = Get |     get = Get | ||||||
|     set_focus = Element.SetFocus |     set_focus = Element.SetFocus | ||||||
|     set_tooltip = Element.SetTooltip |     set_tooltip = Element.SetTooltip | ||||||
|  | @ -13758,6 +13774,10 @@ import sys | ||||||
| import site | import site | ||||||
| import os | import os | ||||||
| import requests | import requests | ||||||
|  | import shutil | ||||||
|  | import hashlib | ||||||
|  | import base64 | ||||||
|  | 
 | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
|  | @ -13767,22 +13787,30 @@ def _upgrade_from_github(): | ||||||
|     url = "https://raw.githubusercontent.com/PySimpleGUI/PySimpleGUI/master/" |     url = "https://raw.githubusercontent.com/PySimpleGUI/PySimpleGUI/master/" | ||||||
| 
 | 
 | ||||||
|     Pythonista = sys.platform == "ios" |     Pythonista = sys.platform == "ios" | ||||||
|  |     debug = False | ||||||
| 
 | 
 | ||||||
|     package = files[0].split('.py')[0] |     package = files[0].split(".py")[0] | ||||||
|     contents = {} |     contents = {} | ||||||
|     for file in files: |     for file in files: | ||||||
|         page = requests.get(url + file) |         page = requests.get(url + file) | ||||||
|  | 
 | ||||||
|         if page.status_code != 200: |         if page.status_code != 200: | ||||||
|             raise FileNotFoundError(file + ' not found on github. Nothing installed.') |             raise FileNotFoundError(file + " not found on github. Nothing installed.") | ||||||
|         contents[file] = page.text |         contents[file] = page.content | ||||||
| 
 | 
 | ||||||
|     sourcefile = files[0] |     sourcefile = files[0] | ||||||
| 
 | 
 | ||||||
|     version = None |     version = "-" | ||||||
|     for line in contents[sourcefile].split('\n'): |     for line in contents[sourcefile].decode("utf-8").split("\n"): | ||||||
|         line_split = line.split("__version__ =") |         line_split = line.split("__version__ =") | ||||||
|         if len(line_split) > 1: |         if len(line_split) > 1: | ||||||
|             version = line_split[-1].strip(" '\"") |             raw_version = line_split[-1].strip(" '\"") | ||||||
|  |             version = "" | ||||||
|  |             for c in raw_version: | ||||||
|  |                 if c in "0123456789-.": | ||||||
|  |                     version += c | ||||||
|  |                 else: | ||||||
|  |                     break | ||||||
|             break |             break | ||||||
| 
 | 
 | ||||||
|     if Pythonista: |     if Pythonista: | ||||||
|  | @ -13791,25 +13819,70 @@ def _upgrade_from_github(): | ||||||
|         if len(sp) != 2: |         if len(sp) != 2: | ||||||
|             print("unable to install") |             print("unable to install") | ||||||
|             exit() |             exit() | ||||||
|         path = sp[0] + documents + os.sep + "site-packages" + os.sep + package |         sitepackages_path = sp[0] + documents + os.sep + "site-packages" | ||||||
| 
 |  | ||||||
|     else: |     else: | ||||||
|         path = site.getsitepackages()[-1] + os.sep + package |         sitepackages_path = site.getsitepackages()[-1] + os.sep | ||||||
|  | 
 | ||||||
|  |     path = os.path.join(site.getsitepackages()[-1], package) | ||||||
| 
 | 
 | ||||||
|     if not os.path.isdir(path): |     if not os.path.isdir(path): | ||||||
|         os.makedirs(path) |         os.makedirs(path) | ||||||
| 
 | 
 | ||||||
|     for file in files: |     for file in files: | ||||||
|         with open(path + os.sep + file, 'w') as f: |         with open(os.path.join(path, file), "wb") as f: | ||||||
|             f.write(contents[sourcefile]) |             f.write(contents[file]) | ||||||
|  |         if debug: | ||||||
|  |             print("copy", file) | ||||||
| 
 | 
 | ||||||
|         print("copy", file) |     if "__init__.py" not in files: | ||||||
|  |         with open(os.path.join(path, "__init__.py"), "w") as f: | ||||||
|  |             f.write("from ." + package + " import *\n") | ||||||
|  |             if version is not None: | ||||||
|  |                 f.write("from ." + package + " import __version__\n") | ||||||
| 
 | 
 | ||||||
|     with open(path + os.sep + "__init__.py", "w") as initfile: |     if not Pythonista: | ||||||
|         initfile.write("from ." + package + " import *\n") |         for entry in os.listdir(sitepackages_path): | ||||||
|         if version is not None: |             if os.path.isdir(sitepackages_path + entry): | ||||||
|             initfile.write("from ." + package + " import __version__\n") |                 if entry.startswith(package) and entry.endswith(".dist-info"): | ||||||
|     print(package + " " + ("?" if version is None else version) + " successfully installed in " + path) |                     shutil.rmtree(sitepackages_path + entry) | ||||||
|  |         path_distinfo = path + "-" + ("unknown" if version is None else version) + ".dist-info" | ||||||
|  |         if not os.path.isdir(path_distinfo): | ||||||
|  |             os.makedirs(path_distinfo) | ||||||
|  |         with open(os.path.join(path_distinfo, "METADATA"), "w") as f:  # make a dummy METADATA file | ||||||
|  |             f.write("Name: " + package + "\n") | ||||||
|  |             f.write("Version: " + version + "\n") | ||||||
|  | 
 | ||||||
|  |         with open(os.path.join(path_distinfo, "INSTALLER"), "w") as f:  # make a dummy METADATA file | ||||||
|  |             f.write("github\n") | ||||||
|  |         with open(os.path.join(path_distinfo, "RECORD"), "w") as f: | ||||||
|  |             pass  # just to create the file to be recorded | ||||||
|  | 
 | ||||||
|  |         with open(os.path.join(path_distinfo, "RECORD"), "w") as record_file: | ||||||
|  | 
 | ||||||
|  |             for p in (path, path_distinfo): | ||||||
|  |                 for file in os.listdir(p): | ||||||
|  |                     full = os.path.join(p, file) | ||||||
|  |                     name = full[len(sitepackages_path) :].replace("\\", "/") | ||||||
|  |                     record_file.write(name + ",") | ||||||
|  |                     if file == "RECORD" and p == path_distinfo: | ||||||
|  |                         record_file.write(",") | ||||||
|  |                     else: | ||||||
|  |                         with open(os.path.join(p, file), "rb") as f: | ||||||
|  |                             contents = f.read() | ||||||
|  |                             hash = "sha256=" + base64.urlsafe_b64encode(hashlib.sha256(contents).digest()).decode( | ||||||
|  |                                 "latin1" | ||||||
|  |                             ).rstrip("=") | ||||||
|  |                             # hash calculation derived from wheel.py in pip | ||||||
|  | 
 | ||||||
|  |                             length = str(len(contents)) | ||||||
|  |                             record_file.write(hash + "," + length) | ||||||
|  | 
 | ||||||
|  |                     record_file.write("\n") | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  |     # print(package + " " + ("?" if version is None else version) + " successfully installed in " + path) | ||||||
|  | 
 | ||||||
|  |     popup(package, 'SUCCESSFULLY installed', 'Version ' + ("?" if version is None else version), 'Location installed:', path, keep_on_top=True, background_color='red', text_color='white') | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
| def main(): | def main(): | ||||||
|  |  | ||||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue