{-# LANGUAGE BangPatterns #-} module App.Cli.Commands.RankSelect.SelectAll ( cmdSelectAll ) where import Control.Lens import Control.Monad import Data.Generics.Product.Any import Data.Succinct.RankSelect.Base.Select1 import Data.Succinct.RankSelect.CsPoppy import Data.Succinct.RankSelect.Poppy512 import HaskellWorks.Data.Bits.PopCount.PopCount1 import HaskellWorks.Data.FromForeignRegion import Options.Applicative hiding (columns) import System.Directory import qualified App.Cli.Options.Type as Z import qualified Data.List as L {- HLINT ignore "Redundant do" -} {- HLINT ignore "Reduce duplication" -} {- HLINT ignore "Redundant bracket" -} runSelectAll :: Z.SelectAllOptions -> IO () runSelectAll opts = case opts ^. the @"indexType" of Z.CsPoppy -> do entries <- getDirectoryContents "components/succinct-core/data" let files = ("components/succinct-core/data/" ++) <$> (".ib" `L.isSuffixOf`) `filter` entries forM_ files $ \file -> do putStrLn $ "Loading cspoppy for " <> file v :: CsPoppy <- mmapFromForeignRegion file forM_ [1..popCount1 v] $ \i -> do let !_ = select1 v i return () return () Z.Poppy512 -> do entries <- getDirectoryContents "components/succinct-core/data" let files = ("components/succinct-core/data/" ++) <$> (".ib" `L.isSuffixOf`) `filter` entries forM_ files $ \file -> do putStrLn $ "Loading cspoppy for " <> file v :: Poppy512 <- mmapFromForeignRegion file forM_ [1..popCount1 v] $ \i -> do let !_ = select1 v i return () return () optsSelectAll :: Parser Z.SelectAllOptions optsSelectAll = Z.SelectAllOptions <$> option auto ( long "index-type" <> help "Index type" <> metavar "INDEX_TYPE" ) cmdSelectAll :: Mod CommandFields (IO ()) cmdSelectAll = command "select-all" $ flip info idm $ runSelectAll <$> optsSelectAll