diff options
Diffstat (limited to 'utils/hpc/HpcCombine.hs')
| -rw-r--r-- | utils/hpc/HpcCombine.hs | 148 | 
1 files changed, 74 insertions, 74 deletions
| diff --git a/utils/hpc/HpcCombine.hs b/utils/hpc/HpcCombine.hs index 190a727a5f..b57112f45e 100644 --- a/utils/hpc/HpcCombine.hs +++ b/utils/hpc/HpcCombine.hs @@ -3,7 +3,7 @@  -- Andy Gill, Oct 2006  --------------------------------------------------------- -module HpcCombine (sum_plugin,combine_plugin,map_plugin) where  +module HpcCombine (sum_plugin,combine_plugin,map_plugin) where  import Trace.Hpc.Tix  import Trace.Hpc.Util @@ -16,70 +16,70 @@ import qualified Data.Map as Map  ------------------------------------------------------------------------------  sum_options :: FlagOptSeq -sum_options  +sum_options          = excludeOpt          . includeOpt          . outputOpt -	. unionModuleOpt  +        . unionModuleOpt  sum_plugin :: Plugin  sum_plugin = Plugin { name = "sum" -	      	       , usage = "[OPTION] .. <TIX_FILE> [<TIX_FILE> [<TIX_FILE> ..]]"  -		       , options = sum_options  -		       , summary = "Sum multiple .tix files in a single .tix file" -		       , implementation = sum_main -		       , init_flags = default_flags -		       , final_flags = default_final_flags -		       } +                    , usage = "[OPTION] .. <TIX_FILE> [<TIX_FILE> [<TIX_FILE> ..]]" +                    , options = sum_options +                    , summary = "Sum multiple .tix files in a single .tix file" +                    , implementation = sum_main +                    , init_flags = default_flags +                    , final_flags = default_final_flags +                    }  combine_options :: FlagOptSeq -combine_options  +combine_options          = excludeOpt          . includeOpt          . outputOpt          . combineFunOpt          . combineFunOptInfo -	. unionModuleOpt  +        . unionModuleOpt  combine_plugin :: Plugin  combine_plugin = Plugin { name = "combine" -	      	       , usage = "[OPTION] .. <TIX_FILE> <TIX_FILE>"  -		       , options = combine_options  -		       , summary = "Combine two .tix files in a single .tix file" -		       , implementation = combine_main -		       , init_flags = default_flags -		       , final_flags = default_final_flags -		       } +                        , usage = "[OPTION] .. <TIX_FILE> <TIX_FILE>" +                        , options = combine_options +                        , summary = "Combine two .tix files in a single .tix file" +                        , implementation = combine_main +                        , init_flags = default_flags +                        , final_flags = default_final_flags +                        }  map_options :: FlagOptSeq -map_options  +map_options          = excludeOpt          . includeOpt          . outputOpt -	. mapFunOpt +        . mapFunOpt          . mapFunOptInfo -	. unionModuleOpt  +        . unionModuleOpt  map_plugin :: Plugin  map_plugin = Plugin { name = "map" -	      	       , usage = "[OPTION] .. <TIX_FILE> " -		       , options = map_options  -		       , summary = "Map a function over a single .tix file" -		       , implementation = map_main -		       , init_flags = default_flags -		       , final_flags = default_final_flags -		       } +                    , usage = "[OPTION] .. <TIX_FILE> " +                    , options = map_options +                    , summary = "Map a function over a single .tix file" +                    , implementation = map_main +                    , init_flags = default_flags +                    , final_flags = default_final_flags +                    }  ------------------------------------------------------------------------------  sum_main :: Flags -> [String] -> IO () -sum_main _     [] = hpcError sum_plugin $ "no .tix file specified"  +sum_main _     [] = hpcError sum_plugin $ "no .tix file specified"  sum_main flags (first_file:more_files) = do    Just tix <- readTix first_file -  tix' <- foldM (mergeTixFile flags (+))  -       	  	(filterTix flags tix) -		more_files +  tix' <- foldM (mergeTixFile flags (+)) +                (filterTix flags tix) +                more_files    case outputFile flags of      "-" -> putStrLn (show tix') @@ -92,10 +92,10 @@ combine_main flags [first_file,second_file] = do    Just tix1 <- readTix first_file    Just tix2 <- readTix second_file -  let tix = mergeTix (mergeModule flags)  -		     f -		     (filterTix flags tix1) -		     (filterTix flags tix2) +  let tix = mergeTix (mergeModule flags) +                     f +                     (filterTix flags tix1) +                     (filterTix flags tix2)    case outputFile flags of      "-" -> putStrLn (show tix) @@ -110,55 +110,55 @@ map_main flags [first_file] = do    let (Tix inside_tix) = filterTix flags tix    let tix' = Tix [ TixModule m p i (map f t) -	         | TixModule m p i t <- inside_tix -		 ] +                 | TixModule m p i t <- inside_tix +                 ]    case outputFile flags of      "-" -> putStrLn (show tix')      out -> writeTix out tix' -map_main _     [] = hpcError map_plugin $ "no .tix file specified"  -map_main _     _  = hpcError map_plugin $ "to many .tix files specified"  +map_main _     [] = hpcError map_plugin $ "no .tix file specified" +map_main _     _  = hpcError map_plugin $ "to many .tix files specified"  mergeTixFile :: Flags -> (Integer -> Integer -> Integer) -> Tix -> String -> IO Tix  mergeTixFile flags fn tix file_name = do    Just new_tix <- readTix file_name    return $! strict $ mergeTix (mergeModule flags) fn tix (filterTix flags new_tix) --- could allow different numbering on the module info,  +-- could allow different numbering on the module info,  -- as long as the total is the same; will require normalization.  mergeTix :: MergeFun -	 -> (Integer -> Integer -> Integer) -> Tix -> Tix -> Tix  +         -> (Integer -> Integer -> Integer) -> Tix -> Tix -> Tix  mergeTix modComb f -	 (Tix t1) -      	 (Tix t2)  = Tix  -	 [ case (Map.lookup m fm1,Map.lookup m fm2) of -	   -- todo, revisit the semantics of this combination -	    (Just (TixModule _ hash1 len1 tix1),Just (TixModule _ hash2 len2 tix2))  -	       | hash1 /= hash2  -	       || length tix1 /= length tix2 -	       || len1 /= length tix1 -	       || len2 /= length tix2 -	       	     -> error $ "mismatched in module " ++ m -	       | otherwise      ->  -	       	     TixModule m hash1 len1 (zipWith f tix1 tix2)  -	    (Just m1,Nothing) ->  -	    	  m1 -	    (Nothing,Just m2) -> -		  m2 -	    _ -> error "impossible" -	 | m <- Set.toList (theMergeFun modComb m1s m2s) +         (Tix t1) +         (Tix t2)  = Tix +         [ case (Map.lookup m fm1,Map.lookup m fm2) of +           -- todo, revisit the semantics of this combination +            (Just (TixModule _ hash1 len1 tix1),Just (TixModule _ hash2 len2 tix2)) +               | hash1 /= hash2 +               || length tix1 /= length tix2 +               || len1 /= length tix1 +               || len2 /= length tix2 +                     -> error $ "mismatched in module " ++ m +               | otherwise      -> +                     TixModule m hash1 len1 (zipWith f tix1 tix2) +            (Just m1,Nothing) -> +                  m1 +            (Nothing,Just m2) -> +                  m2 +            _ -> error "impossible" +         | m <- Set.toList (theMergeFun modComb m1s m2s)           ] -  where  -   m1s = Set.fromList $ map tixModuleName t1  +  where +   m1s = Set.fromList $ map tixModuleName t1     m2s = Set.fromList $ map tixModuleName t2 -   fm1 = Map.fromList [ (tixModuleName tix,tix)  -       	 	      | tix <- t1 -		      ] -   fm2 = Map.fromList [ (tixModuleName tix,tix)  -       	 	      | tix <- t2 -		      ] +   fm1 = Map.fromList [ (tixModuleName tix,tix) +                      | tix <- t1 +                      ] +   fm2 = Map.fromList [ (tixModuleName tix,tix) +                      | tix <- t2 +                      ]  -- What I would give for a hyperstrict :-) @@ -172,7 +172,7 @@ instance Strict Integer where  instance Strict Int where     strict i = i -instance Strict Hash where	-- should be fine, because Hash is a newtype round an Int +instance Strict Hash where      -- should be fine, because Hash is a newtype round an Int     strict i = i  instance Strict Char where @@ -186,10 +186,10 @@ instance (Strict a, Strict b) => Strict (a,b) where     strict (a,b) = (((,) $! strict a) $! strict b)  instance Strict Tix where -  strict (Tix t1) =  -  	    Tix $! strict t1 +  strict (Tix t1) = +            Tix $! strict t1  instance Strict TixModule where -  strict (TixModule m1 p1 i1 t1) =  -  	    ((((TixModule $! strict m1) $! strict p1) $! strict i1) $! strict t1) +  strict (TixModule m1 p1 i1 t1) = +            ((((TixModule $! strict m1) $! strict p1) $! strict i1) $! strict t1) | 
