module PStemmer.Internal.Function (
  module PST,
  module PStemmer.Internal.Function,
  fromMaybe,
  first, second, (***), (&&&)) where

  import qualified Data.Text as T
  import qualified Data.List as DL
  import qualified Data.Ord as DO
  import Data.Maybe (fromMaybe)
  import PStemmer.Types as PST
  import Control.Arrow (second, first, (***), (&&&))

  applySteps :: T.Text -> [Step] -> T.Text
  applySteps rv [] = rv
  applySteps rv (f:fs) =
    let
      r :: T.Text
      r = f rv
    in
      if T.null r
        then r
        else applySteps r fs

  cutList :: List -> Substep
  cutList (w:ws) txt =
    if w `T.isSuffixOf` txt
      then fromMaybe (txt, False) (flip (,) True <$> T.stripSuffix w txt)
      else cutList ws txt
  cutList _ txt = (txt, False)

  getFirstSR :: [Substep] -> T.Text -> T.Text
  getFirstSR [] txt = txt
  getFirstSR (f:fs) txt =
    let
      r :: StepResult
      r = f txt
    in
      if snd r
        then fst r
        else getFirstSR fs txt

  sortByLengthDown :: List -> List
  sortByLengthDown = DL.sortBy (DO.comparing (DO.Down . T.length))