Hello community,

here is the log from the commit of package liblognorm for openSUSE:Factory 
checked in at 2012-09-21 14:41:27
++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
Comparing /work/SRC/openSUSE:Factory/liblognorm (Old)
 and      /work/SRC/openSUSE:Factory/.liblognorm.new (New)
++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++

Package is "liblognorm", Maintainer is ""

Changes:
--------
--- /work/SRC/openSUSE:Factory/liblognorm/liblognorm.changes    2012-08-27 
16:12:00.000000000 +0200
+++ /work/SRC/openSUSE:Factory/.liblognorm.new/liblognorm.changes       
2012-09-21 14:41:29.000000000 +0200
@@ -1,0 +2,6 @@
+Thu Sep 20 22:02:57 UTC 2012 - [email protected]
+
+- update to 0.3.5:
+  renamed "normalizer" tool to "lognormalizer to solve name clashes
+
+-------------------------------------------------------------------

Old:
----
  liblognorm-0.3.4.tar.gz

New:
----
  liblognorm-0.3.5.tar.gz

++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++

Other differences:
------------------
++++++ liblognorm.spec ++++++
--- /var/tmp/diff_new_pack.deIZCO/_old  2012-09-21 14:41:30.000000000 +0200
+++ /var/tmp/diff_new_pack.deIZCO/_new  2012-09-21 14:41:30.000000000 +0200
@@ -17,7 +17,7 @@
 
 
 Name:           liblognorm
-Version:        0.3.4
+Version:        0.3.5
 Release:        0
 Summary:        Library and tool to normalize log data
 License:        LGPL-2.1+
