fix 1693
[oweals/gnunet.git] / HACKING
diff --git a/HACKING b/HACKING
index 511a88060b25376e5422a9fb0d6c7e3a724080f1..ecd9e6adb1b8769c3eea63d570173eb234dd7edb 100644 (file)
--- a/HACKING
+++ b/HACKING
@@ -13,6 +13,16 @@ include files:
   * gnunet_directories.h --- generated
   * gettext.h            --- external library
 
+
+binaries:
+- gnunet-service-xxx: service process (has listen socket)
+- gnunet-daemon-xxx: daemon process (no listen socket)
+- gnunet-helper-xxx[-yyy]: SUID helper for module xxx
+- gnunet-yyy: command-line tool for end-users
+- libgnunet_plugin_xxx_yyy.so: plugin for API xxx
+- libgnunetxxx.so: library for API xxx
+
+
 configuration:
 - paths (that are substituted in all filenames) are in PATHS (have as few as possible)
 - globals for the daemon are in [gnunetd] (for now, have as few as possible!)
@@ -22,11 +32,11 @@ configuration:
   together with the options for the testing module itself
 
 
-
 exported symbols:
 - must start with "GNUNET_modulename_" and be defined in "modulename.c"
 - exceptions: those defined in gnunet_common.h
 
+
 private (library-internal) symbols (including structs & macros):
 - must NOT start with any prefix
 - must not be exported in a way that linkers could use them or
@@ -43,7 +53,7 @@ testcases:
 performance tests:
 - must be called "perf_module-under-test_case-description.c"
 - "case-description" maybe omitted if there is only one performance test
-
+- Must only be run if HAVE_BENCHMARKS is satisfied
 
 
 src/ directories:
@@ -54,22 +64,6 @@ src/ directories:
 - libgnunet_plugin_DIR_NAME: loadable plugins (i.e., libgnunet_plugin_transport_tcp)
 
 
-
-Minimum file-sharing system (in order of dependency):
-gnunet-service-arm
-gnunet-service-transport
-gnunet-service-core
-gnunet-daemon-hostlist
-gnunet-daemon-topology
-gnunet-service-statistics
-gnunet-service-datastore
-gnunet-service-datacache
-gnunet-service-dht
-gnunet-service-fs (or just lib?)
-
-
-
-
 Coding style:
 - GNU guidelines apply
 - declare only one variable per line, so 
@@ -82,7 +76,6 @@ Coding style:
   int i,j;
 
 
-
 Build-system:
 
 If you have code that is likely not to compile or build rules you might want to not
@@ -92,6 +85,24 @@ it is OK to (temporarily) add non-compiling (or known-to-not-port) code.
 If you want to compile all testcases but NOT run them, run configure with the
 --enable-test-suppression option.
 
+If you want to run all testcases, including those that take a while, run configure with the
+--enable-expensive-testcases option.
+
+If you want to compile and run benchmarks, run configure with the
+--enable-benchmarks option.
+
 If you want to obtain code coverage results, run configure with the
 --enable-coverage option and run the coverage.sh script in contrib/.
 
+
+Minimum file-sharing system (in order of dependency):
+gnunet-service-arm
+gnunet-service-transport
+gnunet-service-core
+gnunet-daemon-hostlist
+gnunet-daemon-topology
+gnunet-service-statistics
+gnunet-service-datastore
+gnunet-service-datacache
+gnunet-service-dht
+gnunet-service-fs