File:  [ELWIX - Embedded LightWeight unIX -] / embedaddon / pimd / CONTRIBUTING.md
Revision 1.1.1.1 (vendor branch): download - view: text, annotated - select for diffs - revision graph
Mon Jun 12 07:59:37 2017 UTC (6 years, 11 months ago) by misho
Branches: pimd, MAIN
CVS tags: v2_3_2, HEAD
pimd 2.3.2

Contributing to pimd
====================

pimd is an old project.  As such it has a lot of history that sometimes
creep up through the cracks.  Bugs!

Bugs can be missing or unclear documentation, faulty legacy behavior,
missing key features or support for a new cool operating system.  Or
simple things, like speling errors or too frequent, or missing logs.

pimd exists on [GitHub][github] for this exact purpose -- to fix bugs,
collaboratively.

We welcome any and all help in the form of bug reports, fixes, patches
for new features -- *preferably as GitHub pull requests*, submitting a
pull request practically guarantees inclusion ... other methods are of
course also possible: emailing the maintainer a patch or even a raw
file, or simply emailing a feature request or an alert for a problem.
For email questions/requests/alerts there is always the risk of memory
exhaustion on the part of the maintainer.


Coding Style
------------

> **Tip:** Adapt your code to what the surrounding code looks like!

pimd is written in C.  C is an old language and sometimes that age is
clearly visible.  The current maintainer has tried to (re)enforce a
consistent and more modern C style, without having to completly
re-indent the whole code base.

First of all, lines are allowed to be longer than 72 characters these
days.  In fact, there exist no enforced maximum, but keeping it around
100 chars is OK.

pimd use leading four spaces in functions and structs.  The next level
use eight spaces, but the original authors used tab for that level.  A
`switch()` has its `case` statements indented four spaces ... but then
it is more or less [KNF][].

In Emacs this coding style can be achieved by using the following
footer applied to a C file:

    /**
     * Local Variables:
     *  version-control: t
     *  indent-tabs-mode: t
     *  c-file-style: "ellemtel"
     *  c-basic-offset: 4
     * End:
     */

The current maintainer has considered shifting the original coding
style to FULL [KNF][] several times.


GIT Submodules
--------------

pimd is maintained using the GIT version control system.  It also use a
Git submodule, [libite][], to provide several utilities functions, like
`pidfile()` and the OpenBSD `strlcpy()` family of functions.

Make sure to `git submodule update` after a `git pull`, in addition to
`git submodule update --init` when you clone the repository initially.


Commit Messages
---------------

Commit messages exist to track *why* a change was made.  Try to be as
clear and concise as possible in your commit messages.  Example from
the [Pro Git][gitbook] online book:

    Brief, but clear and concise summary of changes
    
    More detailed explanatory text, if necessary.  Wrap it to about 72
    characters or so.  In some contexts, the first line is treated as
    the subject of an email and the rest of the text as the body.  The
    blank line separating the ummary from the body is critical (unless
    you omit the body entirely); tools like rebase can get confused if
    you run the two together.
    
    Further paragraphs come after blank lines.
    
     - Bullet points are okay, too
    
     - Typically a hyphen or asterisk is used for the bullet, preceded
       by a single space, with blank lines in between, but conventions
       vary here

Another good *counter* example [is this][rambling] ...


Target Systems
--------------

pimd mainly targets modern UNIX systems and we semi-regularly test it on
both Debian and Ubuntu for Linux, FreeBSD, NetBSD, and OpenBSD.  Please
consider these targets when submitting new features.  If you cannot test
on other operating systems yourself, be prepared that your feature/fix
will likely be delayed by the maintaier, who will attempt to test and in
some cases port the feature for you.


Code of Conduct
---------------

It is expected of everyone engaging in the project to, in the words of
Bill & Ted; [be excellent to each other][conduct].


[github]:   https://github.com/troglobit/pimd/
[KNF]:      https://en.wikipedia.org/wiki/Kernel_Normal_Form
[libite]:   https://github.com/troglobit/libite
[gitbook]:  https://git-scm.com/book/ch5-2.html
[rambling]: http://stopwritingramblingcommitmessages.com/
[conduct]:  https://github.com/troglobit/pimd/blob/master/CODE-OF-CONDUCT.md

<!--
  -- Local Variables:
  -- mode: markdown
  -- End:
  -->

FreeBSD-CVSweb <freebsd-cvsweb@FreeBSD.org>