Skip to content

Latest commit

 

History

History
139 lines (101 loc) · 4.97 KB

CONTRIBUTE.md

File metadata and controls

139 lines (101 loc) · 4.97 KB

LIRC tips for contributors

So, you are considering contributing to lirc? You are most welcome! Some points:

Code layout and git hooks

We use the kernel coding standards, as described in [1], with some exceptions and notes:

  • Many lines in the code are actually too long according to these, but stick to the rules (< 80 chars) for new code.
  • For various reasons pointer types are written with the star attached to the type, not the variable. I. e., we use char* s instead of char *s. While this is a good practise it requires us to have all pointer declarations on separate lines.
  • The format-files script uses uncrustify and the uncrustify.cfg file to re-format sources according to these rules with reasonable results.
  • The checkfiles scripts is a wrapper for checkfiles.pl. This is from the kernel, with some minor patches for lirc. Notably it allows code with warnings to be checked in.

In the git-tools directory there is a pre-commit hook aimed to be installed in .git/hooks/pre-commit (a symlink works fine):

cd .git/hooks
ln -s ../../git-tools/pre-commit .

This will invoke the checkfile script before committing to avoid problems. Use git commit --no-verify should you want to avoid these checks.

The git hook also does some other updates. Use it!

Git branches

We basically use the branching scheme described in [2]. However, what is called 'devel' in that document we call 'master'. Likewise, what is called 'master' in [2] we call 'release'. In short:

- master is the current development, from time to time unstable.
- release contains the last stable version, and also all tagged releases.
- When a release is upcoming, we fork a release branch from master. This
  is kept stable, only bugfixes are allowed. Eventually it is merged into
  release and tagged.
- Other branches are feature branches for test and review. They can not
  be trusted, and are often rewritten.

New remote configuration files

There is a document describing how check and submit new remotes at [4].

New drivers.

Info on how to build new drivers is in the wiki [4].

Testing and and bug reporting

Non-trivial changes should be checked using the lirc-codecs-regression-test.sh in test/. Structural and build system changes should be tested with 'make distcheck'. All code changes should be checked using the rudimentary unit tests in test/run-tests.

Please report bugs, RFE:s etc. at sourceforge[3]; either the mailing list or the issue tracker.

Running from the source tree.

You can run the lirc programs directly from their source directory after a successful 'make' without installing things. One gotcha is that you need to provide the plugin directory on the command line. You also need to load the libraries in lib/. E. g., to run lircd:

$ make
$ cd daemons
$ export LD_LIBRARY_PATH=../lib/.libs
$ ./lircd --nodaemon --plugindir=../plugins/.libs

Note that the gnu tools places the generated so-files in the hidden .libs directory.

Another thing to fix is to have reasonable, writable defaults. In order to make this work you should create some temporary, writable dir and direct at least pidfile and output socket to it. A more complete example:

$ make
$ cd daemons
$ export LD_LIBRARY_PATH=../lib/.libs
$ mkdir var || :
$ ./lircd --nodaemon --plugindir=../plugins/.libs \
>     --pidfile var/lircd.pd --output var/lircd.socket

You might want to check which runtime libraries actually loaded by lircd when running like this. Use something like

$  lsof -p 4437  | awk '{print $NF}' | grep '.so' | sort  | uniq

where 4437 is the pid of the real lircd process started by the lircd script, usualle found using

$ pgrep lircd

Generating a stacktrace.

A stacktrace is extremely useful if a lirc program crashes. The common way is to use gdb. If possible, try to start the program you are testing from the command line rather than from e. g., a systemd script.

To generate a core and show the stacktrace:

$ cd daemons
$ ulimit -c unlimited
$ ./lircd --nodaemon  --plugindir=../plugins/.libs [other options]
---> crash
$ ls -lt core*   # will list newest core first.
$ libtool --mode=execute gdb lircd core.12345
[... lots of gdb welcome talk]
(gdb) bt
#12 0xb7fbba63 in for_each_driver [...] at hw-types.c:167
#13 0xb7fbbad3 in hw_choose_driver [...] at hw-types.c:206
#14 0x08049d39 in main (argc=2, argv=0xbffff034) at lircd.c:2250

You dont need a core file. You can also start your program inside gdb and let gdb trap the crash. Something like:

$ cd daemons
$ libtool --mode=execute gdb lircd
(gdb) set args --nodaemon --plugindir=../plugins/.libs [more options]
(gdb) run
----> program crashed
(gdb) bt
[ stack trace displayed ]

References

[1] https://www.kernel.org/doc/Documentation/CodingStyle [2] http://nvie.com/posts/a-successful-git-branching-model [3] http://sourceforge.net/projects/lirc/ [4] https://sourceforge.net/p/lirc/wiki/Drivers