X-Git-Url: https://git.mxchange.org/?a=blobdiff_plain;f=simgear%2Fdebug%2Flogstream.cxx;h=664038b93a713e57ebcfb368ca0ea5407e236dba;hb=9f88b077ee5294c4ad898016b7d66682466bbafb;hp=e1201bfd9a8683e24bbab487cb13bfeeb25fde78;hpb=82459a2802a939434f9fc5b88d2b2aea58f0043d;p=simgear.git diff --git a/simgear/debug/logstream.cxx b/simgear/debug/logstream.cxx index e1201bfd..664038b9 100644 --- a/simgear/debug/logstream.cxx +++ b/simgear/debug/logstream.cxx @@ -14,20 +14,37 @@ // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Library General Public License for more details. // -// You should have received a copy of the GNU Library 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. +// You should have received a copy of the GNU General Public License +// along with this program; if not, write to the Free Software +// Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. // // $Id$ +#include + #include "logstream.hxx" +logstream *logstream::global_logstream = 0; + bool logbuf::logging_enabled = true; -fgDebugClass logbuf::logClass = FG_NONE; -fgDebugPriority logbuf::logPriority = FG_INFO; +#ifdef _WIN32 + bool logbuf::has_console = true; +#endif +sgDebugClass logbuf::logClass = SG_NONE; +sgDebugPriority logbuf::logPriority = SG_INFO; streambuf* logbuf::sbuf = NULL; +namespace { +struct ignore_me +{ + ignore_me() + { + logstream::initGlobalLogstream(); + } +}; +static ignore_me im; +} + logbuf::logbuf() { // if ( sbuf == NULL ) @@ -50,15 +67,48 @@ logbuf::set_sb( streambuf* sb ) } void -logbuf::set_log_level( fgDebugClass c, fgDebugPriority p ) +logbuf::set_log_level( sgDebugClass c, sgDebugPriority p ) { logClass = c; logPriority = p; } void -logstream::setLogLevels( fgDebugClass c, fgDebugPriority p ) +logbuf::set_log_classes (sgDebugClass c) +{ + logClass = c; +} + +sgDebugClass +logbuf::get_log_classes () +{ + return logClass; +} + +void +logbuf::set_log_priority (sgDebugPriority p) +{ + logPriority = p; +} + +sgDebugPriority +logbuf::get_log_priority () +{ + return logPriority; +} + +void +logstream::setLogLevels( sgDebugClass c, sgDebugPriority p ) { logbuf::set_log_level( c, p ); } +logstream * +logstream::initGlobalLogstream() +{ + // Force initialization of cerr. + static std::ios_base::Init initializer; + if( !global_logstream ) + global_logstream = new logstream(std::cerr); + return global_logstream; +}