diff options
| author | Remko Tronçon <git@el-tramo.be> | 2012-12-25 14:39:48 (GMT) | 
|---|---|---|
| committer | Remko Tronçon <git@el-tramo.be> | 2013-05-11 10:22:56 (GMT) | 
| commit | 927d62cc54c8a5087dba6b61afa9ad30dc528a23 (patch) | |
| tree | e67dc911bd30c0519d31a542d8e085bbb209879d /Swift/Controllers/FileTransfer | |
| parent | 17b188343e7208b875af7af30d94f0bf948f6b93 (diff) | |
| download | swift-contrib-927d62cc54c8a5087dba6b61afa9ad30dc528a23.zip swift-contrib-927d62cc54c8a5087dba6b61afa9ad30dc528a23.tar.bz2 | |
File Transfer refactoring.
Allocate S5B server lazily.
Forward forts lazily.
Various state machine fixes.
Temporarily disabling S5B proxy support.
Change-Id: I3145e85a99b15a7e457306bbfbe9c0eb570191e4
Diffstat (limited to 'Swift/Controllers/FileTransfer')
| -rw-r--r-- | Swift/Controllers/FileTransfer/FileTransferController.cpp | 19 | 
1 files changed, 11 insertions, 8 deletions
| diff --git a/Swift/Controllers/FileTransfer/FileTransferController.cpp b/Swift/Controllers/FileTransfer/FileTransferController.cpp index 69b5c89..0160a7a 100644 --- a/Swift/Controllers/FileTransfer/FileTransferController.cpp +++ b/Swift/Controllers/FileTransfer/FileTransferController.cpp @@ -25,7 +25,7 @@ FileTransferController::FileTransferController(const JID& receipient, const std:  }  FileTransferController::FileTransferController(IncomingFileTransfer::ref transfer) : -	sending(false), otherParty(transfer->getSender()), filename(transfer->filename), transfer(transfer), ftManager(0), ftProgressInfo(0), chatWindow(0), currentState(FileTransfer::State::WaitingForStart) { +	sending(false), otherParty(transfer->getSender()), filename(transfer->getFileName()), transfer(transfer), ftManager(0), ftProgressInfo(0), chatWindow(0), currentState(FileTransfer::State::WaitingForStart) {  } @@ -42,7 +42,7 @@ std::string FileTransferController::setChatWindow(ChatWindow* wnd, std::string n  	if (sending) {  		uiID = wnd->addFileTransfer(QT_TRANSLATE_NOOP("", "me"), true, filename, boost::filesystem::file_size(boost::filesystem::path(filename)));  	} else { -		uiID = wnd->addFileTransfer(nickname, false, filename, transfer->fileSizeInBytes); +		uiID = wnd->addFileTransfer(nickname, false, filename, transfer->getFileSizeInBytes());  	}  	return uiID;  } @@ -65,7 +65,7 @@ int FileTransferController::getProgress() const {  boost::uintmax_t FileTransferController::getSize() const {  	if (transfer) { -		return transfer->fileSizeInBytes; +		return transfer->getFileSizeInBytes();  	} else {  		return 0;  	} @@ -76,9 +76,9 @@ void FileTransferController::start(std::string& description) {  	fileReadStream = boost::make_shared<FileReadBytestream>(boost::filesystem::path(filename));  	OutgoingFileTransfer::ref outgoingTransfer = ftManager->createOutgoingFileTransfer(otherParty, boost::filesystem::path(filename), description, fileReadStream);  	if (outgoingTransfer) { -		ftProgressInfo = new FileTransferProgressInfo(outgoingTransfer->fileSizeInBytes); +		ftProgressInfo = new FileTransferProgressInfo(outgoingTransfer->getFileSizeInBytes());  		ftProgressInfo->onProgressPercentage.connect(boost::bind(&FileTransferController::handleProgressPercentageChange, this, _1)); -		outgoingTransfer->onStateChange.connect(boost::bind(&FileTransferController::handleFileTransferStateChange, this, _1)); +		outgoingTransfer->onStateChanged.connect(boost::bind(&FileTransferController::handleFileTransferStateChange, this, _1));  		outgoingTransfer->onProcessedBytes.connect(boost::bind(&FileTransferProgressInfo::setBytesProcessed, ftProgressInfo, _1));  		outgoingTransfer->start();  		transfer = outgoingTransfer; @@ -93,9 +93,9 @@ void FileTransferController::accept(std::string& file) {  	if (incomingTransfer) {  		fileWriteStream = boost::make_shared<FileWriteBytestream>(boost::filesystem::path(file)); -		ftProgressInfo = new FileTransferProgressInfo(transfer->fileSizeInBytes); +		ftProgressInfo = new FileTransferProgressInfo(transfer->getFileSizeInBytes());  		ftProgressInfo->onProgressPercentage.connect(boost::bind(&FileTransferController::handleProgressPercentageChange, this, _1)); -		transfer->onStateChange.connect(boost::bind(&FileTransferController::handleFileTransferStateChange, this, _1)); +		transfer->onStateChanged.connect(boost::bind(&FileTransferController::handleFileTransferStateChange, this, _1));  		transfer->onProcessedBytes.connect(boost::bind(&FileTransferProgressInfo::setBytesProcessed, ftProgressInfo, _1));  		incomingTransfer->accept(fileWriteStream);  	} else { @@ -114,7 +114,10 @@ void FileTransferController::cancel() {  void FileTransferController::handleFileTransferStateChange(FileTransfer::State state) {  	currentState = state;  	onStateChage(); -	switch(state.state) { +	switch(state.type) { +		case FileTransfer::State::Initial: +			assert(false); +			return;  		case FileTransfer::State::Negotiating:  			chatWindow->setFileTransferStatus(uiID, ChatWindow::Negotiating);  			return; | 
 Swift
 Swift