aboutsummaryrefslogtreecommitdiffstats
path: root/sticker/lib
diff options
context:
space:
mode:
authorTulir Asokan <tulir@maunium.net>2021-10-03 11:49:53 +0300
committerTulir Asokan <tulir@maunium.net>2021-10-03 11:49:53 +0300
commitf29c165357ed116ba0af2f8589ae0a10d959e7e2 (patch)
treec4ef23892f0bfd5d946bcaae7eae3f28fa177dcd /sticker/lib
parentec8eeeeaf526a122008aace7c71e5472bce832e6 (diff)
parent569d9815c65efe14e9ffba0899600a557269c7a6 (diff)
Merge remote-tracking branch 'aWeinzierl/fix-encoding'
Diffstat (limited to 'sticker/lib')
-rw-r--r--sticker/lib/util.py6
1 files changed, 4 insertions, 2 deletions
diff --git a/sticker/lib/util.py b/sticker/lib/util.py
index 240e8ea..2d58c82 100644
--- a/sticker/lib/util.py
+++ b/sticker/lib/util.py
@@ -13,6 +13,7 @@
#
# You should have received a copy of the GNU Affero General Public License
# along with this program. If not, see <https://www.gnu.org/licenses/>.
+from functools import partial
from io import BytesIO
import os.path
import json
@@ -21,6 +22,7 @@ from PIL import Image
from . import matrix
+open_utf8 = partial(open, encoding='UTF-8')
def convert_image(data: bytes) -> (bytes, int, int):
image: Image.Image = Image.open(BytesIO(data)).convert("RGBA")
@@ -41,7 +43,7 @@ def convert_image(data: bytes) -> (bytes, int, int):
def add_to_index(name: str, output_dir: str) -> None:
index_path = os.path.join(output_dir, "index.json")
try:
- with open(index_path) as index_file:
+ with open_utf8(index_path) as index_file:
index_data = json.load(index_file)
except (FileNotFoundError, json.JSONDecodeError):
index_data = {"packs": []}
@@ -49,7 +51,7 @@ def add_to_index(name: str, output_dir: str) -> None:
index_data["homeserver_url"] = matrix.homeserver_url
if name not in index_data["packs"]:
index_data["packs"].append(name)
- with open(index_path, "w") as index_file:
+ with open_utf8(index_path, "w") as index_file:
json.dump(index_data, index_file, indent=" ")
print(f"Added {name} to {index_path}")
send patches to the email below
yukais@pinapelz.com
include the subject [PATCH repo_name]
pinapelz.com
homepage