log.h

Go to the documentation of this file.
00001 /** @file nub/log.h functions for hierarchical logging */
00002 
00003 ///////////////////////////////////////////////////////////////////////
00004 //
00005 // Copyright (c) 2001-2004 California Institute of Technology
00006 // Copyright (c) 2004-2007 University of Southern California
00007 // Rob Peters <rjpeters at usc dot edu>
00008 //
00009 // created: Wed Jun 20 17:47:13 2001
00010 // commit: $Id: log.h 8249 2007-04-12 06:03:40Z rjpeters $
00011 // $HeadURL: svn://isvn.usc.edu/software/invt/trunk/saliency/src/nub/log.h $
00012 //
00013 // --------------------------------------------------------------------
00014 //
00015 // This file is part of GroovX.
00016 //   [http://ilab.usc.edu/rjpeters/groovx/]
00017 //
00018 // GroovX is free software; you can redistribute it and/or modify it
00019 // under the terms of the GNU General Public License as published by
00020 // the Free Software Foundation; either version 2 of the License, or
00021 // (at your option) any later version.
00022 //
00023 // GroovX is distributed in the hope that it will be useful, but
00024 // WITHOUT ANY WARRANTY; without even the implied warranty of
00025 // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
00026 // General Public License for more details.
00027 //
00028 // You should have received a copy of the GNU General Public License
00029 // along with GroovX; if not, write to the Free Software Foundation,
00030 // Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA.
00031 //
00032 ///////////////////////////////////////////////////////////////////////
00033 
00034 #ifndef GROOVX_NUB_LOG_H_UTC20050626084019_DEFINED
00035 #define GROOVX_NUB_LOG_H_UTC20050626084019_DEFINED
00036 
00037 namespace rutz
00038 {
00039   class fstring;
00040 }
00041 
00042 namespace nub
00043 {
00044   class object;
00045 
00046   /// Functions for hierarchical logging.
00047   namespace logging
00048   {
00049     void reset();
00050 
00051     void add_scope(const rutz::fstring& name);
00052     void remove_scope(const rutz::fstring& name);
00053 
00054     /// Add a scope named after the given object's type + id.
00055     void add_obj_scope(const nub::object& obj);
00056 
00057     /// Remove the scope named after the given object's type + id.
00058     void remove_obj_scope(const nub::object& obj);
00059 
00060     /// Specify the name of a file to which log info should be appended.
00061     void set_log_filename(const rutz::fstring& filename);
00062 
00063     /// Specify whether to copy log output to stdout (default = yes).
00064     void copy_to_stdout(bool shouldcopy);
00065   }
00066 
00067   void log(const char* msg);
00068   void log(const rutz::fstring& msg);
00069 }
00070 
00071 static const char __attribute__((used)) vcid_groovx_nub_log_h_utc20050626084019[] = "$Id: log.h 8249 2007-04-12 06:03:40Z rjpeters $ $HeadURL: svn://isvn.usc.edu/software/invt/trunk/saliency/src/nub/log.h $";
00072 #endif // !GROOVX_NUB_LOG_H_UTC20050626084019_DEFINED
Generated on Sun May 8 08:41:07 2011 for iLab Neuromorphic Vision Toolkit by  doxygen 1.6.3