diff options
author | Stefan Radomski <radomski@tk.informatik.tu-darmstadt.de> | 2013-01-12 23:49:43 (GMT) |
---|---|---|
committer | Stefan Radomski <radomski@tk.informatik.tu-darmstadt.de> | 2013-01-12 23:49:43 (GMT) |
commit | a116aeb2cf5a84fa03f9814c3884561149029267 (patch) | |
tree | bdd7dfc15ec1e38edcc9a7532ffad03fe4f6f823 /src/uscxml/plugins/invoker/scxml/USCXMLInvoker.cpp | |
parent | 6d0622c0bb8f0e52589c82252f2cc1eb847ad9bf (diff) | |
download | uscxml-a116aeb2cf5a84fa03f9814c3884561149029267.zip uscxml-a116aeb2cf5a84fa03f9814c3884561149029267.tar.gz uscxml-a116aeb2cf5a84fa03f9814c3884561149029267.tar.bz2 |
Refactored to PIMPL pattern
Diffstat (limited to 'src/uscxml/plugins/invoker/scxml/USCXMLInvoker.cpp')
-rw-r--r-- | src/uscxml/plugins/invoker/scxml/USCXMLInvoker.cpp | 19 |
1 files changed, 10 insertions, 9 deletions
diff --git a/src/uscxml/plugins/invoker/scxml/USCXMLInvoker.cpp b/src/uscxml/plugins/invoker/scxml/USCXMLInvoker.cpp index b4ee3eb..c90ef4d 100644 --- a/src/uscxml/plugins/invoker/scxml/USCXMLInvoker.cpp +++ b/src/uscxml/plugins/invoker/scxml/USCXMLInvoker.cpp @@ -23,7 +23,7 @@ USCXMLInvoker::~USCXMLInvoker() { delete _invokedInterpreter; }; -Invoker* USCXMLInvoker::create(Interpreter* interpreter) { +InvokerImpl* USCXMLInvoker::create(Interpreter* interpreter) { USCXMLInvoker* invoker = new USCXMLInvoker(); invoker->_parentInterpreter = interpreter; return invoker; @@ -34,7 +34,7 @@ Data USCXMLInvoker::getDataModelVariables() { return data; } -void USCXMLInvoker::send(SendRequest& req) { +void USCXMLInvoker::send(const SendRequest& req) { assert(false); } @@ -42,19 +42,20 @@ void USCXMLInvoker::cancel(const std::string sendId) { assert(false); } -void USCXMLInvoker::sendToParent(SendRequest& req) { - req.invokeid = _invokeId; - _parentInterpreter->receive(req); +void USCXMLInvoker::sendToParent(const SendRequest& req) { + SendRequest parentReq = req; + parentReq.invokeid = _invokeId; + _parentInterpreter->receive(parentReq); } -void USCXMLInvoker::invoke(InvokeRequest& req) { +void USCXMLInvoker::invoke(const InvokeRequest& req) { _invokeId = req.invokeid; _invokedInterpreter = Interpreter::fromURI(req.src); - DataModel* dataModel = _invokedInterpreter->getDataModel(); - if (dataModel != NULL) { + DataModel dataModel(_invokedInterpreter->getDataModel()); + if (dataModel) { } - _invokedInterpreter->setInvoker(this); + _invokedInterpreter->setInvoker(boost::static_pointer_cast<InvokerImpl>(shared_from_this())); _invokedInterpreter->start(); } |