From 7d37eb58bf836682a13ef6bb7aa66a8e09f383bb Mon Sep 17 00:00:00 2001 From: Myned Date: Tue, 21 Nov 2017 06:10:27 -0500 Subject: [PATCH 1/5] Fixed Save exception forcing user parameter --- src/main/misc/exceptions.py | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/main/misc/exceptions.py b/src/main/misc/exceptions.py index ecdcb1b..ae9af19 100644 --- a/src/main/misc/exceptions.py +++ b/src/main/misc/exceptions.py @@ -39,7 +39,7 @@ class Right(Exception): class Save(Exception): - def __init__(self, user): + def __init__(self, user=None): self.user = user From 7e6abef2a59852c2118ee9bab17a6d598019b949 Mon Sep 17 00:00:00 2001 From: Myned Date: Tue, 21 Nov 2017 06:11:09 -0500 Subject: [PATCH 2/5] Added score return for _get_pool --- src/main/cogs/booru.py | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/main/cogs/booru.py b/src/main/cogs/booru.py index 599a2c0..1c14b89 100644 --- a/src/main/cogs/booru.py +++ b/src/main/cogs/booru.py @@ -600,7 +600,7 @@ class MsG: posts_request = await u.fetch('https://{}.net/pool/show.json'.format(booru), params={'id': tempool['id'], 'page': page}, json=True) for post in posts_request['posts']: posts[post['id']] = {'artist': ', '.join( - post['artist']), 'file_url': post['file_url']} + post['artist']), 'file_url': post['file_url'], 'score': post['score']} page += 1 return pool, posts From dbaa930d57d3459abe0ee3e326ac4727bd9a6031 Mon Sep 17 00:00:00 2001 From: Myned Date: Tue, 21 Nov 2017 06:12:30 -0500 Subject: [PATCH 3/5] Added ability to cancel GoTo with an input of 0 --- src/main/cogs/booru.py | 63 ++++++++++++++++++++++++------------------ 1 file changed, 36 insertions(+), 27 deletions(-) diff --git a/src/main/cogs/booru.py b/src/main/cogs/booru.py index 1c14b89..4549c18 100644 --- a/src/main/cogs/booru.py +++ b/src/main/cogs/booru.py @@ -694,7 +694,7 @@ class MsG: return False def on_message(msg): - return msg.content.isdigit() and 1 <= int(msg.content) <= len(posts) and msg.author is ctx.author and msg.channel is ctx.channel + return msg.content.isdigit() and 0 <= int(msg.content) <= len(posts) and msg.author is ctx.author and msg.channel is ctx.channel try: kwargs = u.get_kwargs(ctx, args) @@ -756,14 +756,17 @@ class MsG: await paginator.edit(content='\N{INPUT SYMBOL FOR NUMBERS}') number = await self.bot.wait_for('message', check=on_message, timeout=7 * 60) - c = int(number.content) + if int(number.content) != 0: + c = int(number.content) + + embed.title = values[c - 1]['artist'] + embed.url = 'https://e621.net/post/show/{}'.format( + keys[c - 1]) + embed.set_footer(text='{} / {}'.format(c, len(posts)), + icon_url=self._get_score(values[c - 1]['score'])) + embed.set_image(url=values[c - 1]['file_url']) + await number.delete() - embed.title = values[c - 1]['artist'] - embed.url = 'https://e621.net/post/show/{}'.format( - keys[c - 1]) - embed.set_footer(text='{} / {}'.format(c, len(posts)), - icon_url=self._get_score(values[c - 1]['score'])) - embed.set_image(url=values[c - 1]['file_url']) await paginator.edit(content='\N{HEAVY BLACK HEART}' if keys[c - 1] in hearted.keys() else None, embed=embed) @@ -830,7 +833,7 @@ class MsG: return False def on_message(msg): - return msg.content.isdigit() and 1 <= int(msg.content) <= len(posts) and msg.author is ctx.author and msg.channel is ctx.channel + return msg.content.isdigit() and 0 <= int(msg.content) <= len(posts) and msg.author is ctx.author and msg.channel is ctx.channel try: kwargs = u.get_kwargs(ctx, args) @@ -892,17 +895,20 @@ class MsG: await paginator.edit(content='\N{BLACK RIGHTWARDS ARROW}') except exc.GoTo: - await paginator.edit(content='\N{INPUT SYMBOL FOR NUMBERS}') - number = await self.bot.wait_for('message', check=on_message, timeout=7 * 60) + await paginator.edit(content=f'`{c} / {len(posts)}`') + number = int(await self.bot.wait_for('message', check=on_message, timeout=7 * 60)) + + if int(number.content) != 0: + c = int(number.content) + + embed.title = values[c - 1]['artist'] + embed.url = 'https://e621.net/post/show/{}'.format( + keys[c - 1]) + embed.set_footer(text=values[c - 1]['score'], + icon_url=self._get_score(values[c - 1]['score'])) + embed.set_image(url=values[c - 1]['file_url']) - c = int(number.content) await number.delete() - embed.title = values[c - 1]['artist'] - embed.url = 'https://e621.net/post/show/{}'.format( - keys[c - 1]) - embed.set_footer(text='{} / {}'.format(c, len(posts)), - icon_url=self._get_score(values[c - 1]['score'])) - embed.set_image(url=values[c - 1]['file_url']) await paginator.edit(content='\N{HEAVY BLACK HEART}' if keys[c - 1] in hearted.keys() else None, embed=embed) @@ -993,7 +999,7 @@ class MsG: return False def on_message(msg): - return msg.content.isdigit() and 1 <= int(msg.content) <= len(posts) and msg.author is ctx.author and msg.channel is ctx.channel + return msg.content.isdigit() and 0 <= int(msg.content) <= len(posts) and msg.author is ctx.author and msg.channel is ctx.channel try: kwargs = u.get_kwargs(ctx, args) @@ -1055,17 +1061,20 @@ class MsG: await paginator.edit(content='\N{BLACK RIGHTWARDS ARROW}') except exc.GoTo: - await paginator.edit(content='\N{INPUT SYMBOL FOR NUMBERS}') + await paginator.edit(content=f'`{c} / {len(posts)}`') number = await self.bot.wait_for('message', check=on_message, timeout=7 * 60) - c = int(number.content) + if int(number.content) != 0: + c = int(number.content) + + embed.title = values[c - 1]['artist'] + embed.url = 'https://e926.net/post/show/{}'.format( + keys[c - 1]) + embed.set_footer(text=values[c - 1]['score'], + icon_url=self._get_score(values[c - 1]['score'])) + embed.set_image(url=values[c - 1]['file_url']) + await number.delete() - embed.title = values[c - 1]['artist'] - embed.url = 'https://e926.net/post/show/{}'.format( - keys[c - 1]) - embed.set_footer(text='{} / {}'.format(c, len(posts)), - icon_url=self._get_score(values[c - 1]['score'])) - embed.set_image(url=values[c - 1]['file_url']) await paginator.edit(content='\N{HEAVY BLACK HEART}' if keys[c - 1] in hearted.keys() else None, embed=embed) From 59c0f932296109b3b89aba8f6e47ff9cb11a56ef Mon Sep 17 00:00:00 2001 From: Myned Date: Tue, 21 Nov 2017 06:14:12 -0500 Subject: [PATCH 4/5] Fixed hearted assigning a reference instead of copying the embed --- src/main/cogs/booru.py | 17 +++++++++-------- 1 file changed, 9 insertions(+), 8 deletions(-) diff --git a/src/main/cogs/booru.py b/src/main/cogs/booru.py index 4549c18..5f4d237 100644 --- a/src/main/cogs/booru.py +++ b/src/main/cogs/booru.py @@ -7,6 +7,7 @@ from contextlib import suppress from datetime import datetime as dt from datetime import timedelta as td from fractions import gcd +import copy import discord as d from discord import errors as err @@ -729,12 +730,12 @@ class MsG: self.bot.wait_for('reaction_remove', check=on_reaction, timeout=7 * 60)]) except exc.Save: - if embed not in hearted: - hearted.append(embed) + if keys[c - 1] not in hearted: + hearted[keys[c - 1]] = copy.deepcopy(embed) await paginator.edit(content='\N{HEAVY BLACK HEART}') else: - hearted.remove(embed) + del hearted[keys[c - 1]] await paginator.edit(content='\N{BROKEN HEART}') @@ -871,8 +872,8 @@ class MsG: self.bot.wait_for('reaction_remove', check=on_reaction, timeout=7 * 60)]) except exc.Save: - if keys[c - 1] not in hearted: - hearted[keys[c - 1]] = embed + if keys[c - 1] not in hearted.keys(): + hearted[keys[c - 1]] = copy.deepcopy(embed) await paginator.edit(content='\N{HEAVY BLACK HEART}') else: @@ -1037,12 +1038,12 @@ class MsG: self.bot.wait_for('reaction_remove', check=on_reaction, timeout=7 * 60)]) except exc.Save: - if embed not in hearted: - hearted.append(embed) + if keys[c - 1] not in hearted: + hearted[keys[c - 1]] = copy.deepcopy(embed) await paginator.edit(content='\N{HEAVY BLACK HEART}') else: - hearted.remove(embed) + del hearted[keys[c - 1]] await paginator.edit(content='\N{BROKEN HEART}') From 4578cc53755a790b2b028d0281dd4303fc52109c Mon Sep 17 00:00:00 2001 From: Myned Date: Tue, 21 Nov 2017 06:15:25 -0500 Subject: [PATCH 5/5] Changed embed footer to show score (moved image number to GoTo) --- src/main/cogs/booru.py | 24 +++++++++--------------- 1 file changed, 9 insertions(+), 15 deletions(-) diff --git a/src/main/cogs/booru.py b/src/main/cogs/booru.py index 5f4d237..8b98ae8 100644 --- a/src/main/cogs/booru.py +++ b/src/main/cogs/booru.py @@ -812,9 +812,7 @@ class MsG: for embed in hearted.values(): await asyncio.sleep(self.RATE_LIMIT) - embed.footer.text = f'{n} / {len(hearted)}' - - await ctx.author.send(embed=embed) + await ctx.author.send(content=f'`{n} / {len(hearted)}`', embed=embed) n += 1 @cmds.command(name='e621page', aliases=['e621p', 'e6p', '6p']) @@ -856,7 +854,7 @@ class MsG: embed.set_image(url=values[c - 1]['file_url']) embed.set_author(name=formatter.tostring(tags, order=order), url='https://e621.net/post?tags={}'.format(','.join(tags)), icon_url=ctx.author.avatar_url) - embed.set_footer(text='{} / {}'.format(c, len(posts)), + embed.set_footer(text=values[c - 1]['score'], icon_url=self._get_score(values[c - 1]['score'])) paginator = await dest.send(embed=embed) @@ -887,7 +885,7 @@ class MsG: embed.title = values[c - 1]['artist'] embed.url = 'https://e621.net/post/show/{}'.format( keys[c - 1]) - embed.set_footer(text='{} / {}'.format(c, len(posts)), + embed.set_footer(text=values[c - 1]['score'], icon_url=self._get_score(values[c - 1]['score'])) embed.set_image(url=values[c - 1]['file_url']) @@ -928,7 +926,7 @@ class MsG: embed.title = values[c - 1]['artist'] embed.url = 'https://e621.net/post/show/{}'.format( keys[c - 1]) - embed.set_footer(text='{} / {}'.format(c, len(posts)), + embed.set_footer(text=values[c - 1]['score'], icon_url=self._get_score(values[c - 1]['score'])) embed.set_image(url=values[c - 1]['file_url']) @@ -973,9 +971,7 @@ class MsG: for embed in hearted.values(): await asyncio.sleep(self.RATE_LIMIT) - embed.footer.text = f'{n} / {len(hearted)}' - - await ctx.author.send(embed=embed) + await ctx.author.send(content=f'`{n} / {len(hearted)}`', embed=embed) n += 1 # @e621_paginator.error @@ -1022,7 +1018,7 @@ class MsG: embed.set_image(url=values[c - 1]['file_url']) embed.set_author(name=formatter.tostring(tags, order=order), url='https://e926.net/post?tags={}'.format(','.join(tags)), icon_url=ctx.author.avatar_url) - embed.set_footer(text='{} / {}'.format(c, len(posts)), + embed.set_footer(text=values[c - 1]['score'], icon_url=self._get_score(values[c - 1]['score'])) paginator = await dest.send(embed=embed) @@ -1053,7 +1049,7 @@ class MsG: embed.title = values[c - 1]['artist'] embed.url = 'https://e926.net/post/show/{}'.format( keys[c - 1]) - embed.set_footer(text='{} / {}'.format(c, len(posts)), + embed.set_footer(text=values[c - 1]['score'], icon_url=self._get_score(values[c - 1]['score'])) embed.set_image(url=values[c - 1]['file_url']) @@ -1094,7 +1090,7 @@ class MsG: embed.title = values[c - 1]['artist'] embed.url = 'https://e926.net/post/show/{}'.format( keys[c - 1]) - embed.set_footer(text='{} / {}'.format(c, len(posts)), + embed.set_footer(text=values[c - 1]['score'], icon_url=self._get_score(values[c - 1]['score'])) embed.set_image(url=values[c - 1]['file_url']) @@ -1139,9 +1135,7 @@ class MsG: for embed in hearted.values(): await asyncio.sleep(self.RATE_LIMIT) - embed.footer.text = f'{n} / {len(hearted)}' - - await ctx.author.send(embed=embed) + await ctx.author.send(content=f'`{n} / {len(hearted)}`', embed=embed) n += 1 # Searches for and returns images from e621.net given tags when not blacklisted