/* * Copyright (c) 2016, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it * under the terms of the GNU General Public License version 2 only, as * published by the Free Software Foundation. * * This code 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 General Public License * version 2 for more details (a copy is included in the LICENSE file that * accompanied this code). * * You should have received a copy of the GNU General Public License version * 2 along with this work; if not, write to the Free Software Foundation, * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. * * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA * or visit www.oracle.com if you need additional information or have any * questions. * */ #ifndef SHARE_VM_LOGGING_LOGSTREAM_INLINE_HPP #define SHARE_VM_LOGGING_LOGSTREAM_INLINE_HPP #include "logging/log.hpp" #include "logging/logHandle.hpp" #include "logging/logStream.hpp" #include "memory/resourceArea.hpp" #include "utilities/ostream.hpp" inline void LogStreamNoResourceMark::print(const char* fmt, ...) { va_list args; va_start(args, fmt); _log_func(fmt, args); va_end(args); } inline void LogStreamNoResourceMark::write(const char* s, size_t len) { if (len > 0 && s[len - 1] == '\n') { _current_line.write(s, len - 1); print("%s", _current_line.as_string()); _current_line.reset(); } else { _current_line.write(s, len); } update_position(s, len); } // An output stream that logs to the logging framework, and embeds a ResourceMark. // // The class is intended to be stack allocated. // Care needs to be taken when nested ResourceMarks are used. class LogStream : public outputStream { private: ResourceMark _embedded_resource_mark; LogStreamNoResourceMark _stream; public: // Constructor to support creation from a LogTarget instance. // // LogTarget(Debug, gc) log; // LogStream(log) stream; template LogStream(const LogTargetImpl& type_carrier) : _embedded_resource_mark(), _stream(&LogImpl::template vwrite) {} // Constructor to support creation from typed (likely NULL) pointer. Mostly used by the logging framework. // // LogStream stream(log.debug()); // LogStream stream((LogTargetImpl*)NULL); template LogStream(const LogTargetImpl* type_carrier) : _embedded_resource_mark(), _stream(&LogImpl::template vwrite) {} // Constructor to support creation from a LogTargetHandle. // // LogTargt(Debug, gc) log; // LogTargetHandle(log) handle; // LogStream stream(handle); LogStream(LogTargetHandle handle) : _embedded_resource_mark(), _stream(handle._vwrite) {} // Override of outputStream::write. void write(const char* s, size_t len) { _stream.write(s, len); } }; // Support creation of a LogStream without having to provide a LogTarget pointer. #define LogStreamHandle(level, ...) LogStreamTemplate template class LogStreamTemplate : public LogStream { public: LogStreamTemplate() : LogStream((LogTargetImpl*)NULL) {} }; #endif // SHARE_VM_LOGGING_LOGSTREAM_INLINE_HPP