{-# LANGUAGE RecordWildCards #-} module Console.Search(actionSearch) where import CmdLine.All import General.Base import General.System import Hoogle actionSearch :: CmdLine -> Query -> IO () actionSearch flags q = do (missing,dbs) <- loadQueryDatabases (databases flags) q unless (null missing) $ do n <- availableDatabases (databases flags) exitMessage $ ("Could not find some databases: " ++ unwords missing) : "Searching in:" : map (" "++) (databases flags) ++ [""] ++ (if null n then ["There are no available databases, generate them with: hoogle data"] else ["Either the package does not exist or has not been generated"] ++ ["Generate more databases with: hoogle data all" | length n < 100] ++ ["Found " ++ show (length n) ++ " databases, including: " ++ unwords (take 5 n) | not $ null n]) let sug = querySuggestions dbs q when (isJust sug) $ putStrLn $ showTag $ fromJust sug when verbose $ putStrLn "= ANSWERS =" when (color flags) $ putStrLn $ "Searching for: " ++ showTag (renderQuery q) let res = search dbs q if null res then putStrLn "No results found" else if info flags then do let Result{self=self,docs=docs,package=package} = snd $ head res putStrLns 2 $ f $ head res putStrLns 2 $ showTag docs when (isJust package) $ putStrLn $ "From package " ++ snd (fromJust package) putStrLns 1 $ showTag $ snd self else putStr $ unlines $ map f res where search | start2 == 0 && count2 == maxBound = searchAll | otherwise = searchRange (start2,start2+count2-1) where start2 = maybe 0 (subtract 1) $ start flags count2 = fromMaybe maxBound $ count flags showTag = if color flags then showTagANSI else showTagText verbose = False f (s,Result{..}) = maybe "" (\m -> snd m ++ " ") modul ++ showTag (snd self) ++ (if verbose then " -- " ++ show s else "") ++ (if link flags then " -- " ++ fst self else "") -- Put out a string with some blank links following -- Do not put out the blank lines if no text output putStrLns :: Int -> String -> IO () putStrLns n xs = when (xs /= "") $ do putStr xs putStr $ replicate n '\n'