LUMIERA.clone/tests/core/proc/control/command-basic-test.cpp

125 lines
3.4 KiB
C++
Raw Normal View History

/*
CommandBasic(Test) - checking simple ProcDispatcher command definition and execution
2010-12-17 23:28:49 +01:00
Copyright (C) Lumiera.org
2009, Hermann Vosseler <Ichthyostega@web.de>
2010-12-17 23:28:49 +01:00
This program is free software; you can redistribute it and/or
modify it under the terms of the GNU General Public License as
2010-12-17 23:28:49 +01:00
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.
2010-12-17 23:28:49 +01:00
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., 675 Mass Ave, Cambridge, MA 02139, USA.
2010-12-17 23:28:49 +01:00
* *****************************************************/
#include "lib/test/run.hpp"
#include "proc/control/command-def.hpp"
#include "lib/time/timevalue.hpp"
#include "lib/p.hpp"
#include <cstdlib>
using std::rand;
namespace proc {
namespace control {
namespace test {
using lib::P;
using lib::time::Time;
using lib::time::TimeVar;
using lib::time::TimeValue;
namespace { // functions to be invoked through the command system
2009-10-06 05:11:30 +02:00
void
operate (P<TimeVar> dummyObj, int randVal)
{
*dummyObj += TimeValue(randVal);
}
TimeVar
capture (P<TimeVar> dummyObj, int)
{
return *dummyObj;
}
void
undoIt (P<TimeVar> dummyObj, int, TimeVar oldVal)
{
*dummyObj = oldVal;
}
}
/***************************************************************************
* @test basic usage of the Proc-Layer command dispatch system.
* Shows how to define a simple command inline and how to
* trigger execution and UNDO. Verifies the command action
* takes place and is reverted again by the UNDO function.
2009-10-06 05:11:30 +02:00
*
* This is a simplified demonstration. Usually, commands would be defined
* in bulk and without specifying parameters. Later, typically client code
* accesses a handle by ID, binds to the concrete argument and dispatches
* the invocation. Note in this example that by using a smart-ptr as
* argument allows accessing an object by reference and late binding.
*
* @see control::Command
* @see control::CommandDef
* @see mobject::ProcDispatcher
*/
class CommandBasic_test : public Test
{
virtual void
run (Arg)
{
2009-06-15 04:57:23 +02:00
int randVal ((rand() % 10) - 5);
Time five(TimeValue(5));
TimeValue randomTime(randVal);
P<TimeVar> obj (new TimeVar(five));
2009-06-15 04:57:23 +02:00
CommandDef ("test.command1")
.operation (operate)
.captureUndo (capture)
.undoOperation (undoIt)
2009-06-15 04:57:23 +02:00
.bind (obj, randVal)
;
Command ourCmd = Command::get("test.command1");
// invoke the command
CHECK (*obj == five);
ourCmd();
CHECK (*obj == five + randomTime);
// undo the effect of the command
ourCmd.undo();
CHECK (*obj == five);
}
};
/** Register this test class... */
LAUNCHER (CommandBasic_test, "unit controller");
2009-10-06 05:11:30 +02:00
}}} // namespace proc::control::test