|  | Commit message (Collapse) | Author | Lines | 
|---|
|  |  | 
|  |  | 
|  | The comments explain things that should be clear, or basic concepts | 
|  | Previously in some context inventory referred both to a single
"inventory" that we got from a remote objects.inv and to the internal
cog inventories. Always referring to the cog's inventories as plural
The update_single docstring was also changed from rebuild to build,
as the method doesn't handle anything with a preexisting inventory
with the same symbols being in the cog's inventories | 
|  |  | 
|  | The main simplification was getting rid of keeping track of string depth
which was unnecessary, as we can just always skip them as was being
done for strings inside of brackets.
The branching was also simplified to make sure less unnecessary checks
were being done with a bit less confusing elifs. | 
|  |  | 
|  | run_in_executor can provide args to the func it's passed in,
making the use of partial unnecessary. This will also make it more
convenient to move to asyncio.to_thread when the codebase is switched
to python 3.9 | 
|  | The tests import the modules the other way around causing a circular
import | 
|  |  | 
|  | The queue parsing doesn't depend on anything with redis,
so the await only delays the result being set on the future. | 
|  |  | 
|  | The items are added to the futures dict before a context switch can
occur, making the subsequent requests to the url skip the queue
extend and suspend at the future await | 
|  | Trailing commas were also added where missing | 
|  |  | 
|  |  | 
|  | As work is done on the modules the wrapper and wrapped functions are in
more conflicts can occur, previously this could be missed as the
info log that was done in case the error was suppressed was done when
modules were being initialized during which there is a logging spam. | 
|  | The scheduler shields the coroutine from cancellation so we can cancel
the scheduler's tasks inside of it to avoid the error from multiple
tasks with the same id trying to be scheduled which the manual tracking
of attempts solved
Co-authored-by: MarkKoz <[email protected]> | 
|  | This helps avoid subtracting the length of "Moved: " from the shorten
index
Co-authored-by: MarkKoz <[email protected]> | 
|  |  | 
|  | the 0.6.3 update brought a change that fails to ignore newlines in
the html, introducing unnecessary lines into the output | 
|  |  | 
|  | Previously the code deleted the entry of all of the DocItems of the page
after its contents were requested once, but this caused problems when
the cache was cleared when it expired.
Instead of deleting the entry to check if it should be queued on the
next item request, we keep it and create an entry in the
_item_futures dict for all items again and check for containment there.
To avoid populating the queue multiple times with the same item in some
cases the futures cleanup task will now only run when the queue is empty | 
|  | With a normal event, if multiple gets were suspended and a refresh
started, we'd continue the refresh after the first get finished and
set the event which would be the same behaviour as the one it tried
to fix. This is avoided by using a counter that's incremented every time
a context manager is entered around an event and only setting the event
when that counter reaches a zero after everything exited the context mgr | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  | Fixes BOT-KX | 
|  |  | 
|  | in_whitelist allow normal users also run commands in bot commands,
but branding commands should be mod+ only, so we need to use
has_any_role instead from discord.py. | 
|  |  | 
|  | The site can't handle huge syncs. Even a bulk patch of 10k users will
crash the service. Chunk the requests into groups of 1000 users and
await them sequentially. Testing showed that concurrent requests
are not scalable and would also crash the service. | 
|  | Whitelisted mod_meta and mod_tools as mod channels | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  | As the watch reason can contain private information, we shouldn't share it with the whole staff. | 
|  | To be able to set the attribute at the start of the coro we need to
be able to access the item's future before we know about all the other
items. This also saves us from having to add them all as the queue
parser or get_markdown will create the futures for us dynamically | 
|  | If an inventory refresh was started while the symbol embed coroutine
was suspended, it could cause the parser to try to fetch a non existent
future if the markdown was requested after it was cleared but before
new inventories were loaded in. | 
|  | When wrapper uses a global name, which conflicts with a global name
from wrapped's module that wrapped uses for its annotations, we run into
a situation that can't be solved without changing one of the names, so
an error is raised to give this clearer meaning.
The check may be erroneous in some edge cases or the objects the
conflicting names refer to can be functionally identical, so the error
can be turned into a logged warning. | 
|  | Shortening the renamed symbols string to 100 chars is not accurate
as the footer also contains a string before that, subtracting its length
fixes this. |