logger.C

00001 /*
00002  * This file is part of the "Archon" framework.
00003  * (http://files3d.sourceforge.net)
00004  *
00005  * Copyright © 2002 by Kristian Spangsege and Brian Kristiansen.
00006  *
00007  * Permission to use, copy, modify, and distribute this software and
00008  * its documentation under the terms of the GNU General Public License is
00009  * hereby granted. No representations are made about the suitability of
00010  * this software for any purpose. It is provided "as is" without express
00011  * or implied warranty. See the GNU General Public License
00012  * (http://www.gnu.org/copyleft/gpl.html) for more details.
00013  *
00014  * The characters in this file are ISO8859-1 encoded.
00015  *
00016  * The documentation in this file is in "Doxygen" style
00017  * (http://www.doxygen.org).
00018  */
00019 
00020 #include <iostream>
00021 
00022 #include <archon/util/thread.H>
00023 
00024 #include <archon/util/logger.H>
00025 
00026 using namespace std;
00027 
00028 namespace Archon
00029 {
00030   namespace Utilities
00031   {
00032     struct StandardLogger: public Logger
00033     {
00034       virtual ~StandardLogger() {}
00035 
00036       Semaphore s;
00037       void log(string message) throw()
00038       {
00039         s.down();
00040         try
00041         {
00042           cerr << message << "\n";
00043         }
00044         catch(...) {}
00045         s.up();
00046       }
00047     };
00048 
00049     Logger *Logger::get()
00050     {
00051       static StandardLogger standardLogger;
00052       return &standardLogger;
00053     }
00054   }
00055 }

Generated on Sun Jul 30 22:55:44 2006 for Archon by  doxygen 1.4.4