Comments (4)
I'll have a look at this. Let's add to this issue the integration into the CI of some linting validation at the same time. We can probably re-use directly the yaml file from the PyLossless project for that:
name: PEP8 Compliance, Spellcheck, & Docstring
on: pull_request
jobs:
linting:
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v3
- name: Set up Python 3.x
uses: actions/setup-python@v4
with:
python-version: "3.x"
- name: Install dependencies
run: pip install -r requirements_testing.txt
- name: Run flake8
run: flake8 pylossless docs --exclude pylossless/__init__.py
- name: Run Codespell
run: codespell pylossless docs --skip docs/source/generated
- name: Check Numpy Format Docstring
run: pydocstyle pylossless
from ipyniivue.
Just seen there is some linting done in build.yml. I'll look it up and integrate any addition step that could be useful.
from ipyniivue.
I'll note some issues here as I see them. I'll correct them as I see them and may end up merging these corrections through different PRs.
First note: mutable objects should never be given as default values. It can cause side effects that are very hard to detect.
For example, form nvmesh.py
class NVMesh:
#gl variable skipped because python
def __init__(self, input_dict={}, **kwargs):
kwargs.update(input_dict)
This would be better replaced with
For example, form nvmesh.py
class NVMesh:
#gl variable skipped because python
def __init__(self, input_dict=None, **kwargs):
if input_dict is None:
input_dict = {}
kwargs.update(input_dict)
What the hell, right? :)
from ipyniivue.
Second note: This is not a Python thing specifically, but if-elif without else can be somewhat dangerous, depending on the context. An example of that is the add_volume
method in niivue.py
. I was calling it with a Path object, and it was failing silently, just doing nothing. In this function, there is a block of code with an if-elif statement that processes the different types... but no else clause. So, this function was failing silently leaving the user puzzled about what was happening. The correct thing to do here is to add an else
block with a raise TypeError("The argument volume of blablabla accepts only arguments of types blablabla")
... I'll fix this one in my PR for issue #23 if I ever manage to get this working.
from ipyniivue.
Related Issues (20)
- ipyniivue installting correctly but viewer window not showing up
- a
- Graph features
- Add custom colormaps
- devDependency requirement on @jupyterlab/builder@^4.0.0
- load_meshes HOT 1
- Building documentation HOT 8
- load_meshes does not add the mesh to self.meshes in MacOS and Linux HOT 5
- Restarting the kernel fails to destroy the NiiVue object
- jupyterlab 4 support HOT 4
- ENH: Integration with MNE-Python
- Possible to add overlays and/or possibly saving the whole scene as .html file to harddrive?
- Prototype of ipyniivue using anywidget HOT 7
- Project admin, milestones, and roadmap
- Priorities HOT 6
- ☂️ Volume HOT 9
- Better camel/snake scale conversion HOT 10
- Exposing `nv.saveScene` on the python side HOT 1
- Deleting big files HOT 2
Recommend Projects
-
React
A declarative, efficient, and flexible JavaScript library for building user interfaces.
-
Vue.js
🖖 Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.
-
Typescript
TypeScript is a superset of JavaScript that compiles to clean JavaScript output.
-
TensorFlow
An Open Source Machine Learning Framework for Everyone
-
Django
The Web framework for perfectionists with deadlines.
-
Laravel
A PHP framework for web artisans
-
D3
Bring data to life with SVG, Canvas and HTML. 📊📈🎉
-
Recommend Topics
-
javascript
JavaScript (JS) is a lightweight interpreted programming language with first-class functions.
-
web
Some thing interesting about web. New door for the world.
-
server
A server is a program made to process requests and deliver data to clients.
-
Machine learning
Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.
-
Visualization
Some thing interesting about visualization, use data art
-
Game
Some thing interesting about game, make everyone happy.
Recommend Org
-
Facebook
We are working to build community through open source technology. NB: members must have two-factor auth.
-
Microsoft
Open source projects and samples from Microsoft.
-
Google
Google ❤️ Open Source for everyone.
-
Alibaba
Alibaba Open Source for everyone
-
D3
Data-Driven Documents codes.
-
Tencent
China tencent open source team.
from ipyniivue.