diff --git a/.readthedocs.yml b/.readthedocs.yml
new file mode 100644
index 000000000..3f080017d
--- /dev/null
+++ b/.readthedocs.yml
@@ -0,0 +1,14 @@
+---
+version: 2
+
+build:
+ os: "ubuntu-22.04"
+ tools:
+ python: "mambaforge-latest"
+ jobs:
+ pre_build:
+ # add cloned repository to python importable paths
+ - 'echo "$(pwd)" >> $(python -c "import sysconfig;print(sysconfig.get_paths()[\"purelib\"])")/workdir.pth'
+
+conda:
+ environment: docs/environment.yml
diff --git a/Dockerfile b/Dockerfile
index f0130d357..3c65ab939 100644
--- a/Dockerfile
+++ b/Dockerfile
@@ -1,4 +1,4 @@
-ARG BASE_IMAGE
+ARG BASE_IMAGE=nansencenter/nansat_base
FROM ${BASE_IMAGE}
# Necessary to access the BASE_IMAGE variable during the build
ARG BASE_IMAGE
diff --git a/build_container.sh b/build_container.sh
index cbbefae87..3eac7931a 100755
--- a/build_container.sh
+++ b/build_container.sh
@@ -1,9 +1,9 @@
#!/bin/bash
# build container only with Python libraries in conda
-docker build . -t nansat -f docker/Dockerfile_nansat
+docker build . -t nansat
# compile Nansat in current host directory
-docker run --rm -it -v `pwd`:/src nansat python setup.py build_ext --inplace
+docker run --rm -it -v `pwd`:/src nansat pip install -e /src
# remove container (if it exists)
docker rm nansat 2> /dev/null
diff --git a/docs/source/installation.rst b/docs/source/installation.rst
index a0005997e..67ad90d8a 100644
--- a/docs/source/installation.rst
+++ b/docs/source/installation.rst
@@ -14,7 +14,7 @@ The fastest way to install nansat:
# activate environment
source activate py3nansat
# install nansat
- pip instal nansat
+ pip install nansat
Nansat is now installed.
For more details and other methods of installing Nansat, see below.
@@ -24,7 +24,7 @@ Requirements
Nansat requires the following packages:
-* Python 2.7 or higher
+* Python 3.7 or higher
* `Numpy `_ >=1.11.3
* `GDAL `_ >=2.2.3
* `Pillow `_ >=4.0.0
@@ -37,7 +37,7 @@ The following packages are optional:
* Some mappers will not work without scipy. E.g. *sentinel1_l1*
-* `Matplotlib `_ >=2.1.1
+* `Matplotlib `_ >=2.1.1,<3.9
* matplotlib is required for Nansat methods *digitize_points()* and *crop_interactive()*
@@ -75,11 +75,9 @@ This is the recommended approach for installing dependencies.
* *conda create -n nansat Python=3.6*
- * Or use Python version 3.5 or 2.7 if you need those versions.
-
* *source activate nansat*
- * On windows you would ommit 'source' and just run *'activate nansat'*
+ * On windows you would omit 'source' and just run *'activate nansat'*
* *conda install --yes -c conda-forge pythesint numpy scipy=0.18.1 matplotlib basemap netcdf4 gdal
pillow urllib3*
@@ -92,13 +90,13 @@ following procedure can be used to install dependencies with *apt* and *pip*.
.. code-block:: bash
- sudo apt install virtualenv libgdal1-dev python-dev python-gdal python-numpy python-scipy \
- python-matplotlib python-mpltoolkits.basemap python-requests
+ sudo apt install -y virtualenv libgdal-dev gdal-bin python3
cd
- virtualenv --no-site-packages nansat_env
+ virtualenv nansat_env
source ~/nansat_env/bin/activate
- export PYTHONPATH=/usr/lib/python2.7/dist-packages/
- pip install pythesint pillow netcdf4 urllib3
+ pip install pythesint pillow netcdf4 urllib3 requests "gdal==$(gdal-config --version)" numpy \
+ scipy 'matplotlib<3.9' setuptools basemap
+
Compile and Build Yourself
^^^^^^^^^^^^^^^^^^^^^^^^^^
@@ -109,12 +107,25 @@ free to do so. If you need some aid, we would recommend you to look at how the c
Installing Nansat
-----------------
+Install with pip (preferred method)
+^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
+
+Run the following command:
+
+::
+
+ pip install nansat
+
+Nansat will then be added to your site-packages and can be used like any regular Python package.
+
+
Install Nansat from source
^^^^^^^^^^^^^^^^^^^^^^^^^^
If you want to install Nansat from source, you first need to install all requirements.
Then proceed with one of the following methods
+
Install from git repository
"""""""""""""""""""""""""""
@@ -123,19 +134,9 @@ git clone the master (most stable) or develop (cutting edge) branch, and install
.. code-block:: bash
git clone https://github.com/nansencenter/nansat.git
- checkout master (or develop, or a specific tag or branch)
- python setup.py install
-
-Nansat will then be added to your site-packages and can be used like any regular Python package.
-
-Install with pip
-""""""""""""""""
-
-Run the following command:
-
-::
-
- pip install nansat
+ cd nansat
+ git checkout master (or a specific tag or branch)
+ pip install .
Nansat will then be added to your site-packages and can be used like any regular Python package.
@@ -147,14 +148,14 @@ Nansat will then be added to your site-packages and can be used like any regular
Also update the link to "simplest way to install Nansat" in basic info.
Special install for Nansat Developers
-^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
+"""""""""""""""""""""""""""""""""""""
If you are working directly on the Nansat source, you need to install Nansat in the following way.
-Git clone the develop branch (or another branch you are working on), and do:
+Git clone the branch you are working on, and run the following command from the nansat directory:
::
- python setup.py build_ext --inplace
+ pip install -e .
The pixel functions C module is then compiled but no code is copied to site-packages and no linking
is performed. Make sure to follow the `Nansat conventions `_ if you want to
@@ -165,7 +166,7 @@ easily be done with
::
- pip install nose mock
+ pip install mock
Use a self-provisioned Virtual Machine
@@ -204,7 +205,7 @@ and running of Nansat. A user can start using the production version of Nansat D
::
- docker run --rm -it -v /path/to/data:/data akorosov/nansat ipython
+ docker run --rm -it -v /path/to/data:/data nansencenter/nansat ipython
This will mound directory /path/to/data on your host to the directory /data in the container
and launch IPython where Nansat is available.
@@ -216,7 +217,7 @@ do the following steps:
::
- docker run --rm -it -v `pwd`:/src akorosov/nansat python setup.py build_ext --inplace
+ docker run --rm -it -v `pwd`:/src nansencenter/nansat_base pip install -e .
2. Run container with mounting of the current directory into /src. In this case Python
will use Nansat from /src/nansat (the directory shared between host and container):
@@ -224,17 +225,17 @@ will use Nansat from /src/nansat (the directory shared between host and containe
::
# launch Python with Nansat in container
- docker run --rm -it -v `pwd`:/src akorosov/nansat python
+ docker run --rm -it -v `pwd`:/src nansencenter/nansat_base python
- # ...or run nosetests
- docker run --rm -it -v `pwd`:/src akorosov/nansat nosetests nansat
+ # ...or run tests
+ docker run --rm -it -v `pwd`:/src nansencenter/nansat_base python -m unittest discover nansat.tests
-Alternatively you can run the script *build_containr.sh*. The script will build the image with
+Alternatively you can run the script *build_container.sh*. The script will build the image with
Python libraries from Anaconda, compile the Nansat code inplace and create a
container for running Nansat. You can then start container:
::
docker start -i nansat
- # and run nosetests:
- (base) root@d1625f2ce873:~# nosetests nansat
+ # and run tests:
+ (base) root@d1625f2ce873:~# python -m unittest discover nansat.tests
diff --git a/readthedocs.yml b/readthedocs.yml
deleted file mode 100644
index 004a03aec..000000000
--- a/readthedocs.yml
+++ /dev/null
@@ -1,2 +0,0 @@
-conda:
- file: docs/environment.yml