summaryrefslogtreecommitdiff
path: root/Messages/Progress.hs
diff options
context:
space:
mode:
authorGravatar Joey Hess <joeyh@joeyh.name>2016-09-29 16:59:48 -0400
committerGravatar Joey Hess <joeyh@joeyh.name>2016-09-29 16:59:48 -0400
commit08796570e27924179abda72988e243726b8b5565 (patch)
tree9bf9062e393000e690a050e2a975e8f15a8fb7ff /Messages/Progress.hs
parent07347cca3dd9ed015bd35239ccdf0f5df8f2d746 (diff)
Make --json-progress output be shown even when the size of a object is not known.
Diffstat (limited to 'Messages/Progress.hs')
-rw-r--r--Messages/Progress.hs14
1 files changed, 6 insertions, 8 deletions
diff --git a/Messages/Progress.hs b/Messages/Progress.hs
index f21ccae0b..06f2531be 100644
--- a/Messages/Progress.hs
+++ b/Messages/Progress.hs
@@ -30,12 +30,10 @@ import Data.Quantity
{- Shows a progress meter while performing a transfer of a key.
- The action is passed a callback to use to update the meter. -}
metered :: Maybe MeterUpdate -> Key -> (MeterUpdate -> Annex a) -> Annex a
-metered othermeter key a = case keySize key of
- Nothing -> nometer
- Just size -> withMessageState (go $ fromInteger size)
+metered othermeter key a = withMessageState $ go (keySize key)
where
go _ (MessageState { outputType = QuietOutput }) = nometer
- go size (MessageState { outputType = NormalOutput, concurrentOutputEnabled = False }) = do
+ go (Just size) (MessageState { outputType = NormalOutput, concurrentOutputEnabled = False }) = do
showOutput
(progress, meter) <- mkmeter size
m <- liftIO $ rateLimitMeterUpdate 0.1 (Just size) $ \n -> do
@@ -44,7 +42,7 @@ metered othermeter key a = case keySize key of
r <- a (combinemeter m)
liftIO $ clearMeter stdout meter
return r
- go size (MessageState { outputType = NormalOutput, concurrentOutputEnabled = True }) =
+ go (Just size) (MessageState { outputType = NormalOutput, concurrentOutputEnabled = True }) =
#if WITH_CONCURRENTOUTPUT
withProgressRegion $ \r -> do
(progress, meter) <- mkmeter size
@@ -57,10 +55,10 @@ metered othermeter key a = case keySize key of
nometer
#endif
go _ (MessageState { outputType = JSONOutput False }) = nometer
- go size (MessageState { outputType = JSONOutput True }) = do
+ go msize (MessageState { outputType = JSONOutput True }) = do
buf <- withMessageState $ return . jsonBuffer
- m <- liftIO $ rateLimitMeterUpdate 0.1 (Just size) $
- JSON.progress buf size
+ m <- liftIO $ rateLimitMeterUpdate 0.1 msize $
+ JSON.progress buf msize
a (combinemeter m)
mkmeter size = do