File: contributing.md

package info (click to toggle)
pymatgen 2025.2.18%2Bdfsg1-5
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid, trixie
  • size: 85,888 kB
  • sloc: python: 176,173; javascript: 780; makefile: 221; sh: 78
file content (133 lines) | stat: -rw-r--r-- 5,749 bytes parent folder | download
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
---
layout: default
title: Contributing
nav_order: 6
---

# Recommended developer workflow

For developers interested in expanding `pymatgen` for their own purposes, we recommend forking `pymatgen` directly from
the [`pymatgen` GitHub repo](https://github.com/materialsproject/pymatgen). Here's a recommended workflow (updated Jun
2024):

1. Create a free GitHub account (if you don't already have one) and perform the necessary setup (e.g., install SSH keys
   etc.).

1. Fork the `pymatgen` GitHub repo, i.e., go to the
   main [`pymatgen` GitHub repo](https://github.com/materialsproject/pymatgen) and click fork to create a copy of
   the `pymatgen` code base on your own GitHub account.

1. Install `git` on your local machine (if you don't already have it).

1. Clone *your forked repo* to your local machine. You will work mostly with your local repo and only publish changes
   when they are ready to be merged:

    ```sh
    git clone https://github.com/<username>/pymatgen
    cd pymatgen  # Go into pmg directory.
    ```

   Note that the entire Github repo is fairly large because of the presence of test files, but these are necessary for
   rigorous testing.

1. Install the [uv package manager](https://github.com/astral-sh/uv):

    ```sh
    pip install uv
    ```

1. Create a virtual env for pymatgen.

    ```sh
    uv create venv  # A virtual env will be created in the .venv directory in the repo.
    source .venv/bin/activate
    ```

1. Install pymatgen in editable mode with dev and optional dependencies:

    ```sh
    uv pip install -e '.[ci,optional]'
    pre-commit install  # Install pre-commit hook for linters.
    ```

1. Make a new branch for your contributions

    ```sh
    git checkout -b my-new-fix-or-feature  # should be run from up-to-date master
    ```

1. Code (see [Coding Guidelines](#coding-guidelines)). Commit early and commit often. Keep your code up to date. You
   need to add the main repository to the list of your remotes.

    ```sh
    git remote add upstream https://github.com/materialsproject/pymatgen
    ```

   Make sure your repository is clean (no uncommitted changes) and is currently on the master branch. If not, commit or
   stash any changes and switch to the master.

    ```sh
    git checkout master
    ```

   Then you can pull all the new commits from the main line

    ```sh
    git pull upstream master
    ```

   Remember, pull is a combination of the commands fetch and merge, so there may be merge conflicts to be manually
   resolved.

1. Publish your contributions. Assuming that you now have a couple of commits that you would like to contribute to the
   main repository. Please follow the following steps:

    1. If your change is based on a relatively old state of the main repository, then you should probably bring your
       repository up-to-date first to see if the change is not creating any merge conflicts.

    1. Check that everything compiles cleanly and passes all tests. The `pymatgen` repo comes with a complete set of
       tests for all modules. If you have written new modules or methods, you must write tests for the new code as
       well (see [Coding Guidelines](#coding-guidelines)). Install and run `pytest` in your local repo directory and fix
       all errors before continuing further.

    1. If everything is ok, publish the commits to your GitHub repository.

    ```sh
    git push origin master
    ```

1. Now that your commit is published, it doesn't mean that it has already been merged into the main repository. You
   should issue a merge request to `pymatgen` maintainers. They will pull your commits and run their own tests before
   releasing.

"Work-in-progress" pull requests are encouraged, especially if this is your first time contributing to `pymatgen`, and
the maintainers will be happy to help or provide code review as necessary. Put "\[WIP\]" in the title of your pull
request to indicate it's not ready to be merged.

## Coding Guidelines

Given that `pymatgen` is intended to be a long-term code base, we adopt very strict quality control and coding
guidelines for all contributions to `pymatgen`. The following must be satisfied for your contributions to be accepted
into `pymatgen`.

1. **Unit tests** are required for all new modules and methods. The only way to minimize code regression is to ensure
   that all code is well tested. Untested contributions will not be accepted.
1. **Python PEP 8** [code style](https://python.org/dev/peps/pep-0008). We allow a few exceptions when they are
   well-justified (e.g., Element's atomic number is given a variable name of capital Z, in line with accepted scientific
   convention), but generally, PEP 8 must be observed. Code style will be automatically checked for all PRs and must
   pass before any PR is merged. To aid you, you can install and run the same set of formatters and linters that will
   run in CI using

   ```sh
   pre-commit install  # ensures linters are run prior to all future commits
   pre-commit run --files path/to/changed/files  # ensure your current uncommitted changes don't offend linters
   # or
   pre-commit run --all-files  # ensure your entire codebase passes linters
   ```

1. **Python 3**. Check the `pyproject.toml` for the supported Python versions.
1. **Documentation** is required for all modules, classes and methods. In particular, the method doc strings should make
   clear the arguments expected and the return values. For complex algorithms (e.g., an Ewald summation), a summary of
   the algorithm should be provided and preferably with a link to a publication outlining the method in detail.

For the above, if in doubt, please refer to the core classes in `pymatgen` for examples of what is expected.