From 3c0425b45ceab4d175e8f928da4ff3cb03232880 Mon Sep 17 00:00:00 2001
From: dave <dave@dtu.dk>
Date: Mon, 5 Dec 2016 14:08:28 +0100
Subject: [PATCH] docs: update developer guide instructions to submit package
 to PyPi

---
 docs/developer-guide.md | 37 ++++++++++++++++++++++++++++++++-----
 1 file changed, 32 insertions(+), 5 deletions(-)

diff --git a/docs/developer-guide.md b/docs/developer-guide.md
index ab2588c..323278f 100644
--- a/docs/developer-guide.md
+++ b/docs/developer-guide.md
@@ -3,6 +3,7 @@
 Thank you for your interest in developing wetb. This guide details how to
 contribute to wetb in a way that is efficient for everyone.
 
+
 ## Contents
 
 - [Fork](#Fork-project)
@@ -17,6 +18,7 @@ contribute to wetb in a way that is efficient for everyone.
 
 
 ## Fork project
+
 We prefer that you make your contributions in your own fork of the project,
 [make your changes](#Contributions) and [make a merge request](#Upload contributions).
 
@@ -26,6 +28,7 @@ the [frontpage](https://gitlab.windenergy.dtu.dk/toolbox/WindEnergyToolbox)
 
 ## Requirements
 
+
 ### Command line
 
 This guide will use the command line (aka command prompt) frequently.
@@ -58,6 +61,7 @@ is a gui integrated into the windows explorer.
 For all platforms we recommend that you download and install the Anaconda -
 a professional grade, full blown scientific Python distribution.
 
+
 ### Installing Anaconda, activate root environment
 
 * Download and install Anaconda (Python 3.5 version, 64 bit installer is
@@ -167,7 +171,9 @@ or via tortoise-git:
 - "Git Clone..."
 - \<Ok\>
 
+
 ## Install wetb
+
 ```
 >> cd WindEnergyToolbox
 >> pip install -e . --no-deps
@@ -189,18 +195,39 @@ The workflow to make a merge request is as follows:
 - Your tests should run as fast as possible, and if it uses test files, these files should be as small as possible.
 - Please keep the change in a single MR as small as possible. Split the functionality if you can
 
+
 ## Upload contributions
+
 To be written
 
 
 ## Make and upload wheels
 
+Using conda:
+```
+>> conda install --channel https://conda.anaconda.org/pbrod twine --no-channel-priority
+```
+
+Or pip:
 ```
->> conda install --channel https://conda.anaconda.org/pbrod twine
+>> pip install twine
 ```
 
-- Make tag
-- pip install -e . --upgrade
-- python setup.py bdist_wheel -d dist
-- twine upload dist/*
+- Make tag: ```git tag "vX.Y.Z"```, and push tag to remote: ```git push --tags```
+- In order to have a clean version number (which is determined automagically)
+make sure your git working directory is clean (no uncommitted changes etc).
+- ```pip install -e . --upgrade```
+- ```python setup.py bdist_wheel -d dist``` (wheel includes compiled extensions)
+- On Linux you will have to rename the binary wheel file
+(see [PEP 513](https://www.python.org/dev/peps/pep-0513/) for a background discussion):
+    - wetb-0.0.5-cp35-cp35m-linux_x86_64.whl
+    - wetb-0.0.5-cp35-cp35m-manylinux1_x86_64.whl
+- ```python setup.py sdist -d dist``` (for general source distribution installs)
+- ```twine upload dist/*```
+
+In case of problems:
+
+- Make sure the version tag is compliant with
+[PEP 440](https://www.python.org/dev/peps/pep-0440/), otherwise ```twine upload```
+will fail. This means commit hashes can not be part of a release version.
 
-- 
GitLab