Impala
Impalaistheopensource,nativeanalyticdatabaseforApacheHadoop.
 All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Friends Macros
NativeLogger.java
Go to the documentation of this file.
1 // Copyright 2012 Cloudera Inc.
2 //
3 // Licensed under the Apache License, Version 2.0 (the "License");
4 // you may not use this file except in compliance with the License.
5 // You may obtain a copy of the License at
6 //
7 // http://www.apache.org/licenses/LICENSE-2.0
8 //
9 // Unless required by applicable law or agreed to in writing, software
10 // distributed under the License is distributed on an "AS IS" BASIS,
11 // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
12 // See the License for the specific language governing permissions and
13 // limitations under the License.
14 
15 package com.cloudera.impala.util;
16 
17 import org.slf4j.Logger;
18 import org.slf4j.LoggerFactory;
19 
24 public class NativeLogger {
25  private final static Logger LOG = LoggerFactory.getLogger(NativeLogger.class);
26  private static boolean loaded_ = false;
27 
28  // Writes a log message to glog
29  private native static void Log(int severity, String msg, String filename, int line);
30 
31  public static void LogToGlog(int severity, String msg, String filename, int line) {
32  try {
33  Log(severity, msg, filename, line);
34  } catch (UnsatisfiedLinkError e) {
35  loadLibrary();
36  Log(severity, msg, filename, line);
37  }
38  }
39 
43  private static synchronized void loadLibrary() {
44  if (loaded_) return;
45  NativeLibUtil.loadLibrary("libloggingsupport.so");
46  loaded_ = true;
47  }
48 }
static native void Log(int severity, String msg, String filename, int line)
static synchronized void loadLibrary()
static void LogToGlog(int severity, String msg, String filename, int line)