forked from OpenZWave/python-openzwave
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathDEVEL.txt
137 lines (87 loc) · 4.11 KB
/
DEVEL.txt
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
Developpers information
***********************
How to develop for python-openzwave
===================================
Get the sources
git clone https://github.com/bibi21000/python-openzwave
You must now install python-openzwave in develop mode
make develop
Your password will be asked (by sudo) for installing eggs in your
local directory.
Develop, test, debug, test, ... :)
Update the documentation if needed. You surely found the documentation
useful, so please keep it up to date.
You can create an account on travis or docker to run the tests.
At last but not least, submit your request.
How to develop for libopenzwave (was python-openzwave-lib)
==========================================================
After updating the pyx, you need to reinstall it. Otherwise, your
changes will not be applied :
make develop
Tests
=====
Travis-ci, Docker Hub, nosetests and pylint are used to test quality
of code. There reports are here :
* Docker : https://registry.hub.docker.com/u/bibi21000/python-
openzwave/
* Travis : https://travis-ci.org/bibi21000/python-openzwave
* Nosetests report
* Coverage report
* Pylint report
Some tests don't need a ZWave Stick to be launched, so they can be run
on the autobuilders (travis, docker, ...). Place them in the autobuild
directory. Documentation ============= Documentation is managed with
sphinx. Don't utpdate txt files (README, INSTALL, ...), update the RST
sources in docs. Use the following commands to generate all docs files
(txt, html and joomla)
You need to have installed python-openzave (in either develop or
install mode) before generating the documentation.
make docs
Static vs dynamic (or shared)
=============================
The openzwave (c++) lib needs to run as a singleton : it means that it
MUST have only one instance of the manager running on your computer.
There is 2 ways of linking libraries with a program :
* static : includes a copy of the library in your binary program.
This means that your program has its own instance of the library.
This the way the install.sh runs. So you CAN'T have another
program (like the control-panel) running when using the python-
openzwave library
* dynamic or shared : includes a link to the library in your
binary program. This means that your program share the library
with other programs. In this case, the instance is owned directly
by the library. This the way the debian package works. So you CAN
have another program running when using the python-openzwave
library. Of course, this program MUST use the shared library too.
About sudo
==========
If you are like me and don't like root (and sudo), you can use the
following tip to install packages via pip :
Look at your python local library, it should looks like :
ls -lisa /usr/local/lib/python2.7/dist-packages/
total 2428
1445174 12 drwxrwsr-x 115 root staff 12288 avril 9 21:35 .
1445172 4 drwxrwsr-x 4 root staff 4096 mai 2 2014 ..
1457164 4 drwxr-sr-x 5 root staff 4096 nov. 26 2013 actdiag
1715480 4 drwxr-sr-x 2 root staff 4096 nov. 26 2013 actdiag-0.5.1.egg-info
1457163 4 -rw-r--r-- 1 root staff 1004 nov. 26 2013 actdiag_sphinxhelper.py
1457172 4 -rw-r--r-- 1 root staff 620 nov. 26 2013 actdiag_sphinxhelper.pyc
....
So, add your common user to the staff group :
sudo usermod -a -G staff userName
Add the write right to the group staff
sudo chmod -Rf g+w /usr/local/lib/python2.7/dist-packages/
And now, it's time log off and log on. Groups are checked when you
open the session.
You can now install your packages without sudo.
python3
=======
Python 3 is actually not supported.
A branch (python3) has been created with a special Dockerfile. It
build python-openzwave and launch some tests. This branch is
automatically merged from master at "make commit".
So please, do not directly push under python3 branch. Make your
developments under master or another branch.
It's important for me have python2/python3 compatibilty in the master
branch. cython can help for this :
http://docs.cython.org/src/tutorial/strings.html