diff options
author | Alan Conway <aconway@apache.org> | 2007-04-13 20:58:27 +0000 |
---|---|---|
committer | Alan Conway <aconway@apache.org> | 2007-04-13 20:58:27 +0000 |
commit | 26a723475dc6926bde883c8c7f983ee44d8deb01 (patch) | |
tree | d3be63007fb9799549310ee31cfd1aae589bfd96 /qpid/cpp/src/framing/ChannelAdapter.cpp | |
parent | 52a1b1fbcaf2935874f8ab7b85a06d09eed4a94c (diff) | |
download | qpid-python-26a723475dc6926bde883c8c7f983ee44d8deb01.tar.gz |
Moved src/ source code to src/qpid directory:
- allows rhm package to build consistently against checked-out or installed qpid.
- consistent correspondence between source paths and C++ namespaces.
- consistent use of #include <qpid/foo> in source and by users.
- allows header files to split over multiple directories,
e.g. separating generated code, separating public API from private files.
git-svn-id: https://svn.apache.org/repos/asf/incubator/qpid/trunk@528668 13f79535-47bb-0310-9956-ffa450edef68
Diffstat (limited to 'qpid/cpp/src/framing/ChannelAdapter.cpp')
-rw-r--r-- | qpid/cpp/src/framing/ChannelAdapter.cpp | 109 |
1 files changed, 0 insertions, 109 deletions
diff --git a/qpid/cpp/src/framing/ChannelAdapter.cpp b/qpid/cpp/src/framing/ChannelAdapter.cpp deleted file mode 100644 index d16934a857..0000000000 --- a/qpid/cpp/src/framing/ChannelAdapter.cpp +++ /dev/null @@ -1,109 +0,0 @@ -/* - * - * Copyright (c) 2006 The Apache Software Foundation - * - * Licensed under the Apache License, Version 2.0 (the "License"); - * you may not use this file except in compliance with the License. - * You may obtain a copy of the License at - * - * http://www.apache.org/licenses/LICENSE-2.0 - * - * Unless required by applicable law or agreed to in writing, software - * distributed under the License is distributed on an "AS IS" BASIS, - * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. - * See the License for the specific language governing permissions and - * limitations under the License. - * - */ -#include <boost/format.hpp> - -#include "ChannelAdapter.h" -#include "AMQFrame.h" -#include "../Exception.h" - -using boost::format; - -namespace qpid { -namespace framing { - -void ChannelAdapter::init( - ChannelId i, OutputHandler& o, ProtocolVersion v) -{ - assertChannelNotOpen(); - id = i; - out = &o; - version = v; -} - -RequestId ChannelAdapter::send( - shared_ptr<AMQBody> body, Correlator::Action action) -{ - RequestId requestId = 0; - assertChannelOpen(); - switch (body->type()) { - case REQUEST_BODY: { - AMQRequestBody::shared_ptr request = - boost::shared_polymorphic_downcast<AMQRequestBody>(body); - requester.sending(request->getData()); - requestId = request->getData().requestId; - if (!action.empty()) - correlator.request(requestId, action); - break; - } - case RESPONSE_BODY: { - AMQResponseBody::shared_ptr response = - boost::shared_polymorphic_downcast<AMQResponseBody>(body); - responder.sending(response->getData()); - break; - } - // No action required for other body types. - } - out->send(new AMQFrame(getVersion(), getId(), body)); - return requestId; -} - -void ChannelAdapter::handleRequest(AMQRequestBody::shared_ptr request) { - assertMethodOk(*request); - AMQRequestBody::Data& requestData = request->getData(); - responder.received(requestData); - handleMethodInContext(request, MethodContext(this, request)); -} - -void ChannelAdapter::handleResponse(AMQResponseBody::shared_ptr response) { - assertMethodOk(*response); - AMQResponseBody::Data& responseData = response->getData(); - - // FIXME aconway 2007-04-05: processed should be last - // but causes problems with InProcessBroker tests because - // we execute client code in handleMethod. - // Need to introduce a queue & 2 threads for inprocess. - requester.processed(responseData); - // FIXME aconway 2007-04-04: exception handling. - correlator.response(response); - handleMethod(response); -} - -void ChannelAdapter::handleMethod(AMQMethodBody::shared_ptr method) { - assertMethodOk(*method); - handleMethodInContext(method, MethodContext(this, method)); -} - -void ChannelAdapter::assertMethodOk(AMQMethodBody& method) const { - if (getId() != 0 && method.amqpClassId() == ConnectionOpenBody::CLASS_ID) - throw ConnectionException( - 504, format("Connection method on non-0 channel %d.")%getId()); -} - -void ChannelAdapter::assertChannelOpen() const { - if (getId() != 0 && !isOpen()) - throw ConnectionException( - 504, format("Channel %d is not open.")%getId()); -} - -void ChannelAdapter::assertChannelNotOpen() const { - if (getId() != 0 && isOpen()) - throw ConnectionException( - 504, format("Channel %d is already open.") % getId()); -} - -}} // namespace qpid::framing |