summaryrefslogtreecommitdiff
path: root/src/player/PythonLogSink.cpp
blob: 5da5829022841290fd9d052a861fce23d80e67d8 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
//
//  libavg - Media Playback Engine.
//  Copyright (C) 2003-2014 Ulrich von Zadow
//
//  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 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., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA
//
//  Current versions can be found at www.libavg.de

#include "PythonLogSink.h"
#include "WrapPython.h"
#include "../base/Logger.h"

#include <iostream>
#include <boost/algorithm/string.hpp>
#include <boost/python/errors.hpp>

namespace avg
{

PythonLogSink::PythonLogSink(PyObject *pyLogger):
    m_pyLogger(pyLogger)
{
    Py_INCREF(pyLogger);
    assert(pyLogger);
}

PythonLogSink::~PythonLogSink()
{
    Py_DecRef(m_pyLogger);
}

const char * PythonLogSink::LogSeverityToPythonString(severity_t severity)
{
    if(severity == Logger::severity::CRITICAL) {
        return "critical";
    } else if(severity == Logger::severity::ERROR) {
        return "error";
    } else if(severity == Logger::severity::WARNING) {
        return "warning";
    } else if(severity == Logger::severity::INFO) {
        return "info";
    } else if(severity == Logger::severity::DEBUG) {
        return "debug";
    }
    throw Exception(AVG_ERR_UNKNOWN, "Unkown log severity");
}

void PythonLogSink::logMessage(const tm* pTime, unsigned millis,
        const category_t& category, severity_t severity, const UTF8String& sMsg)
{
    try {
        aquirePyGIL aquireGil;
        PyObject * extra = PyDict_New();
        PyObject * pyCat = PyString_FromString(category.c_str());

        PyDict_SetItemString(extra, "category", pyCat);

        PyObject * pyMsg = PyString_FromString(sMsg.c_str());
        PyObject * args = PyTuple_New(1);
        PyObject * kwargs = PyDict_New();
        PyDict_SetItemString(kwargs, "extra", extra);
        PyTuple_SetItem(args, 0, pyMsg);

        PyObject_Call(PyObject_GetAttrString(m_pyLogger,
                LogSeverityToPythonString(severity)), args, kwargs);

        Py_DECREF(extra);
        Py_DECREF(pyCat);
        Py_DECREF(args);
        Py_DECREF(kwargs);
    } catch (const boost::python::error_already_set &) {
        std::cerr << "PythonLogSink: Python raised exception\n";
    } catch (const exception &) {
        std::cerr << "PythonLogSink: Couldn't log to python logger.\n";
    }
}

}