mirror of
				https://github.com/Rapptz/discord.py.git
				synced 2025-10-26 02:53:07 +00:00 
			
		
		
		
	
		
			
				
	
	
		
			65 lines
		
	
	
		
			2.5 KiB
		
	
	
	
		
			ReStructuredText
		
	
	
	
	
	
			
		
		
	
	
			65 lines
		
	
	
		
			2.5 KiB
		
	
	
	
		
			ReStructuredText
		
	
	
	
	
	
| .. currentmodule:: discord
 | |
| 
 | |
| .. _ext_commands_extensions:
 | |
| 
 | |
| Extensions
 | |
| =============
 | |
| 
 | |
| There comes a time in the bot development when you want to extend the bot functionality at run-time and quickly unload and reload code (also called hot-reloading). The command framework comes with this ability built-in, with a concept called **extensions**.
 | |
| 
 | |
| Primer
 | |
| --------
 | |
| 
 | |
| An extension at its core is a python file with an entry point called ``setup``. This setup must be a plain Python function (not a coroutine). It takes a single parameter -- the :class:`~.commands.Bot` that loads the extension.
 | |
| 
 | |
| An example extension looks like this:
 | |
| 
 | |
| .. code-block:: python3
 | |
|     :caption: hello.py
 | |
|     :emphasize-lines: 7,8
 | |
| 
 | |
|     from discord.ext import commands
 | |
| 
 | |
|     @commands.command()
 | |
|     async def hello(ctx):
 | |
|         await ctx.send('Hello {0.display_name}.'.format(ctx.author))
 | |
| 
 | |
|     def setup(bot):
 | |
|         bot.add_command(hello)
 | |
| 
 | |
| In this example we define a simple command, and when the extension is loaded this command is added to the bot. Now the final step to this is loading the extension, which we do by calling :meth:`.commands.Bot.load_extension`. To load this extension we call ``bot.load_extension('hello')``.
 | |
| 
 | |
| .. admonition:: Cogs
 | |
|     :class: helpful
 | |
| 
 | |
|     Extensions are usually used in conjunction with cogs. To read more about them, check out the documentation, :ref:`ext_commands_cogs`.
 | |
| 
 | |
| .. note::
 | |
| 
 | |
|     Extension paths are ultimately similar to the import mechanism. What this means is that if there is a folder, then it must be dot-qualified. For example to load an extension in ``plugins/hello.py`` then we use the string ``plugins.hello``.
 | |
| 
 | |
| Reloading
 | |
| -----------
 | |
| 
 | |
| When you make a change to the extension and want to reload the references, the library comes with a function to do this for you, :meth:`Bot.reload_extension`.
 | |
| 
 | |
| .. code-block:: python3
 | |
| 
 | |
|     >>> bot.reload_extension('hello')
 | |
| 
 | |
| Once the extension reloads, any changes that we did will be applied. This is useful if we want to add or remove functionality without restarting our bot. If an error occurred during the reloading process, the bot will pretend as if the reload never happened.
 | |
| 
 | |
| Cleaning Up
 | |
| -------------
 | |
| 
 | |
| Although rare, sometimes an extension needs to clean-up or know when it's being unloaded. For cases like these, there is another entry point named ``teardown`` which is similar to ``setup`` except called when the extension is unloaded.
 | |
| 
 | |
| .. code-block:: python3
 | |
|     :caption: basic_ext.py
 | |
| 
 | |
|     def setup(bot):
 | |
|         print('I am being loaded!')
 | |
| 
 | |
|     def teardown(bot):
 | |
|         print('I am being unloaded!')
 |