Skip to content

Latest commit

 

History

History
283 lines (214 loc) · 13.2 KB

CONTRIBUTING.md

File metadata and controls

283 lines (214 loc) · 13.2 KB

netrw

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.

Types of Contribution

There are multiple ways to contribute to netrw (borrowed below list from here):

Report Bugs

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.

Fix Bugs

Look through the GitHub issues for bugs. Anything tagged with "bug" and "help wanted" is open to whoever wants to implement it.

Implement Features or New Methods

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.

Improve Documentation

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.

Submit Feedback

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!
A Brief Note On Licensing

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!

Setup

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.

  1. Log in to GitHub.

  2. 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'.

  3. 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).

  4. 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 the netrw/ directory, and execute

    pip 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 pushed 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!

Before you start coding

Once you have completed the above steps, you are ready to choose an algorithm to implement and begin coding.

  1. Choose which algorithm you are interested in working on.

  2. 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.
  3. 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, into netrw/distance/<algorithm_name>.py. Similarly, if you chose a reconstruction algorithm, copy an existing reconstruction method into netrw/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.

  4. 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 or from .base import BaseReconstructor. In the next line, change the class name to something appropriate. Guidelines here are to use CamelCaseLikeThis and not snake_case_like_this. (These are python guidelines, not ours!)

  5. 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.

After you finish coding

  1. 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.

  2. 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.

  3. 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
    
  4. 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.'
    
  5. 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), then push 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!

  6. 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).