~azzar1/unity/add-show-desktop-key

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
.. IVLE - Informatics Virtual Learning Environment
   Copyright (C) 2007-2009 The University of Melbourne

.. This program is free software; you can redistribute it and/or modify
   it under the terms of the GNU General Public License as published by
   the Free Software Foundation; either version 2 of the License, or
   (at your option) any later version.

.. This program is distributed in the hope that it will be useful,
   but WITHOUT ANY WARRANTY; without even the implied warranty of
   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
   GNU General Public License for more details.

.. You should have received a copy of the GNU General Public License
   along with this program; if not, write to the Free Software
   Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA  02110-1301  USA

*************
Coding Policy
*************

Code Style
==========
IVLE is mostly written in the Python programming language. As such, code 
should follow the standards set forward in :pep:`8`. It is particularly 
important that code uses a uniform indentation style otherwise this may cause 
unusual behavior or make the code difficult to understand. This means that 
code should be written with 4 spaces per indent and not use any tabs for 
indentation.

IVLE also includes a modest quantity of code written in other languages such 
as JavaScript, HTML and C. In languages that use braces to delimit code blocks 
the Allman style of indentation is used::

    while (x == y)
    {
        something();
        somethingelse();
    }
    finalthing();

If in doubt, follow the existing coding style used in the module. Having a 
consistent coding style is often of far greater value than choosing any one 
style over another.

Version Control
===============
Code is developed on `Launchpad <https://launchpad.net/>`_ using the `Bazaar 
<http://bazaar-vcs.org/>`_ version control system. The main branch for 
development ``lp:ivle``, though more complex features or large changes should 
be developed in a separate branch with the name
:samp:`lp:~ivle-dev/ivle/{branch-name}` and then merged into the trunk when 
complete.

Developers who are not members of the
`ivle-dev team <https://launchpad.net/~ivle-dev>`_ will not be able to
commit to ``lp:ivle``. However, contributions are still welcome. External
developers with a patch or new feature should create a branch named
:samp:`lp:~{your-name}/ivle/{branch-name}`, and make a Launchpad merge proposal
to ``lp:ivle`` when ready. Regular contributors may be invited to the core team
on a case-by-case basis.

All associated branches can be found on the `IVLE project page on Launchpad
<https://launchpad.net/ivle>`_.


.. seealso::

   `Bazaar in five minutes <http://doc.bazaar.canonical.com/latest/en/mini-tutorial/>`_
      A quick introduction to Bazaar's core functionality.


Test Suite
==========
IVLE has a small (but growing) set of test cases. After making any significant 
changes to the codebase developers are strongly recommended to run the test 
suite and, if a test fails, correct their code or fix the test case.

IVLE currently uses `nose 
<http://somethingaboutorange.com/mrl/projects/nose/>`_ for its test suite. For 
simple functions the easiest way of writing a test is to use the `doctests
<http://docs.python.org/library/doctest.html>`_ style of test markup. The 
``nosetests`` script will automatically detect and run these test cases. For 
more complex tests, you will probably need to write a test module. Test 
modules are any module with a name of the form ``test_MODULENAME.py``. Any 
function with the word 'test' in it's name will be run and should throw an 
exception or fail an assert if the test case fails.

To run the test suite either run the ``ivle-testsuite`` script from 
``lp:~ivle-dev/ivle/dev-scripts`` or run ``IVLECONF="." nosetests`` in the top 
level directory of an IVLE checkout.

License
=======
IVLE is licenced under the `GNU General Public License Version 2.0 
<http://www.gnu.org/licenses/gpl-2.0.html>`_ and requires that all 
contributions be made under it or a compatible license. Code contributions 
should also contain a header of the following form::

    # IVLE - Informatics Virtual Learning Environment
    # Copyright (C) 2007-2010 The University of Melbourne
    #
    # This program is free software; you can redistribute it and/or modify
    # it under the terms of the GNU General Public License as published by
    # the Free Software Foundation; either version 2 of the License, or
    # (at your option) any later version.
    #
    # This program is distributed in the hope that it will be useful,
    # but WITHOUT ANY WARRANTY; without even the implied warranty of
    # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
    # GNU General Public License for more details.
    #
    # You should have received a copy of the GNU General Public License
    # along with this program; if not, write to the Free Software
    # Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA  02110-1301  USA