pydicom (use the most recent development version)
-
Fork the master branch of the project repository by clicking on the 'Fork' button near the top right of the page. This creates a copy of the repository under your GitHub user account. For more details on how to fork a repository see this guide.
-
Clone your fork to your local disk:
$ git clone [email protected]:YourLogin/pynetdicom.git $ cd pynetdicom
-
Create a new branch to hold your development changes:
$ git checkout -b my-branch
-
Develop the feature on your branch. Files can be added using
git add
and changes committed usinggit commit
. For more on using git see the Git documentation. -
When you're ready, push your changes to your GitHub account:
$ git push -u origin my-branch
-
You can then create a pull request using these instructions.
-
Please prefix the title of your pull request with
[WIP]
if its in progress and[MRG]
when you consider it complete and ready for review. -
When fixing bugs your first commit should be the addition of tests that reproduce the original issue and any related issues.
-
Use pytest to run the unit tests.
-
When adding features you should have complete documentation and 100% unit test coverage that covers not just the lines of code but ensure that the feature works as intended.
-
When writing documentation please reference the DICOM Standard where possible. When dealing with significant parts of the code base (
DIMSEMessage.decode_msg()
for example) you should have inline comments that reference both the DICOM Standard and explain in detail what the code is doing and why. -
Docstrings should follow the numpy docstring style.
PEP8 should be followed where it makes sense to do so. In addition there are a handful of project specific styles that should be used:
ae
for an ApplicationEntity objectacse
for the ACSE objectassoc
for an Association objectdimse
for the DIMSE object- Variable and function names should be
lower_case_underscore
, including acronyms such ascontext_id
anduid
. - Where a variable corresponds directly to a DICOM Data Element then use a name that is identical to the element keyword (i.e. the DIMSE command set elements such as MessageID and AffectedSOPClassUID correspond to attributes such as
C_STORE.MessageID
andC_STORE.AffectedSOPClassUID
).
- pylint
- pytest
Building the documentation requires:
- sphinx
- numpy
- matplotlib
- pillow
- pydicom
$ cd pynetdicom/docs
$ make html