@@ -123,7 +123,7 @@
 %defattr(-,root,root)
 %doc COPYING NEWS README AUTHORS ChangeLog
 %{_libdir}/*.so.*
-%{_bindir}/normalizer
+%{_bindir}/lognormalizer
 
 %files devel
 %defattr(-,root,root)

++++++ liblognorm-0.3.4.tar.gz -> liblognorm-0.3.5.tar.gz ++++++
diff -urN '--exclude=CVS' '--exclude=.cvsignore' '--exclude=.svn' 
'--exclude=.svnignore' old/liblognorm-0.3.4/ChangeLog 
new/liblognorm-0.3.5/ChangeLog
--- old/liblognorm-0.3.4/ChangeLog      2012-04-16 13:01:38.000000000 +0200
+++ new/liblognorm-0.3.5/ChangeLog      2012-09-18 14:45:24.000000000 +0200
@@ -1,4 +1,8 @@
 ----------------------------------------------------------------------
+Version 0.3.5 (rgerhards), 2012-09-18
+- renamed "normalizer" tool to "lognormalizer" to solve name clashes
+  Thanks to the Fedora folks for pointing this out.
+----------------------------------------------------------------------
 Version 0.3.4 (rgerhards), 2012-04-16
 - bugfix: normalizer tool had a memory leak
   Thanks to Brian Know for alerting me and helping to debug
diff -urN '--exclude=CVS' '--exclude=.cvsignore' '--exclude=.svn' 
'--exclude=.svnignore' old/liblognorm-0.3.4/configure 
new/liblognorm-0.3.5/configure
--- old/liblognorm-0.3.4/configure      2012-04-16 13:02:05.000000000 +0200
+++ new/liblognorm-0.3.5/configure      2012-09-18 14:45:43.000000000 +0200
@@ -1,6 +1,6 @@
 #! /bin/sh
 # Guess values for system-dependent variables and create Makefiles.
-# Generated by GNU Autoconf 2.67 for liblognorm 0.3.4.
+# Generated by GNU Autoconf 2.67 for liblognorm 0.3.5.
 #
 # Report bugs to <[email protected]>.
 #
@@ -701,8 +701,8 @@
 # Identity of this package.
 PACKAGE_NAME='liblognorm'
 PACKAGE_TARNAME='liblognorm'
-PACKAGE_VERSION='0.3.4'
-PACKAGE_STRING='liblognorm 0.3.4'
+PACKAGE_VERSION='0.3.5'
+PACKAGE_STRING='liblognorm 0.3.5'
 PACKAGE_BUGREPORT='[email protected]'
 PACKAGE_URL=''
 
@@ -1434,7 +1434,7 @@
   # Omit some internal or obsolete options to make the list less imposing.
   # This message is too long to be a string in the A/UX 3.1 sh.
   cat <<_ACEOF
-\`configure' configures liblognorm 0.3.4 to adapt to many kinds of systems.
+\`configure' configures liblognorm 0.3.5 to adapt to many kinds of systems.
 
 Usage: $0 [OPTION]... [VAR=VALUE]...
 
@@ -1504,7 +1504,7 @@
 
 if test -n "$ac_init_help"; then
   case $ac_init_help in
-     short | recursive ) echo "Configuration of liblognorm 0.3.4:";;
+     short | recursive ) echo "Configuration of liblognorm 0.3.5:";;
    esac
   cat <<\_ACEOF
 
@@ -1618,7 +1618,7 @@
 test -n "$ac_init_help" && exit $ac_status
 if $ac_init_version; then
   cat <<\_ACEOF
-liblognorm configure 0.3.4
+liblognorm configure 0.3.5
 generated by GNU Autoconf 2.67
 
 Copyright (C) 2010 Free Software Foundation, Inc.
@@ -2041,7 +2041,7 @@
 This file contains any messages produced by compilers while
 running configure, to aid debugging if configure makes a mistake.
 
-It was created by liblognorm $as_me 0.3.4, which was
+It was created by liblognorm $as_me 0.3.5, which was
 generated by GNU Autoconf 2.67.  Invocation command line was
 
   $ $0 $@
@@ -2856,7 +2856,7 @@
 
 # Define the identity of the package.
  PACKAGE='liblognorm'
- VERSION='0.3.4'
+ VERSION='0.3.5'
 
 
 cat >>confdefs.h <<_ACEOF
@@ -11953,7 +11953,7 @@
 # report actual input values of CONFIG_FILES etc. instead of their
 # values after options handling.
 ac_log="
-This file was extended by liblognorm $as_me 0.3.4, which was
+This file was extended by liblognorm $as_me 0.3.5, which was
 generated by GNU Autoconf 2.67.  Invocation command line was
 
   CONFIG_FILES    = $CONFIG_FILES
@@ -12019,7 +12019,7 @@
 cat >>$CONFIG_STATUS <<_ACEOF || ac_write_fail=1
 ac_cs_config="`$as_echo "$ac_configure_args" | sed 's/^ //; 
s/[\\""\`\$]/\\\\&/g'`"
 ac_cs_version="\\
-liblognorm config.status 0.3.4
+liblognorm config.status 0.3.5
 configured by $0, generated by GNU Autoconf 2.67,
   with options \\"\$ac_cs_config\\"
 
diff -urN '--exclude=CVS' '--exclude=.cvsignore' '--exclude=.svn' 
'--exclude=.svnignore' old/liblognorm-0.3.4/configure.ac 
new/liblognorm-0.3.5/configure.ac
--- old/liblognorm-0.3.4/configure.ac   2012-04-16 13:01:56.000000000 +0200
+++ new/liblognorm-0.3.5/configure.ac   2012-09-18 14:45:32.000000000 +0200
@@ -2,7 +2,7 @@
 # Process this file with autoconf to produce a configure script.
 
 AC_PREREQ(2.61)
-AC_INIT([liblognorm], [0.3.4], [[email protected]])
+AC_INIT([liblognorm], [0.3.5], [[email protected]])
 AM_INIT_AUTOMAKE
 m4_ifdef([AM_SILENT_RULES], [AM_SILENT_RULES([yes])])
 AC_CONFIG_SRCDIR([src/lognorm.c])
diff -urN '--exclude=CVS' '--exclude=.cvsignore' '--exclude=.svn' 
'--exclude=.svnignore' old/liblognorm-0.3.4/src/Makefile.am 
new/liblognorm-0.3.5/src/Makefile.am
--- old/liblognorm-0.3.4/src/Makefile.am        2012-02-06 18:05:39.000000000 
+0100
+++ new/liblognorm-0.3.5/src/Makefile.am        2012-09-18 14:44:42.000000000 
+0200
@@ -6,10 +6,10 @@
 
 # we need to clean the normalizer up once we have reached a decent
 # milestone (latest at initial release!)
-bin_PROGRAMS = normalizer
-normalizer_SOURCES = normalizer.c
-normalizer_CPPFLAGS =  -I$(top_srcdir) $(LIBEE_CFLAGS) $(LIBESTR_CFLAGS)
-normalizer_LDADD = $(LIBEE_LIBS) $(LIBLOGNORM_LIBS) $(LIBESTR_LIBS)
+bin_PROGRAMS = lognormalizer
+lognormalizer_SOURCES = lognormalizer.c
+lognormalizer_CPPFLAGS =  -I$(top_srcdir) $(LIBEE_CFLAGS) $(LIBESTR_CFLAGS)
+lognormalizer_LDADD = $(LIBEE_LIBS) $(LIBLOGNORM_LIBS) $(LIBESTR_LIBS)
 
 lib_LTLIBRARIES = liblognorm.la
 
diff -urN '--exclude=CVS' '--exclude=.cvsignore' '--exclude=.svn' 
'--exclude=.svnignore' old/liblognorm-0.3.4/src/Makefile.in 
new/liblognorm-0.3.5/src/Makefile.in
--- old/liblognorm-0.3.4/src/Makefile.in        2012-04-16 13:02:04.000000000 
+0200
+++ new/liblognorm-0.3.5/src/Makefile.in        2012-09-18 14:45:42.000000000 
+0200
@@ -36,7 +36,7 @@
 POST_UNINSTALL = :
 build_triplet = @build@
 host_triplet = @host@
-bin_PROGRAMS = normalizer$(EXEEXT)
+bin_PROGRAMS = lognormalizer$(EXEEXT)
 subdir = src
 DIST_COMMON = $(include_HEADERS) $(srcdir)/Makefile.am \
        $(srcdir)/Makefile.in
@@ -89,10 +89,10 @@
        $(LIBTOOLFLAGS) --mode=link $(CCLD) $(AM_CFLAGS) $(CFLAGS) \
        $(liblognorm_la_LDFLAGS) $(LDFLAGS) -o $@
 PROGRAMS = $(bin_PROGRAMS)
-am_normalizer_OBJECTS = normalizer-normalizer.$(OBJEXT)
-normalizer_OBJECTS = $(am_normalizer_OBJECTS)
-normalizer_DEPENDENCIES = $(am__DEPENDENCIES_1) $(am__DEPENDENCIES_1) \
-       $(am__DEPENDENCIES_1)
+am_lognormalizer_OBJECTS = lognormalizer-lognormalizer.$(OBJEXT)
+lognormalizer_OBJECTS = $(am_lognormalizer_OBJECTS)
+lognormalizer_DEPENDENCIES = $(am__DEPENDENCIES_1) \
+       $(am__DEPENDENCIES_1) $(am__DEPENDENCIES_1)
 DEFAULT_INCLUDES = -I.@am__isrc@ -I$(top_builddir)
 depcomp = $(SHELL) $(top_srcdir)/depcomp
 am__depfiles_maybe = depfiles
@@ -119,8 +119,8 @@
 AM_V_GEN = $(am__v_GEN_$(V))
 am__v_GEN_ = $(am__v_GEN_$(AM_DEFAULT_VERBOSITY))
 am__v_GEN_0 = @echo "  GEN   " $@;
-SOURCES = $(liblognorm_la_SOURCES) $(normalizer_SOURCES)
-DIST_SOURCES = $(liblognorm_la_SOURCES) $(normalizer_SOURCES)
+SOURCES = $(liblognorm_la_SOURCES) $(lognormalizer_SOURCES)
+DIST_SOURCES = $(liblognorm_la_SOURCES) $(lognormalizer_SOURCES)
 HEADERS = $(include_HEADERS)
 ETAGS = etags
 CTAGS = ctags
@@ -250,9 +250,9 @@
 # Uncomment for debugging
 DEBUG = -g
 PTHREADS_CFLAGS = -pthread
-normalizer_SOURCES = normalizer.c
-normalizer_CPPFLAGS = -I$(top_srcdir) $(LIBEE_CFLAGS) $(LIBESTR_CFLAGS)
-normalizer_LDADD = $(LIBEE_LIBS) $(LIBLOGNORM_LIBS) $(LIBESTR_LIBS)
+lognormalizer_SOURCES = lognormalizer.c
+lognormalizer_CPPFLAGS = -I$(top_srcdir) $(LIBEE_CFLAGS) $(LIBESTR_CFLAGS)
+lognormalizer_LDADD = $(LIBEE_LIBS) $(LIBLOGNORM_LIBS) $(LIBESTR_LIBS)
 lib_LTLIBRARIES = liblognorm.la
 liblognorm_la_SOURCES = \
        liblognorm.c \
@@ -383,9 +383,9 @@
        list=`for p in $$list; do echo "$$p"; done | sed 's/$(EXEEXT)$$//'`; \
        echo " rm -f" $$list; \
        rm -f $$list
-normalizer$(EXEEXT): $(normalizer_OBJECTS) $(normalizer_DEPENDENCIES) 
-       @rm -f normalizer$(EXEEXT)
-       $(AM_V_CCLD)$(LINK) $(normalizer_OBJECTS) $(normalizer_LDADD) $(LIBS)
+lognormalizer$(EXEEXT): $(lognormalizer_OBJECTS) $(lognormalizer_DEPENDENCIES) 
+       @rm -f lognormalizer$(EXEEXT)
+       $(AM_V_CCLD)$(LINK) $(lognormalizer_OBJECTS) $(lognormalizer_LDADD) 
$(LIBS)
 
 mostlyclean-compile:
        -rm -f *.$(OBJEXT)
@@ -398,7 +398,7 @@
 @AMDEP_TRUE@@am__include@ 
@am__quote@./$(DEPDIR)/liblognorm_la-lognorm.Plo@am__quote@
 @AMDEP_TRUE@@am__include@ 
@am__quote@./$(DEPDIR)/liblognorm_la-ptree.Plo@am__quote@
 @AMDEP_TRUE@@am__include@ 
@am__quote@./$(DEPDIR)/liblognorm_la-samp.Plo@am__quote@
-@AMDEP_TRUE@@am__include@ 
@am__quote@./$(DEPDIR)/normalizer-normalizer.Po@am__quote@
+@AMDEP_TRUE@@am__include@ 
@am__quote@./$(DEPDIR)/lognormalizer-lognormalizer.Po@am__quote@
 
 .c.o:
 @am__fastdepCC_TRUE@   $(AM_V_CC)$(COMPILE) -MT $@ -MD -MP -MF 
$(DEPDIR)/$*.Tpo -c -o $@ $<
@@ -464,21 +464,21 @@
 @AMDEP_TRUE@@am__fastdepCC_FALSE@      DEPDIR=$(DEPDIR) $(CCDEPMODE) 
$(depcomp) @AMDEPBACKSLASH@
 @am__fastdepCC_FALSE@  $(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) 
$(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) 
$(liblognorm_la_CPPFLAGS) $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -c -o 
liblognorm_la-lognorm.lo `test -f 'lognorm.c' || echo '$(srcdir)/'`lognorm.c
 
-normalizer-normalizer.o: normalizer.c
-@am__fastdepCC_TRUE@   $(AM_V_CC)$(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) 
$(normalizer_CPPFLAGS) $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -MT 
normalizer-normalizer.o -MD -MP -MF $(DEPDIR)/normalizer-normalizer.Tpo -c -o 
normalizer-normalizer.o `test -f 'normalizer.c' || echo 
'$(srcdir)/'`normalizer.c
-@am__fastdepCC_TRUE@   $(AM_V_at)$(am__mv) $(DEPDIR)/normalizer-normalizer.Tpo 
$(DEPDIR)/normalizer-normalizer.Po
+lognormalizer-lognormalizer.o: lognormalizer.c
+@am__fastdepCC_TRUE@   $(AM_V_CC)$(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) 
$(lognormalizer_CPPFLAGS) $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -MT 
lognormalizer-lognormalizer.o -MD -MP -MF 
$(DEPDIR)/lognormalizer-lognormalizer.Tpo -c -o lognormalizer-lognormalizer.o 
`test -f 'lognormalizer.c' || echo '$(srcdir)/'`lognormalizer.c
+@am__fastdepCC_TRUE@   $(AM_V_at)$(am__mv) 
$(DEPDIR)/lognormalizer-lognormalizer.Tpo 
$(DEPDIR)/lognormalizer-lognormalizer.Po
 @am__fastdepCC_FALSE@  $(AM_V_CC) @AM_BACKSLASH@
-@AMDEP_TRUE@@am__fastdepCC_FALSE@      source='normalizer.c' 
object='normalizer-normalizer.o' libtool=no @AMDEPBACKSLASH@
+@AMDEP_TRUE@@am__fastdepCC_FALSE@      source='lognormalizer.c' 
object='lognormalizer-lognormalizer.o' libtool=no @AMDEPBACKSLASH@
 @AMDEP_TRUE@@am__fastdepCC_FALSE@      DEPDIR=$(DEPDIR) $(CCDEPMODE) 
$(depcomp) @AMDEPBACKSLASH@
-@am__fastdepCC_FALSE@  $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) 
$(normalizer_CPPFLAGS) $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -c -o 
normalizer-normalizer.o `test -f 'normalizer.c' || echo 
'$(srcdir)/'`normalizer.c
+@am__fastdepCC_FALSE@  $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) 
$(lognormalizer_CPPFLAGS) $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -c -o 
lognormalizer-lognormalizer.o `test -f 'lognormalizer.c' || echo 
'$(srcdir)/'`lognormalizer.c
 
-normalizer-normalizer.obj: normalizer.c
-@am__fastdepCC_TRUE@   $(AM_V_CC)$(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) 
$(normalizer_CPPFLAGS) $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -MT 
normalizer-normalizer.obj -MD -MP -MF $(DEPDIR)/normalizer-normalizer.Tpo -c -o 
normalizer-normalizer.obj `if test -f 'normalizer.c'; then $(CYGPATH_W) 
'normalizer.c'; else $(CYGPATH_W) '$(srcdir)/normalizer.c'; fi`
-@am__fastdepCC_TRUE@   $(AM_V_at)$(am__mv) $(DEPDIR)/normalizer-normalizer.Tpo 
$(DEPDIR)/normalizer-normalizer.Po
+lognormalizer-lognormalizer.obj: lognormalizer.c
+@am__fastdepCC_TRUE@   $(AM_V_CC)$(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) 
$(lognormalizer_CPPFLAGS) $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -MT 
lognormalizer-lognormalizer.obj -MD -MP -MF 
$(DEPDIR)/lognormalizer-lognormalizer.Tpo -c -o lognormalizer-lognormalizer.obj 
`if test -f 'lognormalizer.c'; then $(CYGPATH_W) 'lognormalizer.c'; else 
$(CYGPATH_W) '$(srcdir)/lognormalizer.c'; fi`
+@am__fastdepCC_TRUE@   $(AM_V_at)$(am__mv) 
$(DEPDIR)/lognormalizer-lognormalizer.Tpo 
$(DEPDIR)/lognormalizer-lognormalizer.Po
 @am__fastdepCC_FALSE@  $(AM_V_CC) @AM_BACKSLASH@
-@AMDEP_TRUE@@am__fastdepCC_FALSE@      source='normalizer.c' 
object='normalizer-normalizer.obj' libtool=no @AMDEPBACKSLASH@
+@AMDEP_TRUE@@am__fastdepCC_FALSE@      source='lognormalizer.c' 
object='lognormalizer-lognormalizer.obj' libtool=no @AMDEPBACKSLASH@
 @AMDEP_TRUE@@am__fastdepCC_FALSE@      DEPDIR=$(DEPDIR) $(CCDEPMODE) 
$(depcomp) @AMDEPBACKSLASH@
-@am__fastdepCC_FALSE@  $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) 
$(normalizer_CPPFLAGS) $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -c -o 
normalizer-normalizer.obj `if test -f 'normalizer.c'; then $(CYGPATH_W) 
'normalizer.c'; else $(CYGPATH_W) '$(srcdir)/normalizer.c'; fi`
+@am__fastdepCC_FALSE@  $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) 
$(lognormalizer_CPPFLAGS) $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -c -o 
lognormalizer-lognormalizer.obj `if test -f 'lognormalizer.c'; then 
$(CYGPATH_W) 'lognormalizer.c'; else $(CYGPATH_W) '$(srcdir)/lognormalizer.c'; 
fi`
 
 mostlyclean-libtool:
        -rm -f *.lo
diff -urN '--exclude=CVS' '--exclude=.cvsignore' '--exclude=.svn' 
'--exclude=.svnignore' old/liblognorm-0.3.4/src/lognormalizer.c 
new/liblognorm-0.3.5/src/lognormalizer.c
--- old/liblognorm-0.3.4/src/lognormalizer.c    1970-01-01 01:00:00.000000000 
+0100
+++ new/liblognorm-0.3.5/src/lognormalizer.c    2012-09-18 14:39:33.000000000 
+0200
@@ -0,0 +1,246 @@
+/**
+ * @file normalizer.c
+ * @brief A small tool to normalize data.
+ *
+ * This is the most basic example demonstrating how to use liblognorm.
+ * It loads log samples from the files specified on the command line,
+ * reads to-be-normalized data from stdin and writes the normalized
+ * form to stdout. Besides being an example, it also carries out useful
+ * processing.
+ *
+ * @author Rainer Gerhards <[email protected]>
+ *
+ *//*
+ * liblognorm - a fast samples-based log normalization library
+ * Copyright 2010-2011 by Rainer Gerhards and Adiscon GmbH.
+ *
+ * This file is part of liblognorm.
+ *
+ * This library is free software; you can redistribute it and/or
+ * modify it under the terms of the GNU Lesser General Public
+ * License as published by the Free Software Foundation; either
+ * version 2.1 of the License, or (at your option) any later version.
+ *
+ * This library is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
+ * Lesser General Public License for more details.
+ *
+ * You should have received a copy of the GNU Lesser General Public
+ * License along with this library; if not, write to the Free Software
+ * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA  02110-1301  
USA
+ *
+ * A copy of the LGPL v2.1 can be found in the file "COPYING" in this 
distribution.
+ */
+#include <stdio.h>
+#include <string.h>
+#include <getopt.h>
+#include <libestr.h>
+#include <libee/libee.h>
+#include "liblognorm.h"
+#include "ptree.h"
+#include "lognorm.h"
+
+static ln_ctx ctx;
+static ee_ctx eectx;
+
+static int verbose = 0;
+static int parsedOnly = 0;     /**< output unparsed messages? */
+static int flatTags = 0;       /**< output unparsed messages? */
+static FILE *fpDOT;
+static es_str_t *encFmt = NULL; /**< a format string for encoder use */
+static es_str_t *mandatoryTag = NULL; /**< tag which must be given so that 
mesg will
+                                          be output. NULL=all */
+static enum { f_syslog, f_json, f_xml, f_csv } outfmt = f_syslog;
+
+void
+dbgCallBack(void __attribute__((unused)) *cookie, char *msg,
+           size_t __attribute__((unused)) lenMsg)
+{
+       printf("liblognorm: %s\n", msg);
+}
+
+void errout(char *errmsg)
+{
+       fprintf(stderr, "%s\n", errmsg);
+       exit(1);
+}
+
+
+/* param str is just a performance enhancement, which saves us re-creation
+ * of the string on every call.
+ */
+static inline void
+outputEvent(struct ee_event *event)
+{
+       char *cstr;
+       es_str_t *str = NULL;
+
+       switch(outfmt) {
+       case f_json:
+               ee_fmtEventToJSON(event, &str);
+               break;
+       case f_syslog:
+               ee_fmtEventToRFC5424(event, &str);
+               break;
+       case f_xml:
+               ee_fmtEventToXML(event, &str);
+               break;
+       case f_csv:
+               ee_fmtEventToCSV(event, &str, encFmt);
+               break;
+       }
+       cstr = es_str2cstr(str, NULL);
+       if(verbose > 0) printf("normalized: '%s'\n", cstr);
+       printf("%s\n", cstr);
+       free(cstr);
+       es_deleteStr(str);
+}
+
+
+/* normalize input data
+ */
+void
+normalize(void)
+{
+       FILE *fp = stdin;
+       char buf[10*1024];
+       es_str_t *str;
+       struct ee_event *event = NULL;
+       es_str_t *constUnparsed;
+       long long unsigned numUnparsed = 0;
+       long long unsigned numWrongTag = 0;
+
+       constUnparsed = es_newStrFromBuf("unparsed-data", 
sizeof("unparsed-data") - 1);
+
+       while((fgets(buf, sizeof(buf), fp)) != NULL) {
+               buf[strlen(buf)-1] = '\0';
+               if(strlen(buf) > 0 && buf[strlen(buf)-1] == '\r')
+                       buf[strlen(buf)-1] = '\0';
+               if(verbose > 0) printf("To normalize: '%s'\n", buf);
+               str = es_newStrFromCStr(buf, strlen(buf));
+               ln_normalize(ctx, str, &event);
+               //printf("normalize result: %d\n", ln_normalizeRec(ctx, 
ctx->ptree, str, 0, &event));
+               if(event != NULL) {
+                       if(   mandatoryTag == NULL
+                          || (mandatoryTag != NULL && ee_EventHasTag(event, 
mandatoryTag))) {
+                               if(   parsedOnly == 1
+                                  && ee_getEventField(event, constUnparsed) != 
NULL){
+                                       numUnparsed++;
+                               } else {
+                                       outputEvent(event);
+                               }
+                       } else {
+                               numWrongTag++;
+                       }
+                       ee_deleteEvent(event);
+                       event = NULL;
+               }
+               es_deleteStr(str);
+       }
+       if(numUnparsed > 0)
+               fprintf(stderr, "%llu unparsable entries\n", numUnparsed);
+       if(numWrongTag > 0)
+               fprintf(stderr, "%llu entries with wrong tag dropped\n", 
numWrongTag);
+       es_deleteStr(constUnparsed);
+}
+
+
+/**
+ * Generate a command file for the GNU DOT tools.
+ */
+static void
+genDOT()
+{
+       es_str_t *str;
+
+       str = es_newStr(1024);
+       ln_genDotPTreeGraph(ctx->ptree, &str);
+       fwrite(es_getBufAddr(str), 1, es_strlen(str), fpDOT);
+}
+
+
+int main(int argc, char *argv[])
+{
+       int opt;
+       char *repository = NULL;
+       
+       while((opt = getopt(argc, argv, "d:e:r:E:vpt:T")) != -1) {
+               switch (opt) {
+               case 'd': /* generate DOT file */
+                       if(!strcmp(optarg, "")) {
+                               fpDOT = stdout;
+                       } else {
+                               if((fpDOT = fopen(optarg, "w")) == NULL) {
+                                       errout("cannot open DOT file");
+                               }
+                       }
+               case 'v':
+                       verbose++;
+                       break;
+               case 'E': /* encoder-specific format string (will be validated 
by encoder) */ 
+                       encFmt = es_newStrFromCStr(optarg, strlen(optarg));
+                       break;
+               case 'p':
+                       parsedOnly = 1;
+                       break;
+               case 'T':
+                       flatTags = 1;
+                       break;
+               case 'e': /* encoder to use */
+                       if(!strcmp(optarg, "json")) {
+                               outfmt = f_json;
+                       } else if(!strcmp(optarg, "xml")) {
+                               outfmt = f_xml;
+                       } else if(!strcmp(optarg, "csv")) {
+                               outfmt = f_csv;
+                       }
+                       break;
+               case 'r': /* rule base to use */
+                       repository = optarg;
+                       break;
+               case 't': /* if given, only messages tagged with the argument
+                            are output */
+                       mandatoryTag = es_newStrFromCStr(optarg, 
strlen(optarg));
+                       break;
+               }
+       }
+       
+       if(repository == NULL) {
+               errout("samples repository must be given");
+       }
+
+       if((ctx = ln_initCtx()) == NULL) {
+               errout("Could not initialize liblognorm context");
+       }
+
+       if((eectx = ee_initCtx()) == NULL) {
+               errout("Could not initialize libee context");
+       }
+       if(flatTags) {
+               ee_setFlags(eectx, EE_CTX_FLAG_INCLUDE_FLAT_TAGS);
+       }
+
+       if(verbose) {
+               ln_setDebugCB(ctx, dbgCallBack, NULL);
+               ln_enableDebug(ctx, 1);
+       }
+       ln_setEECtx(ctx, eectx);
+
+       ln_loadSamples(ctx, repository);
+
+       if(verbose > 0)
+               printf("number of tree nodes: %d\n", ctx->nNodes);
+
+       if(fpDOT != NULL) {
+               genDOT();
+               exit(1);
+       }
+
+       if(verbose > 2) ln_displayPTree(ctx->ptree, 0);
+
+       normalize();
+
+       ln_exitCtx(ctx);
+       return 0;
+}
diff -urN '--exclude=CVS' '--exclude=.cvsignore' '--exclude=.svn' 
'--exclude=.svnignore' old/liblognorm-0.3.4/src/normalizer.c 
new/liblognorm-0.3.5/src/normalizer.c
--- old/liblognorm-0.3.4/src/normalizer.c       2012-04-11 18:52:07.000000000 
+0200
+++ new/liblognorm-0.3.5/src/normalizer.c       1970-01-01 01:00:00.000000000 
+0100
@@ -1,246 +0,0 @@
-/**
- * @file normalizer.c
- * @brief A small tool to normalize data.
- *
- * This is the most basic example demonstrating how to use liblognorm.
- * It loads log samples from the files specified on the command line,
- * reads to-be-normalized data from stdin and writes the normalized
- * form to stdout. Besides being an example, it also carries out useful
- * processing.
- *
- * @author Rainer Gerhards <[email protected]>
- *
- *//*
- * liblognorm - a fast samples-based log normalization library
- * Copyright 2010-2011 by Rainer Gerhards and Adiscon GmbH.
- *
- * This file is part of liblognorm.
- *
- * This library is free software; you can redistribute it and/or
- * modify it under the terms of the GNU Lesser General Public
- * License as published by the Free Software Foundation; either
- * version 2.1 of the License, or (at your option) any later version.
- *
- * This library is distributed in the hope that it will be useful,
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
- * Lesser General Public License for more details.
- *
- * You should have received a copy of the GNU Lesser General Public
- * License along with this library; if not, write to the Free Software
- * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA  02110-1301  
USA
- *
- * A copy of the LGPL v2.1 can be found in the file "COPYING" in this 
distribution.
- */
-#include <stdio.h>
-#include <string.h>
-#include <getopt.h>
-#include <libestr.h>
-#include <libee/libee.h>
-#include "liblognorm.h"
-#include "ptree.h"
-#include "lognorm.h"
-
-static ln_ctx ctx;
-static ee_ctx eectx;
-
-static int verbose = 0;
-static int parsedOnly = 0;     /**< output unparsed messages? */
-static int flatTags = 0;       /**< output unparsed messages? */
-static FILE *fpDOT;
-static es_str_t *encFmt = NULL; /**< a format string for encoder use */
-static es_str_t *mandatoryTag = NULL; /**< tag which must be given so that 
mesg will
-                                          be output. NULL=all */
-static enum { f_syslog, f_json, f_xml, f_csv } outfmt = f_syslog;
-
-void
-dbgCallBack(void __attribute__((unused)) *cookie, char *msg,
-           size_t __attribute__((unused)) lenMsg)
-{
-       printf("liblognorm: %s\n", msg);
-}
-
-void errout(char *errmsg)
-{
-       fprintf(stderr, "%s\n", errmsg);
-       exit(1);
-}
-
-
-/* param str is just a performance enhancement, which saves us re-creation
- * of the string on every call.
- */
-static inline void
-outputEvent(struct ee_event *event)
-{
-       char *cstr;
-       es_str_t *str = NULL;
-
-       switch(outfmt) {
-       case f_json:
-               ee_fmtEventToJSON(event, &str);
-               break;
-       case f_syslog:
-               ee_fmtEventToRFC5424(event, &str);
-               break;
-       case f_xml:
-               ee_fmtEventToXML(event, &str);
-               break;
-       case f_csv:
-               ee_fmtEventToCSV(event, &str, encFmt);
-               break;
-       }
-       cstr = es_str2cstr(str, NULL);
-       if(verbose > 0) printf("normalized: '%s'\n", cstr);
-       printf("%s\n", cstr);
-       free(cstr);
-       es_deleteStr(str);
-}
-
-
-/* normalize input data
- */
-void
-normalize(void)
-{
-       FILE *fp = stdin;
-       char buf[10*1024];
-       es_str_t *str;
-       struct ee_event *event = NULL;
-       es_str_t *constUnparsed;
-       long long unsigned numUnparsed = 0;
-       long long unsigned numWrongTag = 0;
-
-       constUnparsed = es_newStrFromBuf("unparsed-data", 
sizeof("unparsed-data") - 1);
-
-       while((fgets(buf, sizeof(buf), fp)) != NULL) {
-               buf[strlen(buf)-1] = '\0';
-               if(strlen(buf) > 0 && buf[strlen(buf)-1] == '\r')
-                       buf[strlen(buf)-1] = '\0';
-               if(verbose > 0) printf("To normalize: '%s'\n", buf);
-               str = es_newStrFromCStr(buf, strlen(buf));
-               ln_normalize(ctx, str, &event);
-               //printf("normalize result: %d\n", ln_normalizeRec(ctx, 
ctx->ptree, str, 0, &event));
-               if(event != NULL) {
-                       if(   mandatoryTag == NULL
-                          || (mandatoryTag != NULL && ee_EventHasTag(event, 
mandatoryTag))) {
-                               if(   parsedOnly == 1
-                                  && ee_getEventField(event, constUnparsed) != 
NULL){
-                                       numUnparsed++;
-                               } else {
-                                       outputEvent(event);
-                               }
-                       } else {
-                               numWrongTag++;
-                       }
-                       ee_deleteEvent(event);
-                       event = NULL;
-               }
-               es_deleteStr(str);
-       }
-       if(numUnparsed > 0)
-               fprintf(stderr, "%llu unparsable entries\n", numUnparsed);
-       if(numWrongTag > 0)
-               fprintf(stderr, "%llu entries with wrong tag dropped\n", 
numWrongTag);
-       es_deleteStr(constUnparsed);
-}
-
-
-/**
- * Generate a command file for the GNU DOT tools.
- */
-static void
-genDOT()
-{
-       es_str_t *str;
-
-       str = es_newStr(1024);
-       ln_genDotPTreeGraph(ctx->ptree, &str);
-       fwrite(es_getBufAddr(str), 1, es_strlen(str), fpDOT);
-}
-
-
-int main(int argc, char *argv[])
-{
-       int opt;
-       char *repository = NULL;
-       
-       while((opt = getopt(argc, argv, "d:e:r:E:vpt:T")) != -1) {
-               switch (opt) {
-               case 'd': /* generate DOT file */
-                       if(!strcmp(optarg, "")) {
-                               fpDOT = stdout;
-                       } else {
-                               if((fpDOT = fopen(optarg, "w")) == NULL) {
-                                       errout("cannot open DOT file");
-                               }
-                       }
-               case 'v':
-                       verbose++;
-                       break;
-               case 'E': /* encoder-specific format string (will be validated 
by encoder) */ 
-                       encFmt = es_newStrFromCStr(optarg, strlen(optarg));
-                       break;
-               case 'p':
-                       parsedOnly = 1;
-                       break;
-               case 'T':
-                       flatTags = 1;
-                       break;
-               case 'e': /* encoder to use */
-                       if(!strcmp(optarg, "json")) {
-                               outfmt = f_json;
-                       } else if(!strcmp(optarg, "xml")) {
-                               outfmt = f_xml;
-                       } else if(!strcmp(optarg, "csv")) {
-                               outfmt = f_csv;
-                       }
-                       break;
-               case 'r': /* rule base to use */
-                       repository = optarg;
-                       break;
-               case 't': /* if given, only messages tagged with the argument
-                            are output */
-                       mandatoryTag = es_newStrFromCStr(optarg, 
strlen(optarg));
-                       break;
-               }
-       }
-       
-       if(repository == NULL) {
-               errout("samples repository must be given");
-       }
-
-       if((ctx = ln_initCtx()) == NULL) {
-               errout("Could not initialize liblognorm context");
-       }
-
-       if((eectx = ee_initCtx()) == NULL) {
-               errout("Could not initialize libee context");
-       }
-       if(flatTags) {
-               ee_setFlags(eectx, EE_CTX_FLAG_INCLUDE_FLAT_TAGS);
-       }
-
-       if(verbose) {
-               ln_setDebugCB(ctx, dbgCallBack, NULL);
-               ln_enableDebug(ctx, 1);
-       }
-       ln_setEECtx(ctx, eectx);
-
-       ln_loadSamples(ctx, repository);
-
-       if(verbose > 0)
-               printf("number of tree nodes: %d\n", ctx->nNodes);
-
-       if(fpDOT != NULL) {
-               genDOT();
-               exit(1);
-       }
-
-       if(verbose > 2) ln_displayPTree(ctx->ptree, 0);
-
-       normalize();
-
-       ln_exitCtx(ctx);
-       return 0;
-}

-- 
To unsubscribe, e-mail: [email protected]
For additional commands, e-mail: [email protected]

Reply via email to