vm/include/open/vm_log.h (38 lines of code) (raw):

/* * Licensed to the Apache Software Foundation (ASF) under one or more * contributor license agreements. See the NOTICE file distributed with * this work for additional information regarding copyright ownership. * The ASF licenses this file to You under the Apache License, Version 2.0 * (the "License"); you may not use this file except in compliance with * the License. You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ #ifndef _VM_LOG_H_ #define _VM_LOG_H_ /** * @file * VM-oriented convenience enhancements to logger. */ #include "loggerstring.h" #include "jni.h" #include "open/vm.h" #include "open/vm_method_access.h" /** * The convenience method for logging Class instances. */ inline LoggerString& operator<<(LoggerString& log, const Class_Handle clss) { if (clss) { log << class_get_name(clss); } else { log << "<null class>"; } return log; } /** * The convenience method for logging Method handles. */ inline LoggerString& operator<<(LoggerString& log, const Method_Handle m) { if (m) { log << method_get_class(m) << "." << method_get_name(m) << method_get_descriptor(m); } else { log << "<null method>"; } return log; } /** * The convenience method for logging JNI method IDs. */ inline LoggerString& operator<<(LoggerString& log, const jmethodID m) { return log << reinterpret_cast<const Method_Handle>(m); } /** * The convenience method for logging jboolean values. */ inline LoggerString& operator<<(LoggerString& log, const jboolean b) { if (b == JNI_FALSE) { log << "false"; } else if (b == JNI_TRUE) { log << "true"; } else { log << "(jboolean) " << ((unsigned) b); } return log; } #endif // _VM_LOG_H_