Check for image is bytes in Image.Update. Was crashing trying to get width. Changed upgrade code to use utllib version! Nice!

This commit is contained in:
PySimpleGUI 2020-03-06 13:09:19 -05:00
parent 8b9ddf404c
commit d750afcdbf
1 changed files with 130 additions and 101 deletions

View File

@ -1,6 +1,6 @@
#!/usr/bin/python3 #!/usr/bin/python3
version = __version__ = "4.16.13 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, fix padding lost with visibility, new upgrade utility, upgrade parameter" version = __version__ = "4.16.14 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, fix padding lost with visibility, new upgrade utility, upgrade parameter, switched to urllib"
port = 'PySimpleGUI' port = 'PySimpleGUI'
@ -3376,7 +3376,10 @@ class Image(Element):
else: else:
return return
if image is not None: if image is not None:
width, height = size[0] or image.width(), size[1] or image.height() if type(image) is not bytes:
width, height = size[0] or image.width(), size[1] or image.height()
else:
width, height = size
try: # sometimes crashes if user closed with X try: # sometimes crashes if user closed with X
self.tktext_label.configure(image=image, width=width, height=height) self.tktext_label.configure(image=image, width=width, height=height)
except: except:
@ -14482,11 +14485,13 @@ def _refresh_debugger():
import sys import sys
import site import site
import requests
import shutil import shutil
import hashlib import hashlib
import base64 import base64
from pathlib import Path from pathlib import Path
import configparser
import urllib.request
import urllib.error
def _install(files, url=None): def _install(files, url=None):
@ -14524,7 +14529,15 @@ def _install(files, url=None):
Otherwise, an __init__/py file will be generated. In thet case, if a __version__ = statement Otherwise, an __init__/py file will be generated. In thet case, if a __version__ = statement
is found in the source file, the __version__ will be included in that __init__.py file. is found in the source file, the __version__ will be included in that __init__.py file.
version 1.0.0 Version history
---------------
version 1.0.1 2020-03-04
now uses urllib instead of requests to avoid non standard libraries
installation for Pythonista improved
version 1.0.0 2020-03-04
initial version
(c)2020 Ruud van der Ham - www.salabim.org (c)2020 Ruud van der Ham - www.salabim.org
""" """
@ -14533,55 +14546,40 @@ def _install(files, url=None):
package = "?" package = "?"
path = "?" path = "?"
files_copied = [] files_copied = []
log = ''
info = Info() info = Info()
Pythonista = sys.platform == "ios" Pythonista = sys.platform == "ios"
if not files:
raise ValueError('no files specified')
if files[0][0] == '!':
raise ValueError('first item in files (sourcefile) may not be optional')
package = Path(files[0]).stem package = Path(files[0]).stem
sourcefile = files[0] sourcefile = files[0]
if Pythonista:
cwd = Path.cwd()
parts1 = []
for part in cwd.parts:
parts1.append(part)
if part == "Documents":
break
else:
raise EnvironmentError("unable to install")
sitepackages_path = Path(*parts1) / "site-packages"
else:
sitepackages_path = Path(site.getsitepackages()[-1])
path = sitepackages_path / package
file_contents = {} file_contents = {}
if url is None: for file in files:
for file in files: optional = file[0] == "!"
optional = file[0] == "!" if optional:
if optional: file = file[1:]
file = file[1:]
if Path(file).is_file(): if url:
try:
with urllib.request.urlopen(url + file) as response:
page = response.read()
# page = requests.get(url + file)
file_contents[file] = page
exists = True
except urllib.error.URLError:
exists = False
else:
exists = Path(file).is_file()
if exists:
with open(file, "rb") as f: with open(file, "rb") as f:
file_contents[file] = f.read() file_contents[file] = f.read()
else:
if not optional:
raise FileNotFoundError(file + " not found. Nothing installed.")
else: if (not exists) and (not optional):
for file in files: raise FileNotFoundError(file + " not found. Nothing installed.")
optional = file[0] == "!"
if optional:
file = file[1:]
page = requests.get(url + file)
if page.status_code == 200:
file_contents[file] = page.content
else:
if not optional:
raise FileNotFoundError(file + " not found on github. Nothing installed.")
version = "unknown" version = "unknown"
for line in file_contents[sourcefile].decode("utf-8").split("\n"): for line in file_contents[sourcefile].decode("utf-8").split("\n"):
@ -14596,68 +14594,99 @@ def _install(files, url=None):
break break
break break
if not path.is_dir(): info.files_copied = list(file_contents.keys())
path.mkdir()
for file, contents in file_contents.items():
with open(path / file, "wb") as f:
f.write(contents)
info.files_copied.append(file)
if "__init__.py" not in file_contents:
with open(path / "__init__.py", "w") as f:
f.write("from ." + package + " import *\n")
if version != "unknown":
f.write("from ." + package + " import __version__\n")
if not Pythonista:
for entry in sitepackages_path.glob("*"):
if entry.is_dir():
if entry.stem.startswith(package) and entry.suffix == ".dist-info":
shutil.rmtree(entry)
path_distinfo = Path(str(path) + "-" + version + ".dist-info")
if not path_distinfo.is_dir():
path_distinfo.mkdir()
with open(path_distinfo / "METADATA", "w") as f: # make a dummy METADATA file
f.write("Name: " + package + "\n")
f.write("Version: " + version + "\n")
with open(path_distinfo / "INSTALLER", "w") as f: # make a dummy METADATA file
f.write("github\n")
with open(path_distinfo / "RECORD", "w") as f:
pass # just to create the file to be recorded
with open(path_distinfo / "RECORD", "w") as record_file:
for p in (path, path_distinfo):
for file in p.glob("**/*"):
info.log += "{} {} {}".format(file, file.is_file(), file.is_dir())
if file.is_file():
name = str(file.relative_to(sitepackages_path)).replace("\\", "/")
record_file.write(name + ",")
if (file.stem == "RECORD" and p == path_distinfo) or ("__pycache__" in name.lower()):
record_file.write(",")
else:
with open(file, "rb") as f:
file_contents = f.read()
hash = "sha256=" + base64.urlsafe_b64encode(
hashlib.sha256(file_contents).digest()
).decode("latin1").rstrip("=")
# hash calculation derived from wheel.py in pip
length = str(len(file_contents))
record_file.write(hash + "," + length)
record_file.write("\n")
info.package = package info.package = package
info.version = version info.version = version
info.path = str(path) paths = []
file = '__init__.py'
if file not in file_contents:
file_contents[file] = ("from ." + package + " import *\n").encode()
if version != 'unknown':
file_contents[file] += ("from ." + package + " import __version__\n").encode()
if Pythonista:
cwd = Path.cwd()
parts1 = []
for part in cwd.parts:
parts1.append(part)
if part == "Documents":
break
else:
raise EnvironmentError("unable to install")
sitepackages_paths = [Path(*parts1) / ("site-packages" + ver) for ver in ("", "-2", "-3")]
else:
sitepackages_paths = [Path(site.getsitepackages()[-1])]
for sitepackages_path in sitepackages_paths:
path = sitepackages_path / package
paths.append(str(path))
if not path.is_dir():
path.mkdir()
for file, contents in file_contents.items():
with open(path / file, "wb") as f:
f.write(contents)
if Pythonista:
pypi_packages = sitepackages_path / '.pypi_packages'
config = configparser.ConfigParser()
config.read(pypi_packages)
config[package] = {}
config[package]['url'] = 'github'
config[package]['version'] = version
config[package]['summary'] = ''
config[package]['files'] = path.as_posix()
config[package]['dependency'] = ''
with pypi_packages.open('w') as f:
config.write(f)
else:
for entry in sitepackages_path.glob("*"):
if entry.is_dir():
if entry.stem.startswith(package) and entry.suffix == ".dist-info":
shutil.rmtree(entry)
path_distinfo = Path(str(path) + "-" + version + ".dist-info")
if not path_distinfo.is_dir():
path_distinfo.mkdir()
with open(path_distinfo / "METADATA", "w") as f: # make a dummy METADATA file
f.write("Name: " + package + "\n")
f.write("Version: " + version + "\n")
with open(path_distinfo / "INSTALLER", "w") as f: # make a dummy METADATA file
f.write("github\n")
with open(path_distinfo / "RECORD", "w") as f:
pass # just to create the file to be recorded
with open(path_distinfo / "RECORD", "w") as record_file:
for p in (path, path_distinfo):
for file in p.glob("**/*"):
if file.is_file():
name = file.relative_to(sitepackages_path).as_posix() # make sure we have slashes
record_file.write(name + ",")
if (file.stem == "RECORD" and p == path_distinfo) or ("__pycache__" in name.lower()):
record_file.write(",")
else:
with open(file, "rb") as f:
file_contents = f.read()
hash = "sha256=" + base64.urlsafe_b64encode(
hashlib.sha256(file_contents).digest()
).decode("latin1").rstrip("=")
# hash calculation derived from wheel.py in pip
length = str(len(file_contents))
record_file.write(hash + "," + length)
record_file.write("\n")
info.path = ','.join(paths)
return info return info
def _upgrade_from_github(): def _upgrade_from_github():
info = _install( info = _install(
files="PySimpleGUI.py !init.py".split(), url="https://raw.githubusercontent.com/PySimpleGUI/PySimpleGUI/master/" files="PySimpleGUI.py !init.py".split(), url="https://raw.githubusercontent.com/PySimpleGUI/PySimpleGUI/master/"