{-# LANGUAGE GADTs #-}
{-# LANGUAGE OverloadedStrings #-}
module Duckling.Quantity.RU.Rules
( rules
) where
import Data.String
import Data.Text (Text)
import Prelude
import qualified Data.Text as Text
import Duckling.Dimensions.Types
import Duckling.Numeral.Helpers
import Duckling.Quantity.Helpers
import Duckling.Regex.Types
import Duckling.Types
import qualified Duckling.Numeral.Types as TNumeral
import qualified Duckling.Quantity.Types as TQuantity
quantities :: [(Text, String, TQuantity.Unit, Double -> Double)]
quantities =
[ ("<quantity> milligrams", "(мг|миллиграмма?)", TQuantity.Gram, (/ 1000))
, ("<quantity> grams", "г(рамма?)?", TQuantity.Gram, id)
, ("<quantity> kilograms", "(кг|килограмма?)", TQuantity.Gram, (* 1000))
, ("<quantity> lb", "фунт(а|ов)?", TQuantity.Pound, id)
, ("<quantity> oz", "унц(ия|ии|ий)", TQuantity.Ounce, id)
]
ruleNumeralQuantities :: [Rule]
ruleNumeralQuantities = map go quantities
where
go :: (Text, String, TQuantity.Unit, Double -> Double) -> Rule
go (name, regexPattern, u, convert) = Rule
{ name = name
, pattern =
[ numberWith TNumeral.value (> 0)
, regex regexPattern
]
, prod = \tokens -> case tokens of
(Token Numeral nd:_) ->
Just . Token Quantity . quantity u . convert $ TNumeral.value nd
_ -> Nothing
}
ruleAQuantity :: [Rule]
ruleAQuantity = map go quantities
where
go :: (Text, String, TQuantity.Unit, Double -> Double) -> Rule
go (name, regexPattern, u, convert) = Rule
{ name = name
, pattern = [ regex regexPattern ]
, prod = \_ -> Just . Token Quantity . quantity u $ convert 1
}
rules :: [Rule]
rules = ruleNumeralQuantities ++ ruleAQuantity