diff options
Diffstat (limited to 'M4-RCs/qpid/cpp/src/qpid/cluster/ConnectionCodec.cpp')
-rw-r--r-- | M4-RCs/qpid/cpp/src/qpid/cluster/ConnectionCodec.cpp | 82 |
1 files changed, 0 insertions, 82 deletions
diff --git a/M4-RCs/qpid/cpp/src/qpid/cluster/ConnectionCodec.cpp b/M4-RCs/qpid/cpp/src/qpid/cluster/ConnectionCodec.cpp deleted file mode 100644 index 44e40f0591..0000000000 --- a/M4-RCs/qpid/cpp/src/qpid/cluster/ConnectionCodec.cpp +++ /dev/null @@ -1,82 +0,0 @@ -/* - * - * Licensed to the Apache Software Foundation (ASF) under one - * or more contributor license agreements. See the NOTICE file - * distributed with this work for additional information - * regarding copyright ownership. The ASF licenses this file - * to you 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 "ConnectionCodec.h" -#include "Connection.h" -#include "Cluster.h" -#include "ProxyInputHandler.h" -#include "qpid/broker/Connection.h" -#include "qpid/framing/ConnectionCloseBody.h" -#include "qpid/framing/ConnectionCloseOkBody.h" -#include "qpid/log/Statement.h" -#include "qpid/memory.h" -#include <stdexcept> -#include <boost/utility/in_place_factory.hpp> - -namespace qpid { -namespace cluster { - -using namespace framing; - -sys::ConnectionCodec* -ConnectionCodec::Factory::create(ProtocolVersion v, sys::OutputControl& out, const std::string& id) { - if (v == ProtocolVersion(0, 10)) - return new ConnectionCodec(out, id, cluster, false); - else if (v == ProtocolVersion(0x80 + 0, 0x80 + 10)) - return new ConnectionCodec(out, id, cluster, true); // Catch-up connection - return 0; -} - -// Used for outgoing Link connections, we don't care. -sys::ConnectionCodec* -ConnectionCodec::Factory::create(sys::OutputControl& out, const std::string& id) { - return next->create(out, id); -} - -ConnectionCodec::ConnectionCodec(sys::OutputControl& out, const std::string& id, Cluster& cluster, bool catchUp) - : codec(out, id, false), - interceptor(new Connection(cluster, codec, id, cluster.getId(), catchUp)), - id(interceptor->getId()), - localId(id) -{ - std::auto_ptr<sys::ConnectionInputHandler> ih(new ProxyInputHandler(interceptor)); - codec.setInputHandler(ih); - if (!catchUp) // Don't put catchUp connections in the cluster map. - cluster.insert(interceptor); -} - -ConnectionCodec::~ConnectionCodec() {} - -size_t ConnectionCodec::decode(const char* buffer, size_t size) { - QPID_LOG(trace, "RECVB [" << localId << "]: " << size << " bytes"); - return interceptor->decode(buffer, size); -} - -bool ConnectionCodec::isClosed() const { return codec.isClosed(); } - -size_t ConnectionCodec::encode(const char* buffer, size_t size) { return codec.encode(buffer, size); } - -bool ConnectionCodec::canEncode() { return codec.canEncode(); } - -void ConnectionCodec::closed() { codec.closed(); } - -ProtocolVersion ConnectionCodec::getVersion() const { return codec.getVersion(); } - -}} // namespace qpid::cluster |