summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorGravatar Joey Hess <joeyh@joeyh.name>2016-12-07 14:52:10 -0400
committerGravatar Joey Hess <joeyh@joeyh.name>2016-12-07 14:52:10 -0400
commitdc08aeb67718d8fbe339ab51f0d7a1bf85fd597e (patch)
treea4721073f113a28a78dd83434ccbb1d92a2bd6f7
parentf9ef5a66ef70d68873c3514b8a634f9bed43fe8b (diff)
offset meters when resuming
-rw-r--r--P2P/Protocol.hs8
-rw-r--r--doc/todo/tor.mdwn3
2 files changed, 6 insertions, 5 deletions
diff --git a/P2P/Protocol.hs b/P2P/Protocol.hs
index b1e2bf481..f51ea7f98 100644
--- a/P2P/Protocol.hs
+++ b/P2P/Protocol.hs
@@ -379,22 +379,24 @@ serveAuthed myuuid = void $ serverLoop handler
handler _ = return ServerUnexpected
sendContent :: Key -> AssociatedFile -> Offset -> MeterUpdate -> Proto Bool
-sendContent key af offset p = do
+sendContent key af offset@(Offset n) p = do
+ let p' = offsetMeterUpdate p (toBytesProcessed n)
(len, content) <- readContentLen key af offset
net $ sendMessage (DATA len)
- net $ sendBytes len content p
+ net $ sendBytes len content p'
checkSuccess
receiveContent :: MeterUpdate -> Local Len -> (Offset -> Len -> L.ByteString -> Local Bool) -> (Offset -> Message) -> Proto Bool
receiveContent p sizer storer mkmsg = do
Len n <- local sizer
+ let p' = offsetMeterUpdate p (toBytesProcessed n)
let offset = Offset n
net $ sendMessage (mkmsg offset)
r <- net receiveMessage
case r of
DATA len -> do
ok <- local . storer offset len
- =<< net (receiveBytes len p)
+ =<< net (receiveBytes len p')
sendSuccess ok
return ok
_ -> do
diff --git a/doc/todo/tor.mdwn b/doc/todo/tor.mdwn
index 1432c770e..af4fa1993 100644
--- a/doc/todo/tor.mdwn
+++ b/doc/todo/tor.mdwn
@@ -7,8 +7,7 @@ Current todo list:
* copy --to peer seems to make the remotedaemon buffer the content in
memory, more than I'd expect.
* update progress logs in remotedaemon send/receive
-* Resuming an interrupted download does not jump the progress to reflect
- the amount already present. And, it fails at the end.
+* Resuming an interrupted download fails at the end.
* Think about locking some more. What happens if the connection to the peer
is dropped while we think we're locking content there from being dropped?
* merge to master