Drizzled Public API Documentation

errmsg.cc

00001 /* -*- mode: c++; c-basic-offset: 2; indent-tabs-mode: nil; -*-
00002  *  vim:expandtab:shiftwidth=2:tabstop=2:smarttab:
00003  *
00004  *  Copyright (C) 2010 Mark Atwood
00005  *
00006  *  This program is free software; you can redistribute it and/or modify
00007  *  it under the terms of the GNU General Public License as published by
00008  *  the Free Software Foundation; version 2 of the License.
00009  *
00010  *  This program is distributed in the hope that it will be useful,
00011  *  but WITHOUT ANY WARRANTY; without even the implied warranty of
00012  *  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
00013  *  GNU General Public License for more details.
00014  *
00015  *  You should have received a copy of the GNU General Public License
00016  *  along with this program; if not, write to the Free Software
00017  *  Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA  02110-1301  USA
00018  */
00019 
00020 #include <config.h>
00021 
00022 #include <drizzled/gettext.h>
00023 #include <drizzled/errmsg_print.h>
00024 
00025 #include <stdarg.h>
00026 
00027 #include "errmsg.h"
00028 #include "wrap.h"
00029 
00030 namespace drizzle_plugin
00031 {
00032 
00033 error_message::Syslog::Syslog(const std::string& facility,
00034                               const std::string& priority) :
00035   drizzled::plugin::ErrorMessage("Syslog"),
00036   _facility(WrapSyslog::getFacilityByName(facility.c_str())),
00037   _priority(WrapSyslog::getPriorityByName(priority.c_str()))
00038 {
00039   if (_facility == -1)
00040   {
00041     drizzled::errmsg_printf(drizzled::error::WARN,
00042                             _("syslog facility \"%s\" not known, using \"local0\""),
00043                             facility.c_str());
00044     _facility= WrapSyslog::getFacilityByName("local0");
00045   }
00046 
00047   if (_priority == -1)
00048   {
00049     drizzled::errmsg_printf(drizzled::error::WARN,
00050                             _("syslog priority \"%s\" not known, using \"warn\""),
00051                             priority.c_str());
00052     _priority= WrapSyslog::getPriorityByName("warn");
00053   }
00054 }
00055 
00056 bool error_message::Syslog::errmsg(drizzled::error::level_t, const char *format, va_list ap)
00057 {
00058   WrapSyslog::singleton().vlog(_facility, _priority, format, ap);
00059   return false;
00060 }
00061 
00062 } /* namespace drizzle_plugin */