2024-08-28 13:35:21 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								# AutoGen Python packages
  
						 
					
						
							
								
									
										
										
										
											2024-06-20 15:19:56 -04:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2024-11-26 11:04:59 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								[](https://microsoft.github.io/autogen/dev/)
							 
						 
					
						
							
								
									
										
										
										
											2024-12-10 08:28:48 -08:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								[](https://pypi.org/project/autogen-core/0.4.0.dev11/) [](https://pypi.org/project/autogen-agentchat/0.4.0.dev11/) [](https://pypi.org/project/autogen-ext/0.4.0.dev11/)
							 
						 
					
						
							
								
									
										
										
										
											2024-08-29 09:46:06 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2024-11-26 11:04:59 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								This directory works as a single `uv`  workspace containing all project packages. See [`packages` ](./packages/ ) to discover all project packages.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2024-08-29 09:46:06 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								## Development
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								**TL;DR**, run all checks with:
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								```sh
							 
						 
					
						
							
								
									
										
										
										
											2024-11-11 12:23:25 -08:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								uv sync --all-extras
							 
						 
					
						
							
								
									
										
										
										
											2024-08-29 09:46:06 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								source .venv/bin/activate
							 
						 
					
						
							
								
									
										
										
										
											2024-08-29 17:58:00 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								poe check
							 
						 
					
						
							
								
									
										
										
										
											2024-08-29 09:46:06 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								```
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								### Setup
  
						 
					
						
							
								
									
										
										
										
											2024-11-27 14:39:31 -08:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2024-11-11 12:23:25 -08:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								`uv`  is a package manager that assists in creating the necessary environment and installing packages to run AutoGen. 
						 
					
						
							
								
									
										
										
										
											2024-11-27 14:39:31 -08:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2024-08-29 09:46:06 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								-  [Install `uv` ](https://docs.astral.sh/uv/getting-started/installation/ ). 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2024-11-11 12:23:25 -08:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								### Virtual Environment
  
						 
					
						
							
								
									
										
										
										
											2024-11-27 14:39:31 -08:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2024-11-11 12:23:25 -08:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								During development, you may need to test changes made to any of the packages.\
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								To do so, create a virtual environment where the AutoGen packages are installed based on the current state of the directory.\
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								Run the following commands at the root level of the Python directory:
							 
						 
					
						
							
								
									
										
										
										
											2024-08-29 09:46:06 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								```sh
							 
						 
					
						
							
								
									
										
										
										
											2024-11-11 12:23:25 -08:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								uv sync --all-extras
							 
						 
					
						
							
								
									
										
										
										
											2024-08-29 09:46:06 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								source .venv/bin/activate
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								```
							 
						 
					
						
							
								
									
										
										
										
											2024-11-27 14:39:31 -08:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2024-11-11 12:23:25 -08:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								-  `uv sync --all-extras`  will create a `.venv`  directory at the current level and install packages from the current directory along with any other dependencies. The `all-extras`  flag adds optional dependencies. 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								-  `source .venv/bin/activate`  activates the virtual environment. 
						 
					
						
							
								
									
										
										
										
											2024-08-29 09:46:06 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2024-11-11 12:23:25 -08:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								### Common Tasks
  
						 
					
						
							
								
									
										
										
										
											2024-11-27 14:39:31 -08:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2024-11-11 12:23:25 -08:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								To create a pull request (PR), ensure the following checks are met. You can run each check individually:
							 
						 
					
						
							
								
									
										
										
										
											2024-11-27 14:39:31 -08:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2024-08-29 09:46:06 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								-  Format: `poe format`  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								-  Lint: `poe lint`  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								-  Test: `poe test`  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								-  Mypy: `poe mypy`  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								-  Pyright: `poe pyright`  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								-  Build docs: `poe --directory ./packages/autogen-core/ docs-build`  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								-  Auto rebuild+serve docs: `poe --directory ./packages/autogen-core/ docs-serve`  
						 
					
						
							
								
									
										
										
										
											2024-11-11 12:23:25 -08:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								Alternatively, you can run all the checks with:
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								-  `poe check`  
						 
					
						
							
								
									
										
										
										
											2024-08-29 09:46:06 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								>  [!NOTE]
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								>  These need to be run in the virtual environment.
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2024-11-11 12:23:25 -08:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								### Creating a New Package
  
						 
					
						
							
								
									
										
										
										
											2024-08-29 10:29:12 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2024-11-11 12:23:25 -08:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								To create a new package, similar to `autogen-core`  or `autogen-chat` , use the following:
							 
						 
					
						
							
								
									
										
										
										
											2024-08-29 10:29:12 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								```sh
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								uv sync
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								source .venv/bin/activate
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								cookiecutter ./templates/new-package/
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								```