mirror of
https://github.com/aria2/aria2.git
synced 2025-04-05 21:47:37 +03:00
2009-04-21 Tatsuhiro Tsujikawa <t-tujikawa@users.sourceforge.net>
Rewritten event dispatch in BtMessage. Removed BtEventListener, BtEvent. * src/AbstractBtEventListener.h: Removed. * src/AbstractBtMessage.cc * src/AbstractBtMessage.h * src/BtAbortOutstandingRequestEvent.h * src/BtCancelSendingPieceEvent.h * src/BtChokedEvent.h: Removed. * src/BtChokingEvent.h * src/BtEvent.h: Removed * src/BtEventListener.h: Removed. * src/BtMessage.h * src/BtPieceMessage.cc * src/BtPieceMessage.h * src/BtRequestMessage.cc * src/BtRequestMessage.h * src/DefaultBtMessageDispatcher.cc * src/Makefile.am * src/a2functional.h * test/BtPieceMessageTest.cc * test/BtRequestMessageTest.cc * test/DefaultBtMessageDispatcherTest.cc * test/MockBtMessage.h
This commit is contained in:
parent
82b0d66505
commit
afdd61f9d1
23 changed files with 150 additions and 485 deletions
26
ChangeLog
26
ChangeLog
|
@ -1,3 +1,29 @@
|
||||||
|
2009-04-21 Tatsuhiro Tsujikawa <t-tujikawa@users.sourceforge.net>
|
||||||
|
|
||||||
|
Rewritten event dispatch in BtMessage. Removed BtEventListener,
|
||||||
|
BtEvent.
|
||||||
|
* src/AbstractBtEventListener.h: Removed.
|
||||||
|
* src/AbstractBtMessage.cc
|
||||||
|
* src/AbstractBtMessage.h
|
||||||
|
* src/BtAbortOutstandingRequestEvent.h
|
||||||
|
* src/BtCancelSendingPieceEvent.h
|
||||||
|
* src/BtChokedEvent.h: Removed.
|
||||||
|
* src/BtChokingEvent.h
|
||||||
|
* src/BtEvent.h: Removed
|
||||||
|
* src/BtEventListener.h: Removed.
|
||||||
|
* src/BtMessage.h
|
||||||
|
* src/BtPieceMessage.cc
|
||||||
|
* src/BtPieceMessage.h
|
||||||
|
* src/BtRequestMessage.cc
|
||||||
|
* src/BtRequestMessage.h
|
||||||
|
* src/DefaultBtMessageDispatcher.cc
|
||||||
|
* src/Makefile.am
|
||||||
|
* src/a2functional.h
|
||||||
|
* test/BtPieceMessageTest.cc
|
||||||
|
* test/BtRequestMessageTest.cc
|
||||||
|
* test/DefaultBtMessageDispatcherTest.cc
|
||||||
|
* test/MockBtMessage.h
|
||||||
|
|
||||||
2009-04-17 Tatsuhiro Tsujikawa <t-tujikawa@users.sourceforge.net>
|
2009-04-17 Tatsuhiro Tsujikawa <t-tujikawa@users.sourceforge.net>
|
||||||
|
|
||||||
Code cleanup
|
Code cleanup
|
||||||
|
|
|
@ -1,59 +0,0 @@
|
||||||
/* <!-- copyright */
|
|
||||||
/*
|
|
||||||
* aria2 - The high speed download utility
|
|
||||||
*
|
|
||||||
* Copyright (C) 2006 Tatsuhiro Tsujikawa
|
|
||||||
*
|
|
||||||
* 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., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
|
|
||||||
*
|
|
||||||
* In addition, as a special exception, the copyright holders give
|
|
||||||
* permission to link the code of portions of this program with the
|
|
||||||
* OpenSSL library under certain conditions as described in each
|
|
||||||
* individual source file, and distribute linked combinations
|
|
||||||
* including the two.
|
|
||||||
* You must obey the GNU General Public License in all respects
|
|
||||||
* for all of the code used other than OpenSSL. If you modify
|
|
||||||
* file(s) with this exception, you may extend this exception to your
|
|
||||||
* version of the file(s), but you are not obligated to do so. If you
|
|
||||||
* do not wish to do so, delete this exception statement from your
|
|
||||||
* version. If you delete this exception statement from all source
|
|
||||||
* files in the program, then also delete it here.
|
|
||||||
*/
|
|
||||||
/* copyright --> */
|
|
||||||
#ifndef _D_ABSTRACT_BT_EVENT_LISTENER_H_
|
|
||||||
#define _D_ABSTRACT_BT_EVENT_LISTENER_H_
|
|
||||||
|
|
||||||
#include "BtEventListener.h"
|
|
||||||
|
|
||||||
namespace aria2 {
|
|
||||||
|
|
||||||
class AbstractBtEventListener : public BtEventListener {
|
|
||||||
public:
|
|
||||||
virtual ~AbstractBtEventListener() {}
|
|
||||||
|
|
||||||
virtual bool canHandle(const SharedHandle<BtEvent>& event) = 0;
|
|
||||||
|
|
||||||
virtual void handleEventInternal(const SharedHandle<BtEvent>& event) = 0;
|
|
||||||
|
|
||||||
virtual void handleEvent(const SharedHandle<BtEvent>& event) {
|
|
||||||
if(canHandle(event)) {
|
|
||||||
handleEventInternal(event);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
};
|
|
||||||
|
|
||||||
} // namespace aria2
|
|
||||||
|
|
||||||
#endif // _D_ABSTRACT_BT_EVENT_LISTENER_H_
|
|
|
@ -36,7 +36,6 @@
|
||||||
#include "Peer.h"
|
#include "Peer.h"
|
||||||
#include "BtContext.h"
|
#include "BtContext.h"
|
||||||
#include "PieceStorage.h"
|
#include "PieceStorage.h"
|
||||||
#include "BtEventListener.h"
|
|
||||||
#include "BtMessageValidator.h"
|
#include "BtMessageValidator.h"
|
||||||
#include "LogFactory.h"
|
#include "LogFactory.h"
|
||||||
#include "Logger.h"
|
#include "Logger.h"
|
||||||
|
@ -74,20 +73,6 @@ bool AbstractBtMessage::validate(std::deque<std::string>& errors)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void AbstractBtMessage::handleEvent(const SharedHandle<BtEvent>& event)
|
|
||||||
{
|
|
||||||
for(std::deque<SharedHandle<BtEventListener> >::iterator itr = listeners.begin();
|
|
||||||
itr != listeners.end(); ++itr) {
|
|
||||||
(*itr)->handleEvent(event);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
void
|
|
||||||
AbstractBtMessage::addEventListener(const SharedHandle<BtEventListener>& listener)
|
|
||||||
{
|
|
||||||
listeners.push_back(listener);
|
|
||||||
}
|
|
||||||
|
|
||||||
void
|
void
|
||||||
AbstractBtMessage::setBtMessageValidator(const SharedHandle<BtMessageValidator>& validator) {
|
AbstractBtMessage::setBtMessageValidator(const SharedHandle<BtMessageValidator>& validator) {
|
||||||
this->validator = validator;
|
this->validator = validator;
|
||||||
|
|
|
@ -48,7 +48,6 @@ class BtMessageFactory;
|
||||||
class BtRequestFactory;
|
class BtRequestFactory;
|
||||||
class PeerConnection;
|
class PeerConnection;
|
||||||
class BtMessageValidator;
|
class BtMessageValidator;
|
||||||
class BtEventListener;
|
|
||||||
class Logger;
|
class Logger;
|
||||||
|
|
||||||
class AbstractBtMessage : public BtMessage {
|
class AbstractBtMessage : public BtMessage {
|
||||||
|
@ -76,8 +75,6 @@ protected:
|
||||||
|
|
||||||
SharedHandle<BtMessageValidator> validator;
|
SharedHandle<BtMessageValidator> validator;
|
||||||
|
|
||||||
std::deque<SharedHandle<BtEventListener> > listeners;
|
|
||||||
|
|
||||||
Logger* logger;
|
Logger* logger;
|
||||||
public:
|
public:
|
||||||
AbstractBtMessage(uint8_t id, const std::string& name);
|
AbstractBtMessage(uint8_t id, const std::string& name);
|
||||||
|
@ -126,9 +123,13 @@ public:
|
||||||
|
|
||||||
virtual void onQueued() {}
|
virtual void onQueued() {}
|
||||||
|
|
||||||
virtual void handleEvent(const SharedHandle<BtEvent>& event);
|
virtual void onAbortOutstandingRequestEvent
|
||||||
|
(const BtAbortOutstandingRequestEvent& event) {}
|
||||||
|
|
||||||
void addEventListener(const SharedHandle<BtEventListener>& listener);
|
virtual void onCancelSendingPieceEvent
|
||||||
|
(const BtCancelSendingPieceEvent& event) {}
|
||||||
|
|
||||||
|
virtual void onChokingEvent(const BtChokingEvent& event) {}
|
||||||
|
|
||||||
void setBtMessageValidator(const SharedHandle<BtMessageValidator>& validator);
|
void setBtMessageValidator(const SharedHandle<BtMessageValidator>& validator);
|
||||||
|
|
||||||
|
|
|
@ -35,29 +35,22 @@
|
||||||
#ifndef _D_BT_ABORT_OUTSTANDING_REQUEST_EVENT_H_
|
#ifndef _D_BT_ABORT_OUTSTANDING_REQUEST_EVENT_H_
|
||||||
#define _D_BT_ABORT_OUTSTANDING_REQUEST_EVENT_H_
|
#define _D_BT_ABORT_OUTSTANDING_REQUEST_EVENT_H_
|
||||||
|
|
||||||
#include "BtEvent.h"
|
#include "common.h"
|
||||||
|
#include "SharedHandle.h"
|
||||||
|
#include "Piece.h"
|
||||||
|
|
||||||
namespace aria2 {
|
namespace aria2 {
|
||||||
|
|
||||||
class Piece;
|
class BtAbortOutstandingRequestEvent {
|
||||||
|
|
||||||
class BtAbortOutstandingRequestEvent : public BtEvent {
|
|
||||||
private:
|
private:
|
||||||
SharedHandle<Piece> piece;
|
SharedHandle<Piece> piece;
|
||||||
public:
|
public:
|
||||||
BtAbortOutstandingRequestEvent(const SharedHandle<Piece>& piece):piece(piece) {}
|
BtAbortOutstandingRequestEvent(const SharedHandle<Piece>& piece):
|
||||||
|
piece(piece) {}
|
||||||
|
|
||||||
SharedHandle<Piece> getPiece() const {
|
SharedHandle<Piece> getPiece() const { return piece; }
|
||||||
return piece;
|
|
||||||
}
|
|
||||||
|
|
||||||
void setPiece(const SharedHandle<Piece>& piece) {
|
|
||||||
this->piece = piece;
|
|
||||||
}
|
|
||||||
};
|
};
|
||||||
|
|
||||||
typedef SharedHandle<BtAbortOutstandingRequestEvent> BtAbortOutstandingRequestEventHandle;
|
|
||||||
|
|
||||||
} // namespace aria2
|
} // namespace aria2
|
||||||
|
|
||||||
#endif // _D_BT_ABORT_OUTSTANDING_REQUEST_EVENT_H_
|
#endif // _D_BT_ABORT_OUTSTANDING_REQUEST_EVENT_H_
|
||||||
|
|
|
@ -35,11 +35,11 @@
|
||||||
#ifndef _D_BT_CANCEL_SENDING_PIECE_EVENT_H_
|
#ifndef _D_BT_CANCEL_SENDING_PIECE_EVENT_H_
|
||||||
#define _D_BT_CANCEL_SENDING_PIECE_EVENT_H_
|
#define _D_BT_CANCEL_SENDING_PIECE_EVENT_H_
|
||||||
|
|
||||||
#include "BtEvent.h"
|
#include "common.h"
|
||||||
|
|
||||||
namespace aria2 {
|
namespace aria2 {
|
||||||
|
|
||||||
class BtCancelSendingPieceEvent : public BtEvent {
|
class BtCancelSendingPieceEvent {
|
||||||
private:
|
private:
|
||||||
size_t index;
|
size_t index;
|
||||||
uint32_t begin;
|
uint32_t begin;
|
||||||
|
@ -48,35 +48,13 @@ public:
|
||||||
BtCancelSendingPieceEvent(size_t index, uint32_t begin, size_t length):
|
BtCancelSendingPieceEvent(size_t index, uint32_t begin, size_t length):
|
||||||
index(index), begin(begin), length(length) {}
|
index(index), begin(begin), length(length) {}
|
||||||
|
|
||||||
virtual ~BtCancelSendingPieceEvent() {}
|
size_t getIndex() const { return index; }
|
||||||
|
|
||||||
void setIndex(size_t index) {
|
uint32_t getBegin() const { return begin; }
|
||||||
this->index = index;
|
|
||||||
}
|
|
||||||
|
|
||||||
size_t getIndex() const {
|
size_t getLength() const { return length; }
|
||||||
return index;
|
|
||||||
}
|
|
||||||
|
|
||||||
void setBegin(uint32_t begin) {
|
|
||||||
this->begin = begin;
|
|
||||||
}
|
|
||||||
|
|
||||||
uint32_t getBegin() const {
|
|
||||||
return begin;
|
|
||||||
}
|
|
||||||
|
|
||||||
void setLength(size_t length) {
|
|
||||||
this->length = length;
|
|
||||||
}
|
|
||||||
|
|
||||||
size_t getLength() const {
|
|
||||||
return length;
|
|
||||||
}
|
|
||||||
};
|
};
|
||||||
|
|
||||||
typedef SharedHandle<BtCancelSendingPieceEvent> BtCancelSendingPieceEventHandle;
|
|
||||||
|
|
||||||
} // namespace aria2
|
} // namespace aria2
|
||||||
|
|
||||||
#endif // _D_BT_CANCEL_SENDING_PIECE_EVENT_H_
|
#endif // _D_BT_CANCEL_SENDING_PIECE_EVENT_H_
|
||||||
|
|
|
@ -1,50 +0,0 @@
|
||||||
/* <!-- copyright */
|
|
||||||
/*
|
|
||||||
* aria2 - The high speed download utility
|
|
||||||
*
|
|
||||||
* Copyright (C) 2006 Tatsuhiro Tsujikawa
|
|
||||||
*
|
|
||||||
* 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., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
|
|
||||||
*
|
|
||||||
* In addition, as a special exception, the copyright holders give
|
|
||||||
* permission to link the code of portions of this program with the
|
|
||||||
* OpenSSL library under certain conditions as described in each
|
|
||||||
* individual source file, and distribute linked combinations
|
|
||||||
* including the two.
|
|
||||||
* You must obey the GNU General Public License in all respects
|
|
||||||
* for all of the code used other than OpenSSL. If you modify
|
|
||||||
* file(s) with this exception, you may extend this exception to your
|
|
||||||
* version of the file(s), but you are not obligated to do so. If you
|
|
||||||
* do not wish to do so, delete this exception statement from your
|
|
||||||
* version. If you delete this exception statement from all source
|
|
||||||
* files in the program, then also delete it here.
|
|
||||||
*/
|
|
||||||
/* copyright --> */
|
|
||||||
#ifndef _D_BT_CHOKED_EVENT_H_
|
|
||||||
#define _D_BT_CHOKED_EVENT_H_
|
|
||||||
|
|
||||||
#include "BtEvent.h"
|
|
||||||
#include "SharedHandle.h"
|
|
||||||
|
|
||||||
namespace aria2 {
|
|
||||||
|
|
||||||
class BtChokedEvent : public BtEvent {
|
|
||||||
};
|
|
||||||
|
|
||||||
typedef SharedHandle<BtChokedEvent> BtChokedEventHandle;
|
|
||||||
|
|
||||||
} // namespace aria2
|
|
||||||
|
|
||||||
#endif // _D_BT_CHOKED_EVENT_H_
|
|
|
@ -35,14 +35,11 @@
|
||||||
#ifndef _D_BT_CHOKING_EVENT_H_
|
#ifndef _D_BT_CHOKING_EVENT_H_
|
||||||
#define _D_BT_CHOKING_EVENT_H_
|
#define _D_BT_CHOKING_EVENT_H_
|
||||||
|
|
||||||
#include "BtEvent.h"
|
#include "common.h"
|
||||||
|
|
||||||
namespace aria2 {
|
namespace aria2 {
|
||||||
|
|
||||||
class BtChokingEvent : public BtEvent {
|
class BtChokingEvent {};
|
||||||
};
|
|
||||||
|
|
||||||
typedef SharedHandle<BtChokingEvent> BtChokingEventHandle;
|
|
||||||
|
|
||||||
} // namespace aria2
|
} // namespace aria2
|
||||||
|
|
||||||
|
|
|
@ -1,51 +0,0 @@
|
||||||
/* <!-- copyright */
|
|
||||||
/*
|
|
||||||
* aria2 - The high speed download utility
|
|
||||||
*
|
|
||||||
* Copyright (C) 2006 Tatsuhiro Tsujikawa
|
|
||||||
*
|
|
||||||
* 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., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
|
|
||||||
*
|
|
||||||
* In addition, as a special exception, the copyright holders give
|
|
||||||
* permission to link the code of portions of this program with the
|
|
||||||
* OpenSSL library under certain conditions as described in each
|
|
||||||
* individual source file, and distribute linked combinations
|
|
||||||
* including the two.
|
|
||||||
* You must obey the GNU General Public License in all respects
|
|
||||||
* for all of the code used other than OpenSSL. If you modify
|
|
||||||
* file(s) with this exception, you may extend this exception to your
|
|
||||||
* version of the file(s), but you are not obligated to do so. If you
|
|
||||||
* do not wish to do so, delete this exception statement from your
|
|
||||||
* version. If you delete this exception statement from all source
|
|
||||||
* files in the program, then also delete it here.
|
|
||||||
*/
|
|
||||||
/* copyright --> */
|
|
||||||
#ifndef _D_BT_EVENT_H_
|
|
||||||
#define _D_BT_EVENT_H_
|
|
||||||
|
|
||||||
#include "common.h"
|
|
||||||
#include "SharedHandle.h"
|
|
||||||
|
|
||||||
namespace aria2 {
|
|
||||||
class BtEvent {
|
|
||||||
public:
|
|
||||||
virtual ~BtEvent() {}
|
|
||||||
};
|
|
||||||
|
|
||||||
typedef SharedHandle<BtEvent> BtEventHandle;
|
|
||||||
|
|
||||||
} // namespace aria2
|
|
||||||
|
|
||||||
#endif // _D_BT_EVENT_H_
|
|
|
@ -1,58 +0,0 @@
|
||||||
/* <!-- copyright */
|
|
||||||
/*
|
|
||||||
* aria2 - The high speed download utility
|
|
||||||
*
|
|
||||||
* Copyright (C) 2006 Tatsuhiro Tsujikawa
|
|
||||||
*
|
|
||||||
* 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., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
|
|
||||||
*
|
|
||||||
* In addition, as a special exception, the copyright holders give
|
|
||||||
* permission to link the code of portions of this program with the
|
|
||||||
* OpenSSL library under certain conditions as described in each
|
|
||||||
* individual source file, and distribute linked combinations
|
|
||||||
* including the two.
|
|
||||||
* You must obey the GNU General Public License in all respects
|
|
||||||
* for all of the code used other than OpenSSL. If you modify
|
|
||||||
* file(s) with this exception, you may extend this exception to your
|
|
||||||
* version of the file(s), but you are not obligated to do so. If you
|
|
||||||
* do not wish to do so, delete this exception statement from your
|
|
||||||
* version. If you delete this exception statement from all source
|
|
||||||
* files in the program, then also delete it here.
|
|
||||||
*/
|
|
||||||
/* copyright --> */
|
|
||||||
#ifndef _D_BT_EVENT_LISTENER_H_
|
|
||||||
#define _D_BT_EVENT_LISTENER_H_
|
|
||||||
|
|
||||||
#include "common.h"
|
|
||||||
#include "SharedHandle.h"
|
|
||||||
#include <deque>
|
|
||||||
|
|
||||||
namespace aria2 {
|
|
||||||
|
|
||||||
class BtEvent;
|
|
||||||
|
|
||||||
class BtEventListener {
|
|
||||||
public:
|
|
||||||
virtual ~BtEventListener() {}
|
|
||||||
|
|
||||||
virtual void handleEvent(const SharedHandle<BtEvent>& event) = 0;
|
|
||||||
};
|
|
||||||
|
|
||||||
typedef SharedHandle<BtEventListener> BtEventListenerHandle;
|
|
||||||
typedef std::deque<BtEventListenerHandle> BtEventListeners;
|
|
||||||
|
|
||||||
} // namespace aria2
|
|
||||||
|
|
||||||
#endif // _D_BT_EVENT_LISTENER_H_
|
|
|
@ -36,10 +36,15 @@
|
||||||
#define _D_BT_MESSAGE_H_
|
#define _D_BT_MESSAGE_H_
|
||||||
|
|
||||||
#include "common.h"
|
#include "common.h"
|
||||||
#include "SharedHandle.h"
|
|
||||||
#include <string>
|
#include <string>
|
||||||
#include <deque>
|
#include <deque>
|
||||||
|
|
||||||
|
#include "SharedHandle.h"
|
||||||
|
#include "BtAbortOutstandingRequestEvent.h"
|
||||||
|
#include "BtCancelSendingPieceEvent.h"
|
||||||
|
#include "BtChokingEvent.h"
|
||||||
|
|
||||||
namespace aria2 {
|
namespace aria2 {
|
||||||
|
|
||||||
class BtEvent;
|
class BtEvent;
|
||||||
|
@ -66,7 +71,13 @@ public:
|
||||||
|
|
||||||
virtual bool validate(std::deque<std::string>& errors) = 0;
|
virtual bool validate(std::deque<std::string>& errors) = 0;
|
||||||
|
|
||||||
virtual void handleEvent(const SharedHandle<BtEvent>& event) = 0;
|
virtual void onAbortOutstandingRequestEvent
|
||||||
|
(const BtAbortOutstandingRequestEvent& event) = 0;
|
||||||
|
|
||||||
|
virtual void onCancelSendingPieceEvent
|
||||||
|
(const BtCancelSendingPieceEvent& event) = 0;
|
||||||
|
|
||||||
|
virtual void onChokingEvent(const BtChokingEvent& event) = 0;
|
||||||
|
|
||||||
virtual void onQueued() = 0;
|
virtual void onQueued() = 0;
|
||||||
|
|
||||||
|
|
|
@ -42,8 +42,6 @@
|
||||||
#include "Util.h"
|
#include "Util.h"
|
||||||
#include "message.h"
|
#include "message.h"
|
||||||
#include "DlAbortEx.h"
|
#include "DlAbortEx.h"
|
||||||
#include "BtChokingEvent.h"
|
|
||||||
#include "BtCancelSendingPieceEvent.h"
|
|
||||||
#include "MessageDigestHelper.h"
|
#include "MessageDigestHelper.h"
|
||||||
#include "DiskAdaptor.h"
|
#include "DiskAdaptor.h"
|
||||||
#include "Logger.h"
|
#include "Logger.h"
|
||||||
|
@ -216,16 +214,8 @@ void BtPieceMessage::erasePieceOnDisk(const PieceHandle& piece) {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
bool BtPieceMessage::BtChokingEventListener::canHandle(const BtEventHandle& event) {
|
void BtPieceMessage::onChokingEvent(const BtChokingEvent& event)
|
||||||
BtChokingEvent* intEvent = dynamic_cast<BtChokingEvent*>(event.get());
|
{
|
||||||
return intEvent != 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
void BtPieceMessage::BtChokingEventListener::handleEventInternal(const BtEventHandle& event) {
|
|
||||||
message->handleChokingEvent(event);
|
|
||||||
}
|
|
||||||
|
|
||||||
void BtPieceMessage::handleChokingEvent(const BtEventHandle& event) {
|
|
||||||
if(!invalidate &&
|
if(!invalidate &&
|
||||||
!sendingInProgress &&
|
!sendingInProgress &&
|
||||||
!peer->isInAmAllowedIndexSet(index)) {
|
!peer->isInAmAllowedIndexSet(index)) {
|
||||||
|
@ -245,22 +235,14 @@ void BtPieceMessage::handleChokingEvent(const BtEventHandle& event) {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
bool BtPieceMessage::BtCancelSendingPieceEventListener::canHandle(const BtEventHandle& event) {
|
void BtPieceMessage::onCancelSendingPieceEvent
|
||||||
BtCancelSendingPieceEvent* intEvent = dynamic_cast<BtCancelSendingPieceEvent*>(event.get());
|
(const BtCancelSendingPieceEvent& event)
|
||||||
return intEvent != 0;
|
{
|
||||||
}
|
|
||||||
|
|
||||||
void BtPieceMessage::BtCancelSendingPieceEventListener::handleEventInternal(const BtEventHandle& event) {
|
|
||||||
message->handleCancelSendingPieceEvent(event);
|
|
||||||
}
|
|
||||||
|
|
||||||
void BtPieceMessage::handleCancelSendingPieceEvent(const BtEventHandle& event) {
|
|
||||||
BtCancelSendingPieceEvent* intEvent = (BtCancelSendingPieceEvent*)(event.get());
|
|
||||||
if(!invalidate &&
|
if(!invalidate &&
|
||||||
!sendingInProgress &&
|
!sendingInProgress &&
|
||||||
index == intEvent->getIndex() &&
|
index == event.getIndex() &&
|
||||||
begin == intEvent->getBegin() &&
|
begin == event.getBegin() &&
|
||||||
blockLength == intEvent->getLength()) {
|
blockLength == event.getLength()) {
|
||||||
logger->debug(MSG_REJECT_PIECE_CANCEL,
|
logger->debug(MSG_REJECT_PIECE_CANCEL,
|
||||||
cuid, index, begin, blockLength);
|
cuid, index, begin, blockLength);
|
||||||
if(peer->isFastExtensionEnabled()) {
|
if(peer->isFastExtensionEnabled()) {
|
||||||
|
|
|
@ -36,11 +36,9 @@
|
||||||
#define _D_BT_PIECE_MESSAGE_H_
|
#define _D_BT_PIECE_MESSAGE_H_
|
||||||
|
|
||||||
#include "AbstractBtMessage.h"
|
#include "AbstractBtMessage.h"
|
||||||
#include "AbstractBtEventListener.h"
|
|
||||||
|
|
||||||
namespace aria2 {
|
namespace aria2 {
|
||||||
|
|
||||||
class BtEvent;
|
|
||||||
class Piece;
|
class Piece;
|
||||||
class BtPieceMessage;
|
class BtPieceMessage;
|
||||||
|
|
||||||
|
@ -65,32 +63,6 @@ private:
|
||||||
void erasePieceOnDisk(const SharedHandle<Piece>& piece);
|
void erasePieceOnDisk(const SharedHandle<Piece>& piece);
|
||||||
|
|
||||||
size_t sendPieceData(off_t offset, size_t length) const;
|
size_t sendPieceData(off_t offset, size_t length) const;
|
||||||
|
|
||||||
class BtChokingEventListener : public AbstractBtEventListener {
|
|
||||||
private:
|
|
||||||
BtPieceMessage* message;
|
|
||||||
public:
|
|
||||||
BtChokingEventListener(BtPieceMessage* message):message(message) {}
|
|
||||||
|
|
||||||
virtual bool canHandle(const SharedHandle<BtEvent>& btEvent);
|
|
||||||
|
|
||||||
virtual void handleEventInternal(const SharedHandle<BtEvent>& btEvent);
|
|
||||||
};
|
|
||||||
|
|
||||||
typedef SharedHandle<BtChokingEventListener> BtChokingEventListenerHandle;
|
|
||||||
|
|
||||||
class BtCancelSendingPieceEventListener : public AbstractBtEventListener {
|
|
||||||
private:
|
|
||||||
BtPieceMessage* message;
|
|
||||||
public:
|
|
||||||
BtCancelSendingPieceEventListener(BtPieceMessage* message):message(message) {}
|
|
||||||
|
|
||||||
virtual bool canHandle(const SharedHandle<BtEvent>& btEvent);
|
|
||||||
|
|
||||||
virtual void handleEventInternal(const SharedHandle<BtEvent>& btEvent);
|
|
||||||
};
|
|
||||||
|
|
||||||
typedef SharedHandle<BtCancelSendingPieceEventListener> BtCancelSendingPieceEventListenerHandle;
|
|
||||||
public:
|
public:
|
||||||
BtPieceMessage(size_t index = 0, uint32_t begin = 0, size_t blockLength = 0)
|
BtPieceMessage(size_t index = 0, uint32_t begin = 0, size_t blockLength = 0)
|
||||||
:AbstractBtMessage(ID, NAME),
|
:AbstractBtMessage(ID, NAME),
|
||||||
|
@ -101,14 +73,6 @@ public:
|
||||||
msgHeader(0)
|
msgHeader(0)
|
||||||
{
|
{
|
||||||
uploading = true;
|
uploading = true;
|
||||||
{
|
|
||||||
SharedHandle<BtEventListener> listener(new BtChokingEventListener(this));
|
|
||||||
addEventListener(listener);
|
|
||||||
}
|
|
||||||
{
|
|
||||||
SharedHandle<BtEventListener> listener(new BtCancelSendingPieceEventListener(this));
|
|
||||||
addEventListener(listener);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
virtual ~BtPieceMessage() {
|
virtual ~BtPieceMessage() {
|
||||||
|
@ -148,9 +112,10 @@ public:
|
||||||
|
|
||||||
virtual std::string toString() const;
|
virtual std::string toString() const;
|
||||||
|
|
||||||
void handleChokingEvent(const SharedHandle<BtEvent>& event);
|
virtual void onChokingEvent(const BtChokingEvent& event);
|
||||||
|
|
||||||
void handleCancelSendingPieceEvent(const SharedHandle<BtEvent>& event);
|
virtual void onCancelSendingPieceEvent
|
||||||
|
(const BtCancelSendingPieceEvent& event);
|
||||||
};
|
};
|
||||||
|
|
||||||
} // namespace aria2
|
} // namespace aria2
|
||||||
|
|
|
@ -33,7 +33,6 @@
|
||||||
*/
|
*/
|
||||||
/* copyright --> */
|
/* copyright --> */
|
||||||
#include "BtRequestMessage.h"
|
#include "BtRequestMessage.h"
|
||||||
#include "BtAbortOutstandingRequestEvent.h"
|
|
||||||
#include "Peer.h"
|
#include "Peer.h"
|
||||||
#include "Piece.h"
|
#include "Piece.h"
|
||||||
#include "PieceStorage.h"
|
#include "PieceStorage.h"
|
||||||
|
@ -76,29 +75,11 @@ void BtRequestMessage::onQueued()
|
||||||
dispatcher->addOutstandingRequest(requestSlot);
|
dispatcher->addOutstandingRequest(requestSlot);
|
||||||
}
|
}
|
||||||
|
|
||||||
bool BtRequestMessage::
|
void BtRequestMessage::onAbortOutstandingRequestEvent
|
||||||
BtAbortOutstandingRequestEventListener::canHandle(const BtEventHandle& event)
|
(const BtAbortOutstandingRequestEvent& event)
|
||||||
{
|
{
|
||||||
BtAbortOutstandingRequestEvent* intEvent =
|
if(getIndex() == event.getPiece()->getIndex() &&
|
||||||
dynamic_cast<BtAbortOutstandingRequestEvent*>(event.get());
|
!invalidate && !sendingInProgress) {
|
||||||
return intEvent != 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
void BtRequestMessage::
|
|
||||||
BtAbortOutstandingRequestEventListener::handleEventInternal
|
|
||||||
(const BtEventHandle& event)
|
|
||||||
{
|
|
||||||
message->handleAbortOutstandingRequestEvent(event);
|
|
||||||
}
|
|
||||||
|
|
||||||
void BtRequestMessage::
|
|
||||||
handleAbortOutstandingRequestEvent(const BtEventHandle& event)
|
|
||||||
{
|
|
||||||
BtAbortOutstandingRequestEvent* intEvent =
|
|
||||||
(BtAbortOutstandingRequestEvent*)event.get();
|
|
||||||
if(getIndex() == intEvent->getPiece()->getIndex() &&
|
|
||||||
!invalidate &&
|
|
||||||
!sendingInProgress) {
|
|
||||||
invalidate = true;
|
invalidate = true;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -36,7 +36,6 @@
|
||||||
#define _D_BT_REQUEST_MESSAGE_H_
|
#define _D_BT_REQUEST_MESSAGE_H_
|
||||||
|
|
||||||
#include "RangeBtMessage.h"
|
#include "RangeBtMessage.h"
|
||||||
#include "AbstractBtEventListener.h"
|
|
||||||
|
|
||||||
namespace aria2 {
|
namespace aria2 {
|
||||||
|
|
||||||
|
@ -48,32 +47,13 @@ class BtRequestMessage : public RangeBtMessage {
|
||||||
private:
|
private:
|
||||||
size_t _blockIndex;
|
size_t _blockIndex;
|
||||||
|
|
||||||
class BtAbortOutstandingRequestEventListener:public AbstractBtEventListener {
|
|
||||||
private:
|
|
||||||
BtRequestMessage* message;
|
|
||||||
public:
|
|
||||||
BtAbortOutstandingRequestEventListener(BtRequestMessage* message):
|
|
||||||
message(message) {}
|
|
||||||
|
|
||||||
virtual bool canHandle(const SharedHandle<BtEvent>& event);
|
|
||||||
|
|
||||||
virtual void handleEventInternal(const SharedHandle<BtEvent>& event);
|
|
||||||
};
|
|
||||||
|
|
||||||
typedef SharedHandle<BtAbortOutstandingRequestEventListener>
|
|
||||||
BtAbortOutstandingRequestEventListenerHandle;
|
|
||||||
public:
|
public:
|
||||||
BtRequestMessage(size_t index = 0,
|
BtRequestMessage(size_t index = 0,
|
||||||
uint32_t begin = 0,
|
uint32_t begin = 0,
|
||||||
uint32_t length = 0,
|
uint32_t length = 0,
|
||||||
size_t blockIndex = 0)
|
size_t blockIndex = 0)
|
||||||
:RangeBtMessage(ID, NAME, index, begin, length),
|
:RangeBtMessage(ID, NAME, index, begin, length),
|
||||||
_blockIndex(blockIndex)
|
_blockIndex(blockIndex) {}
|
||||||
{
|
|
||||||
SharedHandle<BtEventListener> listener
|
|
||||||
(new BtAbortOutstandingRequestEventListener(this));
|
|
||||||
addEventListener(listener);
|
|
||||||
}
|
|
||||||
|
|
||||||
static const uint8_t ID = 6;
|
static const uint8_t ID = 6;
|
||||||
|
|
||||||
|
@ -89,8 +69,8 @@ public:
|
||||||
|
|
||||||
virtual void onQueued();
|
virtual void onQueued();
|
||||||
|
|
||||||
virtual void handleAbortOutstandingRequestEvent
|
virtual void onAbortOutstandingRequestEvent
|
||||||
(const SharedHandle<BtEvent>& event);
|
(const BtAbortOutstandingRequestEvent& event);
|
||||||
};
|
};
|
||||||
|
|
||||||
} // namespace aria2
|
} // namespace aria2
|
||||||
|
|
|
@ -39,7 +39,6 @@
|
||||||
#include "prefs.h"
|
#include "prefs.h"
|
||||||
#include "BtAbortOutstandingRequestEvent.h"
|
#include "BtAbortOutstandingRequestEvent.h"
|
||||||
#include "BtCancelSendingPieceEvent.h"
|
#include "BtCancelSendingPieceEvent.h"
|
||||||
#include "BtChokedEvent.h"
|
|
||||||
#include "BtChokingEvent.h"
|
#include "BtChokingEvent.h"
|
||||||
#include "BtMessageFactory.h"
|
#include "BtMessageFactory.h"
|
||||||
#include "message.h"
|
#include "message.h"
|
||||||
|
@ -114,26 +113,15 @@ void DefaultBtMessageDispatcher::sendMessages() {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
class HandleEvent {
|
|
||||||
private:
|
|
||||||
SharedHandle<BtEvent> _event;
|
|
||||||
public:
|
|
||||||
HandleEvent(const SharedHandle<BtEvent>& event):_event(event) {}
|
|
||||||
|
|
||||||
void operator()(const SharedHandle<BtMessage>& msg) const
|
|
||||||
{
|
|
||||||
msg->handleEvent(_event);
|
|
||||||
}
|
|
||||||
};
|
|
||||||
|
|
||||||
// Cancel sending piece message to peer.
|
// Cancel sending piece message to peer.
|
||||||
void DefaultBtMessageDispatcher::doCancelSendingPieceAction(size_t index, uint32_t begin, size_t length)
|
void DefaultBtMessageDispatcher::doCancelSendingPieceAction(size_t index, uint32_t begin, size_t length)
|
||||||
{
|
{
|
||||||
BtCancelSendingPieceEventHandle event
|
BtCancelSendingPieceEvent event(index, begin, length);
|
||||||
(new BtCancelSendingPieceEvent(index, begin, length));
|
|
||||||
|
|
||||||
BtMessages tempQueue = messageQueue;
|
BtMessages tempQueue = messageQueue;
|
||||||
std::for_each(tempQueue.begin(), tempQueue.end(), HandleEvent(event));
|
std::for_each(tempQueue.begin(), tempQueue.end(),
|
||||||
|
std::bind2nd(mem_fun_sh(&BtMessage::onCancelSendingPieceEvent),
|
||||||
|
event));
|
||||||
}
|
}
|
||||||
|
|
||||||
// Cancel sending piece message to peer.
|
// Cancel sending piece message to peer.
|
||||||
|
@ -177,11 +165,12 @@ void DefaultBtMessageDispatcher::doAbortOutstandingRequestAction(const PieceHand
|
||||||
std::for_each(first, last, AbortOutstandingRequest(piece, cuid));
|
std::for_each(first, last, AbortOutstandingRequest(piece, cuid));
|
||||||
requestSlots.erase(first, last);
|
requestSlots.erase(first, last);
|
||||||
|
|
||||||
BtAbortOutstandingRequestEventHandle event
|
BtAbortOutstandingRequestEvent event(piece);
|
||||||
(new BtAbortOutstandingRequestEvent(piece));
|
|
||||||
|
|
||||||
BtMessages tempQueue = messageQueue;
|
BtMessages tempQueue = messageQueue;
|
||||||
std::for_each(tempQueue.begin(), tempQueue.end(), HandleEvent(event));
|
std::for_each(tempQueue.begin(), tempQueue.end(),
|
||||||
|
std::bind2nd(mem_fun_sh(&BtMessage::onAbortOutstandingRequestEvent),
|
||||||
|
event));
|
||||||
}
|
}
|
||||||
|
|
||||||
class ProcessChokedRequestSlot {
|
class ProcessChokedRequestSlot {
|
||||||
|
@ -236,20 +225,16 @@ void DefaultBtMessageDispatcher::doChokedAction()
|
||||||
requestSlots.erase(std::remove_if(requestSlots.begin(), requestSlots.end(),
|
requestSlots.erase(std::remove_if(requestSlots.begin(), requestSlots.end(),
|
||||||
FindChokedRequestSlot(peer)),
|
FindChokedRequestSlot(peer)),
|
||||||
requestSlots.end());
|
requestSlots.end());
|
||||||
|
|
||||||
BtChokedEventHandle event(new BtChokedEvent());
|
|
||||||
|
|
||||||
BtMessages tempQueue = messageQueue;
|
|
||||||
std::for_each(tempQueue.begin(), tempQueue.end(), HandleEvent(event));
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// localhost dispatched choke message to the peer.
|
// localhost dispatched choke message to the peer.
|
||||||
void DefaultBtMessageDispatcher::doChokingAction()
|
void DefaultBtMessageDispatcher::doChokingAction()
|
||||||
{
|
{
|
||||||
BtChokingEventHandle event(new BtChokingEvent());
|
BtChokingEvent event;
|
||||||
|
|
||||||
BtMessages tempQueue = messageQueue;
|
BtMessages tempQueue = messageQueue;
|
||||||
std::for_each(tempQueue.begin(), tempQueue.end(), HandleEvent(event));
|
std::for_each(tempQueue.begin(), tempQueue.end(),
|
||||||
|
std::bind2nd(mem_fun_sh(&BtMessage::onChokingEvent), event));
|
||||||
}
|
}
|
||||||
|
|
||||||
class ProcessStaleRequestSlot {
|
class ProcessStaleRequestSlot {
|
||||||
|
|
|
@ -312,12 +312,8 @@ SRCS += PeerMessageUtil.cc PeerMessageUtil.h\
|
||||||
DefaultBtMessageReceiver.cc DefaultBtMessageReceiver.h\
|
DefaultBtMessageReceiver.cc DefaultBtMessageReceiver.h\
|
||||||
BtRequestFactory.h\
|
BtRequestFactory.h\
|
||||||
DefaultBtRequestFactory.cc DefaultBtRequestFactory.h\
|
DefaultBtRequestFactory.cc DefaultBtRequestFactory.h\
|
||||||
BtEvent.h\
|
|
||||||
BtEventListener.h\
|
|
||||||
AbstractBtEventListener.h\
|
|
||||||
BtCancelSendingPieceEvent.h\
|
BtCancelSendingPieceEvent.h\
|
||||||
BtAbortOutstandingRequestEvent.h\
|
BtAbortOutstandingRequestEvent.h\
|
||||||
BtChokedEvent.h\
|
|
||||||
BtChokingEvent.h\
|
BtChokingEvent.h\
|
||||||
BtInteractive.h\
|
BtInteractive.h\
|
||||||
DefaultBtInteractive.cc DefaultBtInteractive.h\
|
DefaultBtInteractive.cc DefaultBtInteractive.h\
|
||||||
|
|
|
@ -112,12 +112,8 @@ bin_PROGRAMS = aria2c$(EXEEXT)
|
||||||
@ENABLE_BITTORRENT_TRUE@ DefaultBtMessageReceiver.cc DefaultBtMessageReceiver.h\
|
@ENABLE_BITTORRENT_TRUE@ DefaultBtMessageReceiver.cc DefaultBtMessageReceiver.h\
|
||||||
@ENABLE_BITTORRENT_TRUE@ BtRequestFactory.h\
|
@ENABLE_BITTORRENT_TRUE@ BtRequestFactory.h\
|
||||||
@ENABLE_BITTORRENT_TRUE@ DefaultBtRequestFactory.cc DefaultBtRequestFactory.h\
|
@ENABLE_BITTORRENT_TRUE@ DefaultBtRequestFactory.cc DefaultBtRequestFactory.h\
|
||||||
@ENABLE_BITTORRENT_TRUE@ BtEvent.h\
|
|
||||||
@ENABLE_BITTORRENT_TRUE@ BtEventListener.h\
|
|
||||||
@ENABLE_BITTORRENT_TRUE@ AbstractBtEventListener.h\
|
|
||||||
@ENABLE_BITTORRENT_TRUE@ BtCancelSendingPieceEvent.h\
|
@ENABLE_BITTORRENT_TRUE@ BtCancelSendingPieceEvent.h\
|
||||||
@ENABLE_BITTORRENT_TRUE@ BtAbortOutstandingRequestEvent.h\
|
@ENABLE_BITTORRENT_TRUE@ BtAbortOutstandingRequestEvent.h\
|
||||||
@ENABLE_BITTORRENT_TRUE@ BtChokedEvent.h\
|
|
||||||
@ENABLE_BITTORRENT_TRUE@ BtChokingEvent.h\
|
@ENABLE_BITTORRENT_TRUE@ BtChokingEvent.h\
|
||||||
@ENABLE_BITTORRENT_TRUE@ BtInteractive.h\
|
@ENABLE_BITTORRENT_TRUE@ BtInteractive.h\
|
||||||
@ENABLE_BITTORRENT_TRUE@ DefaultBtInteractive.cc DefaultBtInteractive.h\
|
@ENABLE_BITTORRENT_TRUE@ DefaultBtInteractive.cc DefaultBtInteractive.h\
|
||||||
|
@ -473,18 +469,16 @@ am__libaria2c_a_SOURCES_DIST = Socket.h SocketCore.cc SocketCore.h \
|
||||||
DefaultBtMessageDispatcher.h BtMessageReceiver.h \
|
DefaultBtMessageDispatcher.h BtMessageReceiver.h \
|
||||||
DefaultBtMessageReceiver.cc DefaultBtMessageReceiver.h \
|
DefaultBtMessageReceiver.cc DefaultBtMessageReceiver.h \
|
||||||
BtRequestFactory.h DefaultBtRequestFactory.cc \
|
BtRequestFactory.h DefaultBtRequestFactory.cc \
|
||||||
DefaultBtRequestFactory.h BtEvent.h BtEventListener.h \
|
DefaultBtRequestFactory.h BtCancelSendingPieceEvent.h \
|
||||||
AbstractBtEventListener.h BtCancelSendingPieceEvent.h \
|
BtAbortOutstandingRequestEvent.h BtChokingEvent.h \
|
||||||
BtAbortOutstandingRequestEvent.h BtChokedEvent.h \
|
BtInteractive.h DefaultBtInteractive.cc DefaultBtInteractive.h \
|
||||||
BtChokingEvent.h BtInteractive.h DefaultBtInteractive.cc \
|
ActivePeerConnectionCommand.cc ActivePeerConnectionCommand.h \
|
||||||
DefaultBtInteractive.h ActivePeerConnectionCommand.cc \
|
BtDependency.cc BtDependency.h PeerReceiveHandshakeCommand.cc \
|
||||||
ActivePeerConnectionCommand.h BtDependency.cc BtDependency.h \
|
PeerReceiveHandshakeCommand.h BtSetup.cc BtSetup.h \
|
||||||
PeerReceiveHandshakeCommand.cc PeerReceiveHandshakeCommand.h \
|
BtFileAllocationEntry.cc BtFileAllocationEntry.h \
|
||||||
BtSetup.cc BtSetup.h BtFileAllocationEntry.cc \
|
BtPostDownloadHandler.cc BtPostDownloadHandler.h \
|
||||||
BtFileAllocationEntry.h BtPostDownloadHandler.cc \
|
BtCheckIntegrityEntry.cc BtCheckIntegrityEntry.h \
|
||||||
BtPostDownloadHandler.h BtCheckIntegrityEntry.cc \
|
BtExtendedMessage.cc BtExtendedMessage.h ExtensionMessage.h \
|
||||||
BtCheckIntegrityEntry.h BtExtendedMessage.cc \
|
|
||||||
BtExtendedMessage.h ExtensionMessage.h \
|
|
||||||
ExtensionMessageFactory.h DefaultExtensionMessageFactory.cc \
|
ExtensionMessageFactory.h DefaultExtensionMessageFactory.cc \
|
||||||
DefaultExtensionMessageFactory.h HandshakeExtensionMessage.cc \
|
DefaultExtensionMessageFactory.h HandshakeExtensionMessage.cc \
|
||||||
HandshakeExtensionMessage.h UTPexExtensionMessage.cc \
|
HandshakeExtensionMessage.h UTPexExtensionMessage.cc \
|
||||||
|
|
|
@ -88,6 +88,31 @@ mem_fun_sh(ReturnType (ClassType::*f)() const)
|
||||||
return const_mem_fun_sh_t<ReturnType, ClassType>(f);
|
return const_mem_fun_sh_t<ReturnType, ClassType>(f);
|
||||||
};
|
};
|
||||||
|
|
||||||
|
// mem_fun1_t for SharedHandle
|
||||||
|
template<typename ReturnType, typename ClassType, typename ArgType>
|
||||||
|
class mem_fun1_sh_t:public std::binary_function<SharedHandle<ClassType>,
|
||||||
|
ArgType,
|
||||||
|
ReturnType>
|
||||||
|
{
|
||||||
|
private:
|
||||||
|
ReturnType (ClassType::*f)(ArgType);
|
||||||
|
|
||||||
|
public:
|
||||||
|
mem_fun1_sh_t(ReturnType (ClassType::*f)(ArgType)):f(f) {}
|
||||||
|
|
||||||
|
ReturnType operator()(const SharedHandle<ClassType>& x, ArgType a) const
|
||||||
|
{
|
||||||
|
return (x.get()->*f)(a);
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
template<typename ReturnType, typename ClassType, typename ArgType>
|
||||||
|
mem_fun1_sh_t<ReturnType, ClassType, ArgType>
|
||||||
|
mem_fun_sh(ReturnType (ClassType::*f)(ArgType))
|
||||||
|
{
|
||||||
|
return mem_fun1_sh_t<ReturnType, ClassType, ArgType>(f);
|
||||||
|
};
|
||||||
|
|
||||||
template<class BinaryOp, class UnaryOp>
|
template<class BinaryOp, class UnaryOp>
|
||||||
class adopt2nd_t:public std::binary_function<typename BinaryOp::first_argument_type,
|
class adopt2nd_t:public std::binary_function<typename BinaryOp::first_argument_type,
|
||||||
typename UnaryOp::argument_type,
|
typename UnaryOp::argument_type,
|
||||||
|
|
|
@ -156,7 +156,7 @@ void BtPieceMessageTest::testChokingEvent() {
|
||||||
CPPUNIT_ASSERT(!peer->isInAmAllowedIndexSet(1));
|
CPPUNIT_ASSERT(!peer->isInAmAllowedIndexSet(1));
|
||||||
CPPUNIT_ASSERT(!peer->isFastExtensionEnabled());
|
CPPUNIT_ASSERT(!peer->isFastExtensionEnabled());
|
||||||
|
|
||||||
msg->handleEvent(SharedHandle<BtEvent>(new BtChokingEvent()));
|
msg->onChokingEvent(BtChokingEvent());
|
||||||
|
|
||||||
CPPUNIT_ASSERT(msg->isInvalidate());
|
CPPUNIT_ASSERT(msg->isInvalidate());
|
||||||
CPPUNIT_ASSERT_EQUAL((size_t)0, btMessageDispatcher->messageQueue.size());
|
CPPUNIT_ASSERT_EQUAL((size_t)0, btMessageDispatcher->messageQueue.size());
|
||||||
|
@ -170,7 +170,7 @@ void BtPieceMessageTest::testChokingEvent_allowedFastEnabled() {
|
||||||
CPPUNIT_ASSERT(!peer->isInAmAllowedIndexSet(1));
|
CPPUNIT_ASSERT(!peer->isInAmAllowedIndexSet(1));
|
||||||
CPPUNIT_ASSERT(peer->isFastExtensionEnabled());
|
CPPUNIT_ASSERT(peer->isFastExtensionEnabled());
|
||||||
|
|
||||||
msg->handleEvent(SharedHandle<BtEvent>(new BtChokingEvent()));
|
msg->onChokingEvent(BtChokingEvent());
|
||||||
|
|
||||||
CPPUNIT_ASSERT(msg->isInvalidate());
|
CPPUNIT_ASSERT(msg->isInvalidate());
|
||||||
CPPUNIT_ASSERT_EQUAL((size_t)1, btMessageDispatcher->messageQueue.size());
|
CPPUNIT_ASSERT_EQUAL((size_t)1, btMessageDispatcher->messageQueue.size());
|
||||||
|
@ -190,7 +190,7 @@ void BtPieceMessageTest::testChokingEvent_inAmAllowedIndexSet() {
|
||||||
CPPUNIT_ASSERT(peer->isInAmAllowedIndexSet(1));
|
CPPUNIT_ASSERT(peer->isInAmAllowedIndexSet(1));
|
||||||
CPPUNIT_ASSERT(peer->isFastExtensionEnabled());
|
CPPUNIT_ASSERT(peer->isFastExtensionEnabled());
|
||||||
|
|
||||||
msg->handleEvent(SharedHandle<BtEvent>(new BtChokingEvent()));
|
msg->onChokingEvent(BtChokingEvent());
|
||||||
|
|
||||||
CPPUNIT_ASSERT(!msg->isInvalidate());
|
CPPUNIT_ASSERT(!msg->isInvalidate());
|
||||||
CPPUNIT_ASSERT_EQUAL((size_t)0, btMessageDispatcher->messageQueue.size());
|
CPPUNIT_ASSERT_EQUAL((size_t)0, btMessageDispatcher->messageQueue.size());
|
||||||
|
@ -203,7 +203,7 @@ void BtPieceMessageTest::testChokingEvent_invalidate() {
|
||||||
CPPUNIT_ASSERT(!peer->isInAmAllowedIndexSet(1));
|
CPPUNIT_ASSERT(!peer->isInAmAllowedIndexSet(1));
|
||||||
CPPUNIT_ASSERT(!peer->isFastExtensionEnabled());
|
CPPUNIT_ASSERT(!peer->isFastExtensionEnabled());
|
||||||
|
|
||||||
msg->handleEvent(SharedHandle<BtEvent>(new BtChokingEvent()));
|
msg->onChokingEvent(BtChokingEvent());
|
||||||
|
|
||||||
CPPUNIT_ASSERT(msg->isInvalidate());
|
CPPUNIT_ASSERT(msg->isInvalidate());
|
||||||
CPPUNIT_ASSERT_EQUAL((size_t)0, btMessageDispatcher->messageQueue.size());
|
CPPUNIT_ASSERT_EQUAL((size_t)0, btMessageDispatcher->messageQueue.size());
|
||||||
|
@ -216,7 +216,7 @@ void BtPieceMessageTest::testChokingEvent_sendingInProgress() {
|
||||||
CPPUNIT_ASSERT(!peer->isInAmAllowedIndexSet(1));
|
CPPUNIT_ASSERT(!peer->isInAmAllowedIndexSet(1));
|
||||||
CPPUNIT_ASSERT(!peer->isFastExtensionEnabled());
|
CPPUNIT_ASSERT(!peer->isFastExtensionEnabled());
|
||||||
|
|
||||||
msg->handleEvent(SharedHandle<BtEvent>(new BtChokingEvent()));
|
msg->onChokingEvent(BtChokingEvent());
|
||||||
|
|
||||||
CPPUNIT_ASSERT(!msg->isInvalidate());
|
CPPUNIT_ASSERT(!msg->isInvalidate());
|
||||||
CPPUNIT_ASSERT_EQUAL((size_t)0, btMessageDispatcher->messageQueue.size());
|
CPPUNIT_ASSERT_EQUAL((size_t)0, btMessageDispatcher->messageQueue.size());
|
||||||
|
@ -227,8 +227,7 @@ void BtPieceMessageTest::testCancelSendingPieceEvent() {
|
||||||
CPPUNIT_ASSERT(!msg->isSendingInProgress());
|
CPPUNIT_ASSERT(!msg->isSendingInProgress());
|
||||||
CPPUNIT_ASSERT(!peer->isFastExtensionEnabled());
|
CPPUNIT_ASSERT(!peer->isFastExtensionEnabled());
|
||||||
|
|
||||||
msg->handleEvent
|
msg->onCancelSendingPieceEvent(BtCancelSendingPieceEvent(1, 1024, 16*1024));
|
||||||
(SharedHandle<BtEvent>(new BtCancelSendingPieceEvent(1, 1024, 16*1024)));
|
|
||||||
|
|
||||||
CPPUNIT_ASSERT(msg->isInvalidate());
|
CPPUNIT_ASSERT(msg->isInvalidate());
|
||||||
}
|
}
|
||||||
|
@ -238,18 +237,15 @@ void BtPieceMessageTest::testCancelSendingPieceEvent_noMatch() {
|
||||||
CPPUNIT_ASSERT(!msg->isSendingInProgress());
|
CPPUNIT_ASSERT(!msg->isSendingInProgress());
|
||||||
CPPUNIT_ASSERT(!peer->isFastExtensionEnabled());
|
CPPUNIT_ASSERT(!peer->isFastExtensionEnabled());
|
||||||
|
|
||||||
msg->handleEvent
|
msg->onCancelSendingPieceEvent(BtCancelSendingPieceEvent(0, 1024, 16*1024));
|
||||||
(SharedHandle<BtEvent>(new BtCancelSendingPieceEvent(0, 1024, 16*1024)));
|
|
||||||
|
|
||||||
CPPUNIT_ASSERT(!msg->isInvalidate());
|
CPPUNIT_ASSERT(!msg->isInvalidate());
|
||||||
|
|
||||||
msg->handleEvent
|
msg->onCancelSendingPieceEvent(BtCancelSendingPieceEvent(1, 0, 16*1024));
|
||||||
(SharedHandle<BtEvent>(new BtCancelSendingPieceEvent(1, 0, 16*1024)));
|
|
||||||
|
|
||||||
CPPUNIT_ASSERT(!msg->isInvalidate());
|
CPPUNIT_ASSERT(!msg->isInvalidate());
|
||||||
|
|
||||||
msg->handleEvent
|
msg->onCancelSendingPieceEvent(BtCancelSendingPieceEvent(1, 1024, 0));
|
||||||
(SharedHandle<BtEvent>(new BtCancelSendingPieceEvent(1, 1024, 0)));
|
|
||||||
|
|
||||||
CPPUNIT_ASSERT(!msg->isInvalidate());
|
CPPUNIT_ASSERT(!msg->isInvalidate());
|
||||||
}
|
}
|
||||||
|
@ -260,8 +256,7 @@ void BtPieceMessageTest::testCancelSendingPieceEvent_allowedFastEnabled() {
|
||||||
CPPUNIT_ASSERT(!msg->isSendingInProgress());
|
CPPUNIT_ASSERT(!msg->isSendingInProgress());
|
||||||
CPPUNIT_ASSERT(peer->isFastExtensionEnabled());
|
CPPUNIT_ASSERT(peer->isFastExtensionEnabled());
|
||||||
|
|
||||||
msg->handleEvent
|
msg->onCancelSendingPieceEvent(BtCancelSendingPieceEvent(1, 1024, 16*1024));
|
||||||
(SharedHandle<BtEvent>(new BtCancelSendingPieceEvent(1, 1024, 16*1024)));
|
|
||||||
|
|
||||||
CPPUNIT_ASSERT(msg->isInvalidate());
|
CPPUNIT_ASSERT(msg->isInvalidate());
|
||||||
CPPUNIT_ASSERT_EQUAL((size_t)1, btMessageDispatcher->messageQueue.size());
|
CPPUNIT_ASSERT_EQUAL((size_t)1, btMessageDispatcher->messageQueue.size());
|
||||||
|
@ -279,8 +274,7 @@ void BtPieceMessageTest::testCancelSendingPieceEvent_invalidate() {
|
||||||
CPPUNIT_ASSERT(!msg->isSendingInProgress());
|
CPPUNIT_ASSERT(!msg->isSendingInProgress());
|
||||||
CPPUNIT_ASSERT(peer->isFastExtensionEnabled());
|
CPPUNIT_ASSERT(peer->isFastExtensionEnabled());
|
||||||
|
|
||||||
msg->handleEvent
|
msg->onCancelSendingPieceEvent(BtCancelSendingPieceEvent(1, 1024, 16*1024));
|
||||||
(SharedHandle<BtEvent>(new BtCancelSendingPieceEvent(1, 1024, 16*1024)));
|
|
||||||
|
|
||||||
CPPUNIT_ASSERT(msg->isInvalidate());
|
CPPUNIT_ASSERT(msg->isInvalidate());
|
||||||
CPPUNIT_ASSERT_EQUAL((size_t)0, btMessageDispatcher->messageQueue.size());
|
CPPUNIT_ASSERT_EQUAL((size_t)0, btMessageDispatcher->messageQueue.size());
|
||||||
|
@ -292,8 +286,7 @@ void BtPieceMessageTest::testCancelSendingPieceEvent_sendingInProgress() {
|
||||||
CPPUNIT_ASSERT(msg->isSendingInProgress());
|
CPPUNIT_ASSERT(msg->isSendingInProgress());
|
||||||
CPPUNIT_ASSERT(!peer->isFastExtensionEnabled());
|
CPPUNIT_ASSERT(!peer->isFastExtensionEnabled());
|
||||||
|
|
||||||
msg->handleEvent
|
msg->onCancelSendingPieceEvent(BtCancelSendingPieceEvent(1, 1024, 16*1024));
|
||||||
(SharedHandle<BtEvent>(new BtCancelSendingPieceEvent(1, 1024, 16*1024)));
|
|
||||||
|
|
||||||
CPPUNIT_ASSERT(!msg->isInvalidate());
|
CPPUNIT_ASSERT(!msg->isInvalidate());
|
||||||
}
|
}
|
||||||
|
|
|
@ -236,47 +236,34 @@ void BtRequestMessageTest::testDoReceivedAction_doesntHavePieceAndFastExtensionD
|
||||||
|
|
||||||
void BtRequestMessageTest::testHandleAbortRequestEvent() {
|
void BtRequestMessageTest::testHandleAbortRequestEvent() {
|
||||||
SharedHandle<Piece> piece(new Piece(1, 16*1024));
|
SharedHandle<Piece> piece(new Piece(1, 16*1024));
|
||||||
SharedHandle<BtAbortOutstandingRequestEvent> event
|
|
||||||
(new BtAbortOutstandingRequestEvent(piece));
|
|
||||||
|
|
||||||
CPPUNIT_ASSERT(!msg->isInvalidate());
|
CPPUNIT_ASSERT(!msg->isInvalidate());
|
||||||
msg->handleEvent(event);
|
msg->onAbortOutstandingRequestEvent(BtAbortOutstandingRequestEvent(piece));
|
||||||
|
|
||||||
CPPUNIT_ASSERT(msg->isInvalidate());
|
CPPUNIT_ASSERT(msg->isInvalidate());
|
||||||
}
|
}
|
||||||
|
|
||||||
void BtRequestMessageTest::testHandleAbortRequestEvent_indexNoMatch() {
|
void BtRequestMessageTest::testHandleAbortRequestEvent_indexNoMatch() {
|
||||||
SharedHandle<Piece> piece(new Piece(2, 16*1024));
|
SharedHandle<Piece> piece(new Piece(2, 16*1024));
|
||||||
SharedHandle<BtAbortOutstandingRequestEvent> event
|
|
||||||
(new BtAbortOutstandingRequestEvent(piece));
|
|
||||||
|
|
||||||
CPPUNIT_ASSERT(!msg->isInvalidate());
|
CPPUNIT_ASSERT(!msg->isInvalidate());
|
||||||
CPPUNIT_ASSERT(!msg->isSendingInProgress());
|
CPPUNIT_ASSERT(!msg->isSendingInProgress());
|
||||||
msg->handleEvent(event);
|
msg->onAbortOutstandingRequestEvent(BtAbortOutstandingRequestEvent(piece));
|
||||||
CPPUNIT_ASSERT(!msg->isInvalidate());
|
CPPUNIT_ASSERT(!msg->isInvalidate());
|
||||||
}
|
}
|
||||||
|
|
||||||
void BtRequestMessageTest::testHandleAbortRequestEvent_alreadyInvalidated() {
|
void BtRequestMessageTest::testHandleAbortRequestEvent_alreadyInvalidated() {
|
||||||
SharedHandle<Piece> piece(new Piece(1, 16*1024));
|
SharedHandle<Piece> piece(new Piece(1, 16*1024));
|
||||||
SharedHandle<BtAbortOutstandingRequestEvent> event
|
|
||||||
(new BtAbortOutstandingRequestEvent(piece));
|
|
||||||
msg->setInvalidate(true);
|
msg->setInvalidate(true);
|
||||||
|
|
||||||
CPPUNIT_ASSERT(msg->isInvalidate());
|
CPPUNIT_ASSERT(msg->isInvalidate());
|
||||||
CPPUNIT_ASSERT(!msg->isSendingInProgress());
|
CPPUNIT_ASSERT(!msg->isSendingInProgress());
|
||||||
msg->handleEvent(event);
|
msg->onAbortOutstandingRequestEvent(BtAbortOutstandingRequestEvent(piece));
|
||||||
CPPUNIT_ASSERT(msg->isInvalidate());
|
CPPUNIT_ASSERT(msg->isInvalidate());
|
||||||
}
|
}
|
||||||
|
|
||||||
void BtRequestMessageTest::testHandleAbortRequestEvent_sendingInProgress() {
|
void BtRequestMessageTest::testHandleAbortRequestEvent_sendingInProgress() {
|
||||||
SharedHandle<Piece> piece(new Piece(1, 16*1024));
|
SharedHandle<Piece> piece(new Piece(1, 16*1024));
|
||||||
SharedHandle<BtAbortOutstandingRequestEvent> event
|
|
||||||
(new BtAbortOutstandingRequestEvent(piece));
|
|
||||||
msg->setSendingInProgress(true);
|
msg->setSendingInProgress(true);
|
||||||
|
|
||||||
CPPUNIT_ASSERT(!msg->isInvalidate());
|
CPPUNIT_ASSERT(!msg->isInvalidate());
|
||||||
CPPUNIT_ASSERT(msg->isSendingInProgress());
|
CPPUNIT_ASSERT(msg->isSendingInProgress());
|
||||||
msg->handleEvent(event);
|
msg->onAbortOutstandingRequestEvent(BtAbortOutstandingRequestEvent(piece));
|
||||||
CPPUNIT_ASSERT(!msg->isInvalidate());
|
CPPUNIT_ASSERT(!msg->isInvalidate());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -99,13 +99,11 @@ public:
|
||||||
return sendCalled;
|
return sendCalled;
|
||||||
}
|
}
|
||||||
|
|
||||||
virtual void handleEvent(const SharedHandle<BtEvent>& event) {
|
virtual void onCancelSendingPieceEvent
|
||||||
BtCancelSendingPieceEvent* e =
|
(const BtCancelSendingPieceEvent& event)
|
||||||
dynamic_cast<BtCancelSendingPieceEvent*>(event.get());
|
{
|
||||||
if(e) {
|
|
||||||
doCancelActionCalled = true;
|
doCancelActionCalled = true;
|
||||||
}
|
}
|
||||||
}
|
|
||||||
|
|
||||||
bool isDoCancelActionCalled() const {
|
bool isDoCancelActionCalled() const {
|
||||||
return doCancelActionCalled;
|
return doCancelActionCalled;
|
||||||
|
|
|
@ -84,7 +84,13 @@ public:
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
virtual void handleEvent(const SharedHandle<BtEvent>& event) {}
|
virtual void onAbortOutstandingRequestEvent
|
||||||
|
(const BtAbortOutstandingRequestEvent& event) {}
|
||||||
|
|
||||||
|
virtual void onCancelSendingPieceEvent
|
||||||
|
(const BtCancelSendingPieceEvent& event) {}
|
||||||
|
|
||||||
|
virtual void onChokingEvent(const BtChokingEvent& event) {}
|
||||||
|
|
||||||
virtual void onQueued() {}
|
virtual void onQueued() {}
|
||||||
|
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue