X-Git-Url: https://sigrok.org/gitweb/?p=libsigrokdecode.git;a=blobdiff_plain;f=HACKING;h=6aaedac13acb0939feda256ef4e35e5ccba31736;hp=a9a6a03f1d70d82df6b6960765b2a19ec3a13771;hb=077fa8acbcb8b585af6f5323f16221940a27a72e;hpb=0672779d5e3e128ef3f7ec932772ff6d65fcbc50 diff --git a/HACKING b/HACKING index a9a6a03..6aaedac 100644 --- a/HACKING +++ b/HACKING @@ -38,18 +38,21 @@ Random notes - Generally avoid assigning values to variables at declaration time, especially so for complex and/or run-time dependent values. - - Consistently use g_try_malloc() / g_try_malloc0(). Do not use standard + - Consistently use g_*malloc() / g_*malloc0(). Do not use standard malloc()/calloc() if it can be avoided (sometimes other libs such as libftdi can return malloc()'d memory, for example). - Always properly match allocations with the proper *free() functions. If - glib's g_try_malloc()/g_try_malloc0() was used, use g_free() to free the + glib's g_*malloc()/g_*malloc0() was used, use g_free() to free the memory. Otherwise use standard free(). Never use the wrong function! - - Never use g_malloc() or g_malloc0(). These functions do not return NULL - if not enough memory is available but rather lead to an exit() or segfault - instead. This behaviour is not acceptable for libraries. - Use g_try_malloc()/g_try_malloc0() instead and check the return value. + - We assume that "small" memory allocations (< 1MB) will always succeed. + Thus, it's fine to use g_malloc() or g_malloc0() for allocations of + simple/small structs and such (instead of using g_try_malloc()), and + there's no need to check the return value. + + Do use g_try_malloc() or g_try_malloc0() for large (>= 1MB) allocations + and check the return value. - You should never print any messages (neither to stdout nor stderr nor elsewhere) "manually" via e.g. printf() or g_log() or similar functions. @@ -182,9 +185,8 @@ You can run the libsigrokdecode testsuite using: Protocol decoder test framework ------------------------------- -You can run the protocol decoder tests using (e.g.): - - $ ./tests/pdtest -r -a -v +Please see the sigrok-test repository for a protocol decoder test suite that +checks the decoded data of various PDs against known-good reference data. Release engineering