00001
00002
00003
00004
00005
00006
00007
00008
00009
00010
00011
00012
00013
00014
00015
00016
00017
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 }