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