Create a class to store messages for event log

Create a Logger class that can store log messages along with their
timestamps.  These messages will then be added to an event log when they
are created for missing fans, for debug purposes.  Each message is also
logged to the journal.

The maximum number of entries to keep around is specified in the
constructor, and when full the oldest message will be purged when new
ones are added.  This number comes from a configuration option which
defaults to 50.

A standalone getLogger() API was also added to give the new object
singleton behavior, so the same object can be accessed from all classes
in an application.

Signed-off-by: Matt Spinler <spinler@us.ibm.com>
Change-Id: I8d5ac137acb67bfe78609d02aaf59a01b03c5c8b
diff --git a/configure.ac b/configure.ac
index 3d79076..89221ad 100644
--- a/configure.ac
+++ b/configure.ac
@@ -100,6 +100,12 @@
        AC_SUBST([PFPGEN],
                 ["$PYTHON \${top_srcdir}/presence/pfpgen.py generate-cpp -i $PRESENCE_CONFIG"])
     ])
+
+    AC_ARG_VAR(NUM_PRESENCE_LOG_ENTRIES, [Maximum number of entries in the message log])
+    AS_IF([test "x$NUM_PRESENCE_LOG_ENTRIES" == "x"], [NUM_PRESENCE_LOG_ENTRIES=50])
+    AC_DEFINE_UNQUOTED([NUM_PRESENCE_LOG_ENTRIES], [$NUM_PRESENCE_LOG_ENTRIES],
+                       [Maximum number of entries in the message log])
+
     AC_CONFIG_FILES([presence/Makefile])
 ])
 
@@ -191,5 +197,5 @@
 ])
 
 # Create configured output
-AC_CONFIG_FILES([Makefile presence/test/Makefile])
+AC_CONFIG_FILES([Makefile test/Makefile presence/test/Makefile])
 AC_OUTPUT