2026-04-04 18:16:04 -07:00
# Contributing to MemPalace
Thanks for wanting to help. MemPalace is open source and we welcome contributions of all sizes — from typo fixes to new features.
## Getting Started
``` bash
2026-04-13 03:44:22 -03:00
# Fork the repo on GitHub first, then clone your fork
git clone https://github.com/<your-username>/mempalace.git
2026-04-04 18:16:04 -07:00
cd mempalace
2026-04-13 03:44:22 -03:00
git remote add upstream https://github.com/MemPalace/mempalace.git
2026-05-08 01:37:46 -03:00
# Recommended: uv (https://docs.astral.sh/uv/) handles the venv for you
uv sync --extra dev
# Or with pip in your own venv:
# pip install -e ".[dev]"
2026-04-04 18:16:04 -07:00
```
## Running Tests
``` bash
2026-05-08 01:37:46 -03:00
uv run pytest tests/ -v
2026-04-04 18:16:04 -07:00
```
All tests must pass before submitting a PR. Tests should run without API keys or network access.
## Running Benchmarks
``` bash
# Quick test (20 questions, ~30 seconds)
2026-05-08 01:37:46 -03:00
uv run python benchmarks/longmemeval_bench.py /path/to/longmemeval_s_cleaned.json --limit 20
2026-04-04 18:16:04 -07:00
# Full benchmark (500 questions, ~5 minutes)
2026-05-08 01:37:46 -03:00
uv run python benchmarks/longmemeval_bench.py /path/to/longmemeval_s_cleaned.json
2026-04-04 18:16:04 -07:00
```
See [benchmarks/README.md ](benchmarks/README.md ) for data download instructions and reproduction guide.
## Project Structure
```
mempalace/ ← core package (see mempalace/README.md for module guide)
benchmarks/ ← reproducible benchmark runners
hooks/ ← Claude Code auto-save hooks
examples/ ← usage examples
tests/ ← test suite
assets/ ← logo + brand
```
## PR Guidelines
1. Fork the repo and create a feature branch: `git checkout -b feat/my-thing`
2. Write your code
3. Add or update tests if applicable
2026-05-08 01:37:46 -03:00
4. Run `uv run pytest tests/ -v` — everything must pass
2026-04-04 18:16:04 -07:00
5. Commit with a clear message following [conventional commits ](https://www.conventionalcommits.org/ ):
- `feat: add Notion export format`
- `fix: handle empty transcript files`
- `docs: update MCP tool descriptions`
- `bench: add LoCoMo turn-level metrics`
2026-04-12 12:00:21 +05:00
6. Push to your fork and open a PR against `develop`
2026-04-04 18:16:04 -07:00
## Code Style
- **Formatting**: [Ruff ](https://docs.astral.sh/ruff/ ) with 100-char line limit (configured in `pyproject.toml` )
- **Naming**: `snake_case` for functions/variables, `PascalCase` for classes
- **Docstrings**: on all modules and public functions
- **Type hints**: where they improve readability
- **Dependencies**: minimize. ChromaDB + PyYAML only. Don't add new deps without discussion.
## Good First Issues
2026-04-12 12:00:21 +05:00
Check the [Issues ](https://github.com/MemPalace/mempalace/issues ) tab. Great starting points:
2026-04-04 18:16:04 -07:00
- **New chat formats**: Add import support for Cursor, Copilot, or other AI tool exports
- **Room detection**: Improve pattern matching in `room_detector_local.py`
- **Tests**: Increase coverage — especially for `knowledge_graph.py` and `palace_graph.py`
- **Entity detection**: Better name disambiguation in `entity_detector.py`
- **Docs**: Improve examples, add tutorials
## Architecture Decisions
If you're planning a significant change, open an issue first to discuss the approach. Key principles:
- **Verbatim first**: Never summarize user content. Store exact words.
- **Local first**: Everything runs on the user's machine. No cloud dependencies.
- **Zero API by default**: Core features must work without any API key.
2026-04-14 21:38:00 -03:00
- **Palace structure is scoping, not magic**: Wings, halls, and rooms act as metadata filters in the underlying vector store. They keep retrieval predictable when a palace holds many unrelated projects or people. Respect the hierarchy — but don't present it as a novel retrieval mechanism.
2026-04-04 18:16:04 -07:00
## Community
- **Discord**: [Join us ](https://discord.com/invite/ycTQQCu6kn )
- **Issues**: Bug reports and feature requests welcome
- **Discussions**: For questions and ideas
## License
MIT — your contributions will be released under the same license.