From: <vo...@us...> - 2009-01-03 12:57:20
|
Revision: 1082 http://opde.svn.sourceforge.net/opde/?rev=1082&view=rev Author: volca Date: 2009-01-03 12:57:16 +0000 (Sat, 03 Jan 2009) Log Message: ----------- Adding a simple asynchronous value handling helper (stores new value of something for later use) Added Paths: ----------- trunk/src/base/ValueChangeRequest.h Added: trunk/src/base/ValueChangeRequest.h =================================================================== --- trunk/src/base/ValueChangeRequest.h (rev 0) +++ trunk/src/base/ValueChangeRequest.h 2009-01-03 12:57:16 UTC (rev 1082) @@ -0,0 +1,57 @@ +/****************************************************************************** + * + * This file is part of openDarkEngine project + * Copyright (C) 2005-2006 openDarkEngine team + * + * This program is free software; you can redistribute it and/or modify + * it under the terms of the GNU General Public License as published by + * the Free Software Foundation; either version 2 of the License, or + * (at your option) any later version. + * + * This program 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 General Public License for more details. + * + * 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., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA + * + * $Id$ + * + *****************************************************************************/ + +#ifndef __VALUECHANGEREQUEST_H +#define __VALUECHANGEREQUEST_H + +namespace Opde { + + /** A value + bool pair used to store requests of particular value (request for setting change). + * A typical usage is a within value change method that modifies a value that should be persistent + * for a defined period of time (one cycle iteration). + */ + template<typename T> class ValueChangeRequest { + public: + /// Constructor + ValueChangeRequest() : mValue() { mRequested = false; }; + + /// A request application method. Call this to set the new desired value + void set(T newVal) { mValue = mValue; mRequested = true; }; + + /** Sets the reference target with the new value if request happened + * @param tgt The target for the value change + * @return true uf value change happened + */ + bool getIfReq(T& tgt) { if (mRequested) { tgt = mValue; mRequested = false; return true; }; return false; }; + + /// getter for the requested value + T requestedVal() { return mValue; }; + + protected: + T mValue; + bool mRequested; + }; + +} + +#endif Property changes on: trunk/src/base/ValueChangeRequest.h ___________________________________________________________________ Added: svn:keywords + Author Date Id Revision Added: svn:eol-style + native This was sent by the SourceForge.net collaborative development platform, the world's largest Open Source development site. |