Contributions are welcome, and they are greatly appreciated. Every little bit helps, and credit will always be given.
You can contribute in many ways:
Report bugs at https://github.com/equinor/fmu-ensemble/issues.
If you are reporting a bug, please include:
- 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 Git issues for bugs. Anything tagged with "bug" and "help wanted" is open to whoever wants to implement it.
Look through the Git issues for features. Anything tagged with "enhancement" and "help wanted" is open to whoever wants to implement it.
fmu-ensemble could always use more documentation, whether as part of the official fmu-ensemble docs, in docstrings, or even on the web in blog posts, articles, and such.
The best way to send feedback is to file an issue at https://github.com/equinor/fmu-ensemble/issues.
If you are proposing a feature:
- Explain in detail how it would work.
- Keep the scope as narrow as possible, to make it easier to implement.
It is very important to be complient to code standards. A summary:
- Use PEP8 standard (https://www.python.org/dev/peps/pep-0008/) and PEP20 philosophy, with line length set 88.
- Use the source code formatter black (https://github.com/python/black)
- Naming: files_as_this, ClassesAsThis, ExceptionsAsThis, CONSTANTS, function_as_this, method_as_this
- Use a single underscore to protect instance variables, other private variables and and private classes
- 4 space indents (spaces, no tabs)
- One space before and after =, +, * etc
- No space around = in keyword lists, e.g. my_function(value=27, default=None)
- Avoid one or two letter variables, even for counters. And meaningful names, but don't overdo it.
- Start with documentation and tests. Think and communicate first!
- Docstrings shall start and end with """.
- Use pytest as testing engine
- Code shall be be Python 2.7.13 + and python 3.4 + compliant
python -m flake8 mycode.py
make flake # for all
The pylint is rather strict and sometimes exceptions are needed... , but anyway quite useful!
python -m pylint mycode.py
make lint # for all