This file captures agent-specific guidance for working in the Weblate codebase.
For application-developer workflows and broader product integration guidance, use
docs/devel/ instead of repeating that material here.
- Weblate is a Django-based web translation platform with Celery background tasks.
- The primary stack is Python, Django, JavaScript, and HTML/CSS/Bootstrap.
- Follow existing Django patterns and project conventions.
- Prefer the repository's configured Ruff-based formatting and linting rules.
- Prefer type hints and use
from __future__ import annotationsin Python modules. - Use
TYPE_CHECKINGimports for type-only dependencies when that avoids runtime import cycles. - All user-facing strings must be translatable using Django i18n helpers.
- In templates, use
{% translate %}/{% blocktranslate %}for translatable text. - Preserve accessibility and the existing Bootstrap/jQuery-based frontend patterns.
- Write commit messages using the Conventional Commits format
<type>(<optional scope>): <description>. Common types includefeat,fix,docs,refactor,test,ci, andchore. Example:fix(translations): handle empty component slug. - Include the GPL-3.0-or-later license header in new Python files.
- Be careful with repository, webhook, and file-handling code; validate inputs and avoid introducing path traversal, command injection, or script injection risks.
- Handle VCS operations defensively and surface failures cleanly.
- Mock external VCS operations and API calls in tests.
- For user-visible changes, add a changelog entry to the top section of
docs/changes.rst.
- Install the development dependencies first using
uv sync --all-extras --dev. - After syncing, prefer
uv run ...for subsequent commands so they use the virtual environment created in.venv. If needed, you can also activate it withsource .venv/bin/activateor invoke tools from.venv/bin/. - Prefer
prek run --all-filesas the primary linting/formatting command because it runs the repository's configured pre-commit framework checks. prekis a third-party reimplementation of thepre-committool.- Use
pytestto run the test suite:pytest weblate. On a fresh checkout, first follow the local test setup indocs/contributing/tests.rst(DJANGO_SETTINGS_MODULE=weblate.settings_test,collectstatic, and test database prerequisites).scripts/test-database.shcan be sourced to set up the database connection variables such asCI_DB_USER,CI_DB_PASSWORD,CI_DB_HOST, andCI_DB_PORT. - Use
pylintto lint the Python code:pylint weblate/ - Use
mypyto type check the code:mypy weblate/ - All mentioned linting tools MUST pass.