# Contributors' Guide This guide will help familiarize contributors to the `containerd/containerd` repository. ## Prerequisite First read the containerd project's [general guidelines around contribution](https://github.com/containerd/project/blob/main/CONTRIBUTING.md) which apply to all containerd projects. ## Getting started See [`BUILDING.md`](https://github.com/containerd/containerd/blob/main/BUILDING.md) for instructions for setting up a development environment. If you are also a new user to containerd, you can first check out the [_Getting started with containerd_](https://github.com/containerd/containerd/blob/main/docs/getting-started.md) guide. ## Setting up your local environment At a minimum, the dev tools from `script/setup/install-dev-tools` should be installed. Run `make install-deps` to install dependencies used for running and developing the CRI plugin. Other install scripts under `script/setup` may need to be run depending on your environment and your preference for installing libraries and dependencies. The versions used by `containerd/containerd` CI can be found in `script/setup` and referred to if installing manually. ``` $ script/setup/install-dev-tools $ make install-deps ``` ## Automated and AI-generated contributions Pull requests must be opened by a human. Any use of automation to create pull requests must be approved by a maintainer. Accounts creating pull requests using automation without prior approval may be restricted from the containerd organization. All AI-generated or AI-assisted submissions — whether code, PR descriptions, or comments — must be reviewed by the human author before being submitted. The human author is responsible for the correctness and quality of all content in their pull request and any associated comments. ## Code style - Go files adhere to standard Go formatting and styling - Protobuf files use tabs for indentation - Other files must not contain trailing whitespace and should end with a single new line character Use the `check` command in the makefile to verify your code matches the expected style. ``` make check ``` ## Updating protobuf files Ensure protoc and dev tools have been installed, then run `make protos` > **Note** > When running `make protos`, the current working directory should be found under the `GOPATH` environment > variable to ensure protoc can properly resolve the paths of protofiles in the project. ## Naming packages Package names should be short and simple. Avoid using `_` and repeating words from parent directories. ### Where to put packages Try to put a new package under the appropriate root directories. The root directory is reserved for configuration and build files, no source files will be accepted in root since containerd v2.0. - `api` - All protobuf service definitions and types used by services - `bin` - Autogenerated during build, do not check in file here - `client` - All Go files for the containerd client (formerly in `containerd/containerd` root in 1.x) - `cmd` - All Go main packages and the packages used only for that main package - `contrib` - Files, configurations, and packages related to external tools or libraries - `core` - Core Go packages with interface definitions and built-in implementations - `docs` - All containerd technical documentation using markdown - `internal` - All utility packages used by containerd and not intended for direct import - `man`- All containerd reference manuals used for the `man` command - `pkg` - Non-core Go packages used by clients and other containerd packages - `plugins` - All included containerd plugins which are registered via init - `releases` - All release note files - `script` - All scripts used for testing, development, and CI - `test` - Test scripts used for external end to end testing of containerd, do not add new files here - `vendor` - Autogenerated vendor files from `make vendor` command, do not manually edit files here - `version` - Version package with the current containerd version