// -*-C++-*- /* src/observe/EchoObserver.cpp */ /* * Author: Philogelos A. <Philogelos@yahoo.com> * Maintainer: Philogelos A. * Keywords: C++, library, containers * * Copyright (C) 1998 Philogelos A. * * This file is part of Quercus Robusta. * * Quercus Robusta is free software; you can redistribute it and/or modify * it under the terms of the GNU Library General Public License as published by * the Free Software Foundation; either version 2, or (at your option) * any later version. * * This software 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 Library General Public License for more details. * * You should have received a copy of the GNU Library General Public License * along with this software; see the file COPYING.LIB. If not, write to the * Free Software Foundation, Inc., 59 Temple Place - Suite 330, * Boston, MA 02111-1307, USA. * */ /* $Id: EchoObserver.cpp,v 1.3 1999/05/22 13:00:56 philogelos Exp $ */ #if !defined(_INLINE) static char cvsid[] = "@(#)$Id: EchoObserver.cpp,v 1.3 1999/05/22 13:00:56 philogelos Exp $"; static char debugFileId[] = __FILE__; #endif #include "observe/EchoObserver.hpp" #include "Condition.hpp" #include "String.hpp" #include "OGuard.hpp" #include "Debug.hpp" EchoObserver::EchoObserver() { hitCount = 0; } EchoObserver::~EchoObserver() {} HandlerResult EchoObserver::fire( Condition *aCondition, ObservationContext *aContext ) { preC_( aCondition != ( Condition * ) NIL ); preC_( aContext != ( ObservationContext * ) NIL ); OGuard _condition( aCondition, this ); OGuard _context( aContext, this ); ++hitCount; Debug::getLogger() -> logObject( "beholding: ``%s''", aCondition ); Debug::getLogger() -> logObject( "in context ``%s'' ", aContext ); Debug::getLogger() -> log( "totally: %li hits", hitCount ); if( aContext -> isAt( this ) ) { Debug::getLogger() -> log( "Already was here!" ); } else { aContext -> setBy( this, new String( "Wizard of Yendor was here!" ) ); } return 0; } Top *EchoObserver::clone() const { return new EchoObserver(); } String EchoObserver::getClassName() const { return "EchoObserver"; } #if defined(_INLINE) #include "../src/Debug.ipp" #endif /* $Log: EchoObserver.cpp,v $ * Revision 1.3 1999/05/22 13:00:56 philogelos * Merging sources back from SPARC * * Revision 1.2 1999/03/03 19:09:47 philogelos * Put sources under GNU Library License * * Revision 1.1 1999/02/28 16:30:50 philogelos * Tuned for inlines. * */