1 /*
2 * Copyright 2008, The Android Open Source Project
3 *
4 * Redistribution and use in source and binary forms, with or without
5 * modification, are permitted provided that the following conditions
6 * are met:
7 * * Redistributions of source code must retain the above copyright
8 * notice, this list of conditions and the following disclaimer.
9 * * Redistributions in binary form must reproduce the above copyright
10 * notice, this list of conditions and the following disclaimer in the
11 * documentation and/or other materials provided with the distribution.
12 *
13 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS ``AS IS'' AND ANY
14 * EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
15 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
16 * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL APPLE COMPUTER, INC. OR
17 * CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
18 * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
19 * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR
20 * PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY
21 * OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
22 * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
23 * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
24 */
25
26 #define LOG_TAG "plugin"
27
28 #include "utils/Log.h"
29 #include "android_npapi.h"
30 #include <stdarg.h>
31
anp_log(NPP inst,ANPLogType logType,const char format[],...)32 static void anp_log(NPP inst, ANPLogType logType, const char format[], ...) {
33 va_list args;
34 va_start(args, format);
35
36 android_LogPriority priority;
37 switch (logType) {
38 case kError_ANPLogType:
39 priority = ANDROID_LOG_ERROR;
40 break;
41 case kWarning_ANPLogType:
42 priority = ANDROID_LOG_WARN;
43 break;
44 case kDebug_ANPLogType:
45 priority = ANDROID_LOG_DEBUG;
46 break;
47 default:
48 priority = ANDROID_LOG_UNKNOWN;
49 break;
50 }
51 LOG_PRI_VA(priority, "plugin", format, args);
52
53 va_end(args);
54 }
55
ANPLogInterfaceV0_Init(ANPInterface * value)56 void ANPLogInterfaceV0_Init(ANPInterface* value) {
57 ANPLogInterfaceV0* i = reinterpret_cast<ANPLogInterfaceV0*>(value);
58
59 i->log = anp_log;
60 }
61
62