/**
 * @file
 * $Id$
 * $Revision$
 * $Author$
 * $Date$
 *
 * This file is part of The iWear Framework.
 * In particular this file is part of the Framework Core Library
 *
 * The iWear Framework is free software; you can redistribute it and/or modify
 * it under the terms of the GNU General Public License as published by the
 * Free Software Foundation as in version 2 of the License.

 * 
 * The iWear Framework 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 General Public License for
 * more details.
 * 
 * You should have received a copy of the GNU General Public License along with
 * The iWear Framework; if not, write to the Free Software Foundation, Inc., 59
 * Temple Place, Suite 330, Boston, MA  02111-1307  USA
 */

#ifndef __IWEAR_DEBUGMODULESYSLOG_H
#define __IWEAR_DEBUGMODULESYSLOG_H

#ifndef __IWEAR_DEBUGMODULE_H
#include <iwear/debugmodule.h>
#endif

#include <string>
using std::string;

extern "C" {
#include <syslog.h>
}

namespace iwear
{
/**
 * This output modules logs everything to the syslog facility.
 */
class debugmodulesyslog : public debugmodule/*{{{*/
{
private:
protected:
public:
   /**
    * We need to base a debugmanager reference to the base.
    * @param ident is the identification under which the program will output in
    * the syslog. Usually this should be the process name (argv[0]). After this
    * will be put the pid. The facility is only of special use for the syslog
    * system to seperate into different logfiles. usually the LOG_USER is
    * enough and will put everything into /var/log/messages
    */
    debugmodulesyslog( const string& ident, debugmanager&, int facility = LOG_USER );

   /**
    * This does nothing at the moment
    */
    virtual ~debugmodulesyslog( );

   /**
    * This simply outputs things to syslog
    */
    virtual int log ( const char * msg );
};/*}}}*/

}

#endif

