Welcome to netrw
and thanks for your interest in contributing! During development please
make sure to keep the following checklists handy. They contain a summary of all
the important steps you need to take to contribute to the package. As a general statement,
the more familiar you already are with git(hub), the less relevant the detailed instructions
below will be for you.
There are multiple ways to contribute to netrw
(borrowed below list from here):
To report a bug in the package, open an issue at https://github.com/netsiphd/netrw/issues.
Please include in your bug report:
- Your operating system name and version.
- Any details about your local setup that might be helpful in troubleshooting.
- Detailed steps to reproduce the bug.
Look through the GitHub issues for bugs. Anything tagged with "bug" and "help wanted" is open to whoever wants to implement it.
Look through the GitHub issues for features. Anything tagged with "enhancement" and "help wanted" is open to whomever wants to implement it. If you know of a method that is implemented in another programming language, feel free to translate it into python here. If you don't want to translate it yourself, feel free to add an issue at https://github.com/netsiphd/netrw/issues. If you have read through this document and still have questions, also open an issue. When in doubt, open an issue.
Documentation is just as important as the code it documents. Please feel free to submit PRs that are focused on fixing, improving, correcting, or refactoring documentation. Documentation lives here.
The best way to send feedback is to open an issue at https://github.com/netsiphd/netrw/issues.
If you are proposing to implement a rewiring method, see more details below.
If you are proposing a feature not directly related to implementing a new method:
- Explain in detail why the feature is desirable and how it would work.
- Keep the scope as narrow as possible, to make it easier to implement.
- Remember that this is a volunteer-driven project, and that your contributions are welcome!
Often, python code for an algorithm of interest already exists. In the interest of avoiding repeated reinvention of the wheel, we welcome code from other sources being integrated into netrw
. If you are doing this, we ask that you be explicit and transparent about where the code came from and which license it is released under. The safest thing to do is copy the license from the original code into the header documentation of your file. For reference, this software is licensed under MIT. If you do not know the licencing on a particular repository, please reach out to the maintainer!
Before starting your contribution, you need to complete the following instructions once.
The goal of this process is to fork, download, and install the latest version of netrw
.
-
Log in to GitHub.
-
Fork this repository by pressing 'Fork' at the top right of this page. This will lead you to 'github.com/<your_account>/netrw'. We refer to this as your personal fork (or just 'your fork'), as opposed to this repository (github.com/netsiphd/netrw), which we refer to as the 'upstream repository'.
-
Clone your fork to your machine by opening a console and doing
git clone https://github.com/<your_account>/netrw.git
Make sure to clone your fork, not the upstream repo. This will create a directory called 'netrw/'. Navigate to it and execute
git remote add upstream https://github.com/netsiphd/netrw.git
In this way, your machine will know of both your fork (which git calls
origin
) and the upstream repository (upstream
). -
During development, you will probably want to play around with your code. For this, you need to install the
netrw
package and have it reflect your changes as you go along. For this, open the console and navigate to thenetrw/
directory, and executepip install -e .
From now on, you can open a Jupyter notebook, ipython console, or your favorite IDE from anywhere in your computer and type
import netrw
.
These steps need to be taken only once. Now anything you do in the netrw/
directory in your machine can be push
ed into your fork. Once it is in
your fork you can then request one of the organizers to pull
from your
fork into the upstream repository (by submitting a 'pull request'). More on this later!
Once you have completed the above steps, you are ready to choose an algorithm to implement and begin coding.
-
Choose which algorithm you are interested in working on.
-
Open an issue at https://github.com/netsiphd/netrw/issues by clicking the "New Issue" button.
- Title the issue "Implement XYZ method", where XYZ method is a shorthand name for the algorithm, feature, or utility that you plan to implement.
- Leave a comment that includes a brief motivation for why you want to see this method in
netrw
, as well as any key citations. - If such an issue already exists for the method you are going to write, it is not necessary to open another. However, it is a good idea to leave a comment letting others know you are going to work on it.
-
In your machine, create the file where your algorithm is going to live. Note to maintainers: The following text will change depedning on the ultimate package structure. If you chose a distance algorithm, copy an existing distance, such as
/netrw/distance/nbd.py
, intonetrw/distance/<algorithm_name>.py
. Similarly, if you chose a reconstruction algorithm, copy an existing reconstruction method intonetrw/reconstruction/<algorithm_name>.py
. Please keep in mind that <algorithm_name> will be used inside the code, so try to choose something that looks "pythonic". In particular, <algorithm_name> cannot include spaces, should not include upper case letters, and should use underscores rather than hyphens. -
Open the newly created file and edit as follows. At the very top you will find a string describing the algorithm. Note to maintainers: The following text will change depedning on the ultimate package structure. Edit this to describe the algorithm you are about to code, and preferably include a citation and link to any relevant papers. Also add your name and email address (optional). Do not delete the line
from .base import BaseDistance
orfrom .base import BaseReconstructor
. In the next line, change the class name to something appropriate. Guidelines here are to useCamelCaseLikeThis
and notsnake_case_like_this
. (These are python guidelines, not ours!) -
If you are implementing a distance method, you need to edit
netrw/distance/__init__.py
. Open it and add the following line:from .<your_file_name> import <YourAlgorithmName>
- Note: there is one dot (.) before <your_file_name>. This is important!
- Note: this line must go BEFORE the line with
__all__ = []
.
If you are implementing a reconstruction method, you need to edit
netrw/reconstruction/__init__.py
instead, with the same line.This line tells the
netrw
package where to find your code.
-
This project enforces a consistent coding style through the use of the Black autoformatter. Before committing your changes, please run Black to make sure your code passes our automated tests.
# if you don't have black installed on your system, just pip install: # pip install black black netrw/ black tests/
If you do not do this, our tests will likely fail and your code will not be merged without further changes.
-
We also want to make sure there are no unused imports; for that we'll use flake8. This is a general-purpose linter that we're using to catch unused imports and wildcard imports. You can probably check these manually, but our test suite will run this command:
# if you don't have flake8 installed on your system, just pip install: # pip install flake8 flake8 --select F401,F403 netrw/ flake8 --select F401,F403 tests/
And if there are any import warnings, it cause the tests to fail and will have to be fixed before merging.
-
After updating your local code, the first thing to do is tell git which files you have been working on. (This is called staging.) If you worked on a distance algorithm, for example, do
git add netrw/distance/<your_file> netrw/distance/__init__.py
-
Next tell git to commit (or save) your changes:
git commit -m 'Write a commit message here. This will be public and should be descriptive of the work you have done. Please be as explicit as possible, but at least make sure to include the name of the method you implemented. For example, the commit message may be: add implementation of SomeMethod, based on SomeAuthor and/or SomeCode.'
-
Now you have to tell git to do two things. First,
pull
the latest changes from the upstream repository (in case someone made changes while you were coding), thenpush
your changes and the updated code from your machine to your fork:git pull upstream main git push origin main
NOTE: If you edited already existing files, the
pull
may result in conflicts that must be merged. If you run in to trouble here, ask for help! -
Finally, you need to tell this (the upstream) repository to include your contributions. For this, we use the GitHub web interface. At the top of this page, there is a 'New Pull Request' button. Click on it, and it will take you to a page titled 'Compare Changes'. Right below the title, click on the blue text that reads 'compare across forks'. This will show four buttons. Make sure that the first button reads 'base fork: netsiphd/netrw', the second button reads 'base: main', the third button reads 'head fork: <your_username>/netrw', and the fourth button reads 'compare: main'. (If everything has gone according to plan, the only button you should have to change is the third one - make sure you find your username, not someone else's.) After you find your username, GitHub will show a rundown of the differences that you are adding to the upstream repository, so you will be able to see what changes you are contributing. If everything looks correct, press 'Create Pull Request'. NOTE: Advanced git users may want to develop on branches other than main on their fork. That is totally fine, we won't know the difference in the end anyway.
That's it! After you've completed these steps, maintainers will be notified and will review your code and changes to make sure that everything is in place. Some automated tests will also run in the background to make sure that your code can be imported correctly and other sanity checks. Once that is all done, one of us will either accept your Pull Request, or leave a message requesting some changes (you will receive an email either way).