diff options
author | Joey Hess <joeyh@joeyh.name> | 2016-09-29 16:59:48 -0400 |
---|---|---|
committer | Joey Hess <joeyh@joeyh.name> | 2016-09-29 16:59:48 -0400 |
commit | 08796570e27924179abda72988e243726b8b5565 (patch) | |
tree | 9bf9062e393000e690a050e2a975e8f15a8fb7ff /Messages/Progress.hs | |
parent | 07347cca3dd9ed015bd35239ccdf0f5df8f2d746 (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.hs | 14 |
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 |