module Duckling.Time.FR.Rules
( rules ) where
import Control.Monad (liftM2)
import Prelude
import Duckling.Dimensions.Types
import Duckling.Numeral.Helpers (parseInt)
import Duckling.Regex.Types
import Duckling.Time.Helpers
import Duckling.Time.Types (TimeData (..))
import qualified Duckling.Time.Types as TTime
import qualified Duckling.TimeGrain.Types as TG
import Duckling.Types
ruleAujourdhui :: Rule
ruleAujourdhui = Rule
{ name = "aujourd'hui"
, pattern =
[ regex "(aujourd'? ?hui)|(ce jour)|(dans la journ(\x00e9|e)e?)|(en ce moment)"
]
, prod = \_ -> tt $ cycleNth TG.Day 0
}
ruleNamedday :: Rule
ruleNamedday = Rule
{ name = "named-day"
, pattern =
[ regex "lun\\.?(di)?"
]
, prod = \_ -> tt $ dayOfWeek 1
}
ruleDayofmonthNamedmonth :: Rule
ruleDayofmonthNamedmonth = Rule
{ name = "<day-of-month> <named-month>"
, pattern =
[ Predicate isDOMInteger
, Predicate isAMonth
]
, prod = \tokens -> case tokens of
(token:Token Time td:_) -> Token Time <$> intersectDOM td token
_ -> Nothing
}
ruleHier :: Rule
ruleHier = Rule
{ name = "hier"
, pattern =
[ regex "hier|la veille"
]
, prod = \_ -> tt . cycleNth TG.Day $ 1
}
ruleDbutDeJourne :: Rule
ruleDbutDeJourne = Rule
{ name = "début de journée"
, pattern =
[ regex "d(\x00e9|e)but de journ(\x00e9|e)e"
]
, prod = \_ -> tt . partOfDay . mkLatent $
interval TTime.Open (hour False 6, hour False 10)
}
ruleLeLendemainDuTime :: Rule
ruleLeLendemainDuTime = Rule
{ name = "le lendemain du <time>"
, pattern =
[ regex "(le|au)? ?lendemain du"
, dimension Time
]
, prod = \tokens -> case tokens of
(_:Token Time td:_) ->
tt $ cycleNthAfter True TG.Day 1 td
_ -> Nothing
}
ruleNamedmonth12 :: Rule
ruleNamedmonth12 = Rule
{ name = "named-month"
, pattern =
[ regex "d(\x00e9|e)cembre|d(\x00e9|e)c\\.?"
]
, prod = \_ -> tt $ month 12
}
ruleCePartofday :: Rule
ruleCePartofday = Rule
{ name = "ce <part-of-day>"
, pattern =
[ regex "cet?t?e?"
, Predicate isAPartOfDay
]
, prod = \tokens -> case tokens of
(_:Token Time td:_) -> Token Time . partOfDay . notLatent <$>
intersect (cycleNth TG.Day 0) td
_ -> Nothing
}
ruleCeTime :: Rule
ruleCeTime = Rule
{ name = "ce <time>"
, pattern =
[ regex "ce"
, dimension Time
]
, prod = \tokens -> case tokens of
(_:Token Time td:_) ->
tt $ predNth 0 False td
_ -> Nothing
}
ruleNamedday2 :: Rule
ruleNamedday2 = Rule
{ name = "named-day"
, pattern =
[ regex "mar\\.?(di)?"
]
, prod = \_ -> tt $ dayOfWeek 2
}
ruleDurationAvantTime :: Rule
ruleDurationAvantTime = Rule
{ name = "<duration> avant <time>"
, pattern =
[ dimension Duration
, regex "avant"
, dimension Time
]
, prod = \tokens -> case tokens of
(Token Duration dd:_:Token Time td:_) ->
tt $ durationBefore dd td
_ -> Nothing
}
ruleMidi :: Rule
ruleMidi = Rule
{ name = "midi"
, pattern =
[ regex "midi"
]
, prod = \_ -> tt $ hour False 12
}
ruleNamedday6 :: Rule
ruleNamedday6 = Rule
{ name = "named-day"
, pattern =
[ regex "sam\\.?(edi)?"
]
, prod = \_ -> tt $ dayOfWeek 6
}
ruleDatetimeDatetimeInterval :: Rule
ruleDatetimeDatetimeInterval = Rule
{ name = "<datetime> - <datetime> (interval)"
, pattern =
[ Predicate isNotLatent
, regex "\\-|au|jusqu'(au?|\x00e0)"
, Predicate isNotLatent
]
, prod = \tokens -> case tokens of
(Token Time td1:_:Token Time td2:_) ->
tt $ interval TTime.Closed (td1, td2)
_ -> Nothing
}
ruleNamedmonth7 :: Rule
ruleNamedmonth7 = Rule
{ name = "named-month"
, pattern =
[ regex "juillet|juil?\\."
]
, prod = \_ -> tt $ month 7
}
ruleDatetimeddMonthinterval :: Rule
ruleDatetimeddMonthinterval = Rule
{ name = "<datetime>-dd <month>(interval)"
, pattern =
[ dimension Time
, regex "\\-|au|jusqu'au"
, regex "(3[01]|[12]\\d|0?[1-9])"
, Predicate isAMonth
]
, prod = \tokens -> case tokens of
(Token Time td1:_:Token RegexMatch (GroupMatch (match:_)):Token Time td2:_) -> do
n <- parseInt match
from <- intersect td2 td1
to <- intersect (dayOfMonth n) td2
tt $ interval TTime.Closed (from, to)
_ -> Nothing
}
ruleDeTimeofdayTimeofdayInterval :: Rule
ruleDeTimeofdayTimeofdayInterval = Rule
{ name = "de <time-of-day> - <time-of-day> (interval)"
, pattern =
[ regex "(midi )?de"
, Predicate isATimeOfDay
, regex "\\-|(jusqu')?(\x00e0|au?)"
, Predicate isATimeOfDay
]
, prod = \tokens -> case tokens of
(_:Token Time td1:_:Token Time td2:_) ->
tt $ interval TTime.Closed (td1, td2)
_ -> Nothing
}
ruleNProchainsCycle :: Rule
ruleNProchainsCycle = Rule
{ name = "n prochains <cycle>"
, pattern =
[ Predicate $ isIntegerBetween 2 9999
, regex "prochaine?s?|suivante?s?|apr(e|\x00e8|\x00e9)s"
, dimension TimeGrain
]
, prod = \tokens -> case tokens of
(token:_:Token TimeGrain grain:_) -> do
n <- getIntValue token
tt $ cycleN True grain n
_ -> Nothing
}
ruleNDerniersCycle :: Rule
ruleNDerniersCycle = Rule
{ name = "n derniers <cycle>"
, pattern =
[ Predicate $ isIntegerBetween 2 9999
, regex "derni(e|\x00e8|\x00e9)re?s?"
, dimension TimeGrain
]
, prod = \tokens -> case tokens of
(token:_:Token TimeGrain grain:_) -> do
n <- getIntValue token
tt . cycleN True grain $ n
_ -> Nothing
}
ruleAvantTimeofday :: Rule
ruleAvantTimeofday = Rule
{ name = "avant <time-of-day>"
, pattern =
[ regex "(n[ ']importe quand )?(avant|jusqu'(a|\x00e0))"
, dimension Time
]
, prod = \tokens -> case tokens of
(_:Token Time td:_) ->
tt $ withDirection TTime.Before td
_ -> Nothing
}
ruleEntreDatetimeEtDatetimeInterval :: Rule
ruleEntreDatetimeEtDatetimeInterval = Rule
{ name = "entre <datetime> et <datetime> (interval)"
, pattern =
[ regex "entre"
, dimension Time
, regex "et"
, dimension Time
]
, prod = \tokens -> case tokens of
(_:Token Time td1:_:Token Time td2:_) ->
tt $ interval TTime.Closed (td1, td2)
_ -> Nothing
}
ruleDatetimedayofweekDdMonthinterval :: Rule
ruleDatetimedayofweekDdMonthinterval = Rule
{ name = "<datetime>-<day-of-week> dd <month>(interval)"
, pattern =
[ dimension Time
, regex "\\-|(jusqu')?au"
, Predicate isADayOfWeek
, regex "(3[01]|[12]\\d|0?[1-9])"
, Predicate isAMonth
]
, prod = \tokens -> case tokens of
(Token Time td1:_:_:Token RegexMatch (GroupMatch (match:_)):Token Time td2:_) -> do
n <- parseInt match
from <- intersect td2 td1
to <- intersect (dayOfMonth n) td2
tt $ interval TTime.Closed (from, to)
_ -> Nothing
}
ruleHhhmmTimeofday :: Rule
ruleHhhmmTimeofday = Rule
{ name = "hh(:|h)mm (time-of-day)"
, pattern =
[ regex "((?:[01]?\\d)|(?:2[0-3]))[:h]([0-5]\\d)"
]
, prod = \tokens -> case tokens of
(Token RegexMatch (GroupMatch (m1:m2:_)):_) -> do
h <- parseInt m1
m <- parseInt m2
tt $ hourMinute (h < 12) h m
_ -> Nothing
}
ruleDdMm :: Rule
ruleDdMm = Rule
{ name = "dd mm"
, pattern =
[ regex "(3[01]|[12]\\d|0?[1-9]) (1[0-2]|0?[1-9])"
]
, prod = \tokens -> case tokens of
(Token RegexMatch (GroupMatch (dd:mm:_)):_) -> do
m <- parseInt mm
d <- parseInt dd
tt $ monthDay m d
_ -> Nothing
}
ruleDdMmYyyy :: Rule
ruleDdMmYyyy = Rule
{ name = "dd mm yyyy"
, pattern =
[ regex "(3[01]|[12]\\d|0?[1-9]) (1[0-2]|0?[1-9]) (\\d{2,4})"
]
, prod = \tokens -> case tokens of
(Token RegexMatch (GroupMatch (dd:mm:yy:_)):_) -> do
y <- parseInt yy
m <- parseInt mm
d <- parseInt dd
tt $ yearMonthDay y m d
_ -> Nothing
}
ruleNamedday4 :: Rule
ruleNamedday4 = Rule
{ name = "named-day"
, pattern =
[ regex "jeu\\.?(di)?"
]
, prod = \_ -> tt $ dayOfWeek 4
}
ruleNamedmonthProchain :: Rule
ruleNamedmonthProchain = Rule
{ name = "<named-month> prochain"
, pattern =
[ dimension Time
, regex "prochain"
]
, prod = \tokens -> case tokens of
(Token Time td:_) ->
tt $ predNth 1 False td
_ -> Nothing
}
ruleDiciDuration :: Rule
ruleDiciDuration = Rule
{ name = "d'ici <duration>"
, pattern =
[ regex "d'ici|dans l('|es?)"
, dimension Duration
]
, prod = \tokens -> case tokens of
(_:Token Duration dd:_) ->
tt $
interval TTime.Open (cycleNth TG.Second 0, inDuration dd)
_ -> Nothing
}
ruleToussaint :: Rule
ruleToussaint = Rule
{ name = "toussaint"
, pattern =
[ regex "((la |la journ(\x00e9|e)e de la |jour de la )?toussaint|jour des morts)"
]
, prod = \_ -> tt $ monthDay 11 1
}
ruleDernierCycleDeTimeLatent :: Rule
ruleDernierCycleDeTimeLatent = Rule
{ name = "dernier <cycle> de <time> (latent)"
, pattern =
[ regex "derni(e|\x00e9|\x00e8)re?"
, dimension TimeGrain
, regex "d['e]"
, dimension Time
]
, prod = \tokens -> case tokens of
(_:Token TimeGrain grain:_:Token Time td:_) ->
tt $ cycleLastOf grain td
_ -> Nothing
}
ruleDurationApresTime :: Rule
ruleDurationApresTime = Rule
{ name = "<duration> apres <time>"
, pattern =
[ dimension Duration
, regex "apr(e|\x00e8)s"
, dimension Time
]
, prod = \tokens -> case tokens of
(Token Duration dd:_:Token Time td:_) ->
tt $ durationAfter dd td
_ -> Nothing
}
ruleNCycleAprs :: Rule
ruleNCycleAprs = Rule
{ name = "n <cycle> après"
, pattern =
[ Predicate $ isIntegerBetween 2 9999
, dimension TimeGrain
, regex "(d')? ?apr(e|\x00e8|\x00e9)s|qui sui(t|ves?)|plus tard"
]
, prod = \tokens -> case tokens of
(token:Token TimeGrain grain:_) -> do
n <- getIntValue token
tt $ cycleNth grain n
_ -> Nothing
}
ruleSeason4 :: Rule
ruleSeason4 = Rule
{ name = "season"
, pattern =
[ regex "(ce )?printemps"
]
, prod = \_ -> tt $
interval TTime.Open (monthDay 3 20, monthDay 6 21)
}
ruleYearLatent2 :: Rule
ruleYearLatent2 = Rule
{ name = "year (latent)"
, pattern =
[ Predicate $ isIntegerBetween 2101 10000
]
, prod = \tokens -> case tokens of
(token:_) -> do
n <- getIntValue token
tt . mkLatent $ year n
_ -> Nothing
}
ruleNCycleAvant :: Rule
ruleNCycleAvant = Rule
{ name = "n <cycle> avant"
, pattern =
[ Predicate $ isIntegerBetween 2 9999
, dimension TimeGrain
, regex "(d')? ?avant|plus t(o|\x00f4)t"
]
, prod = \tokens -> case tokens of
(token:Token TimeGrain grain:_) -> do
n <- getIntValue token
tt . cycleNth grain $ n
_ -> Nothing
}
ruleDimTimeDuMatin :: Rule
ruleDimTimeDuMatin = Rule
{ name = "<dim time> du matin"
, pattern =
[ Predicate isATimeOfDay
, regex "((du|dans|de) )?((au|le|la) )?mat(in(\x00e9|e)?e?)?"
]
, prod = \tokens -> case tokens of
(Token Time td:_) ->
let morning = partOfDay . mkLatent $
interval TTime.Open (hour False 0, hour False 12)
in Token Time <$> intersect td morning
_ -> Nothing
}
ruleOrdinalWeekendDeTime :: Rule
ruleOrdinalWeekendDeTime = Rule
{ name = "<ordinal> week-end de <time>"
, pattern =
[ dimension Ordinal
, regex "week(\\s|-)?end (d['eu]|en|du mois de)"
, Predicate isAMonth
]
, prod = \tokens -> case tokens of
(token:_:Token Time td:_) -> do
n <- getIntValue token
from <- intersect (dayOfWeek 5) (hour False 18)
to <- intersect (dayOfWeek 1) (hour False 0)
td2 <- intersect td (interval TTime.Open (from, to))
tt $ predNth (n 1) False td2
_ -> Nothing
}
ruleNamedmonth :: Rule
ruleNamedmonth = Rule
{ name = "named-month"
, pattern =
[ regex "janvier|janv\\.?"
]
, prod = \_ -> tt $ month 1
}
ruleHourofdayEtQuart :: Rule
ruleHourofdayEtQuart = Rule
{ name = "<hour-of-day> et quart"
, pattern =
[ Predicate isAnHourOfDay
, regex "(et )?quart"
]
, prod = \tokens -> case tokens of
(Token Time TimeData {TTime.form = Just (TTime.TimeOfDay (Just hours) is12H)}:
_) -> tt $ hourMinute is12H hours 15
_ -> Nothing
}
ruleHourofdayEtDemi :: Rule
ruleHourofdayEtDemi = Rule
{ name = "<hour-of-day> et demi"
, pattern =
[ Predicate isAnHourOfDay
, regex "et demie?"
]
, prod = \tokens -> case tokens of
(Token Time TimeData {TTime.form = Just (TTime.TimeOfDay (Just hours) is12H)}:
_) -> tt $ hourMinute is12H hours 30
_ -> Nothing
}
ruleHourofdayEtTroisQuart :: Rule
ruleHourofdayEtTroisQuart = Rule
{ name = "<hour-of-day> et trois quarts"
, pattern =
[ Predicate isAnHourOfDay
, regex "(et )?(3|trois) quarts?"
]
, prod = \tokens -> case tokens of
(Token Time TimeData {TTime.form = Just (TTime.TimeOfDay (Just hours) is12H)}:
_) -> tt $ hourMinute is12H hours 45
_ -> Nothing
}
ruleHourofdayEtpassDeNumeral :: Rule
ruleHourofdayEtpassDeNumeral = Rule
{ name = "<hour-of-day> et|passé de <number>"
, pattern =
[ Predicate isAnHourOfDay
, regex "et|(pass(\x00e9|e)e? de)"
, Predicate $ isIntegerBetween 1 59
]
, prod = \tokens -> case tokens of
(Token Time TimeData {TTime.form = Just (TTime.TimeOfDay (Just hours) is12H)}:
_:
token:
_) -> do
n <- getIntValue token
tt $ hourMinute is12H hours n
_ -> Nothing
}
ruleHourofdayEtpassDeNumeralMinutes :: Rule
ruleHourofdayEtpassDeNumeralMinutes = Rule
{ name = "<hour-of-day> et|passé de <number> minutes"
, pattern =
[ Predicate isAnHourOfDay
, regex "et|(pass(\x00e9|e)e? de)"
, Predicate $ isIntegerBetween 1 59
, regex "min\\.?(ute)?s?"
]
, prod = \tokens -> case tokens of
(Token Time TimeData {TTime.form = Just (TTime.TimeOfDay (Just hours) is12H)}:
_:
token:
_) -> do
n <- getIntValue token
tt $ hourMinute is12H hours n
_ -> Nothing
}
ruleHourofdayInteger :: Rule
ruleHourofdayInteger = Rule
{ name = "<hour-of-day> <integer> (as relative minutes)"
, pattern =
[ Predicate isAnHourOfDay
, Predicate $ isIntegerBetween 1 59
]
, prod = \tokens -> case tokens of
(Token Time TimeData {TTime.form = Just (TTime.TimeOfDay (Just hours) is12H)}:
token:
_) -> do
n <- getIntValue token
tt $ hourMinute is12H hours n
_ -> Nothing
}
ruleHourofdayIntegerMinutes :: Rule
ruleHourofdayIntegerMinutes = Rule
{ name = "<hour-of-day> <integer> minutes"
, pattern =
[ Predicate isAnHourOfDay
, Predicate $ isIntegerBetween 1 59
, regex "min\\.?(ute)?s?"
]
, prod = \tokens -> case tokens of
(Token Time TimeData {TTime.form = Just (TTime.TimeOfDay (Just hours) is12H)}:
token:
_) -> do
n <- getIntValue token
tt $ hourMinute is12H hours n
_ -> Nothing
}
ruleHourofdayMoinsIntegerAsRelativeMinutes :: Rule
ruleHourofdayMoinsIntegerAsRelativeMinutes = Rule
{ name = "<hour-of-day> moins <integer> (as relative minutes)"
, pattern =
[ Predicate isAnHourOfDay
, regex "moins( le)?"
, Predicate $ isIntegerBetween 1 59
]
, prod = \tokens -> case tokens of
(Token Time td:_:token:_) -> do
n <- getIntValue token
t <- minutesBefore n td
Just $ Token Time t
_ -> Nothing
}
ruleHourofdayMoinsQuart :: Rule
ruleHourofdayMoinsQuart = Rule
{ name = "<hour-of-day> moins quart"
, pattern =
[ Predicate isAnHourOfDay
, regex "moins( le)? quart"
]
, prod = \tokens -> case tokens of
(Token Time td:_) -> do
t <- minutesBefore 15 td
Just $ Token Time t
_ -> Nothing
}
ruleAprsLeDayofmonth :: Rule
ruleAprsLeDayofmonth = Rule
{ name = "après le <day-of-month>"
, pattern =
[ regex "(apr(e|\x00e8)s le|(a|\x00e0) partir du)"
, Predicate isDOMInteger
]
, prod = \tokens -> case tokens of
(_:token:_) -> do
n <- getIntValue token
tt . withDirection TTime.After $ dayOfMonth n
_ -> Nothing
}
ruleNamedmonth3 :: Rule
ruleNamedmonth3 = Rule
{ name = "named-month"
, pattern =
[ regex "mars|mar\\.?"
]
, prod = \_ -> tt $ month 3
}
ruleCycleDernier :: Rule
ruleCycleDernier = Rule
{ name = "<cycle> dernier"
, pattern =
[ dimension TimeGrain
, regex "derni(\x00e8|e)re?|pass(\x00e9|e)e?|pr(e|\x00e9)c(e|\x00e9)dente?|(d')? ?avant"
]
, prod = \tokens -> case tokens of
(Token TimeGrain grain:_) ->
tt . cycleNth grain $ 1
_ -> Nothing
}
ruleLeOrdinalCycleDeTime :: Rule
ruleLeOrdinalCycleDeTime = Rule
{ name = "le <ordinal> <cycle> de <time>"
, pattern =
[ regex "l[ea]"
, dimension Ordinal
, dimension TimeGrain
, regex "d['eu]|en"
, dimension Time
]
, prod = \tokens -> case tokens of
(_:token:Token TimeGrain grain:_:Token Time td:_) -> do
n <- getIntValue token
tt $ cycleNthAfter True grain (n 1) td
_ -> Nothing
}
ruleEnSemaine :: Rule
ruleEnSemaine = Rule
{ name = "en semaine"
, pattern =
[ regex "(pendant la |en )?semaine"
]
, prod = \_ -> tt $
interval TTime.Open (dayOfWeek 1, dayOfWeek 5)
}
ruleDdmm :: Rule
ruleDdmm = Rule
{ name = "dd/-mm"
, pattern =
[ regex "(3[01]|[12]\\d|0?[1-9])[/-](1[0-2]|0?[1-9])"
]
, prod = \tokens -> case tokens of
(Token RegexMatch (GroupMatch (dd:mm:_)):_) -> do
m <- parseInt mm
d <- parseInt dd
tt $ monthDay m d
_ -> Nothing
}
ruleNamedmonthnameddayDernierpass :: Rule
ruleNamedmonthnameddayDernierpass = Rule
{ name = "<named-month|named-day> dernier|passé"
, pattern =
[ dimension Time
, regex "derni(e|\x00e9|\x00e8)re?|pass(\x00e9|e)e?"
]
, prod = \tokens -> case tokens of
(Token Time td:_) ->
tt $ predNth (1) False td
_ -> Nothing
}
ruleNamedmonth4 :: Rule
ruleNamedmonth4 = Rule
{ name = "named-month"
, pattern =
[ regex "avril|avr\\.?"
]
, prod = \_ -> tt $ month 4
}
ruleLeCycleDernier :: Rule
ruleLeCycleDernier = Rule
{ name = "le <cycle> dernier"
, pattern =
[ regex "l[ae']? ?"
, dimension TimeGrain
, regex "derni(\x00e8|e)re?|pass(\x00e9|e)e?"
]
, prod = \tokens -> case tokens of
(_:Token TimeGrain grain:_) ->
tt . cycleNth grain $ 1
_ -> Nothing
}
ruleNCyclePassesprecedents :: Rule
ruleNCyclePassesprecedents = Rule
{ name = "n <cycle> passes|precedents"
, pattern =
[ Predicate $ isIntegerBetween 2 9999
, dimension TimeGrain
, regex "pass(e|\x00e8|\x00e9)(e|\x00e8|\x00e9)?s?|pr(e|\x00e9)c(e|\x00e9)dente?s?|(d')? ?avant|plus t(o|\x00f4)t"
]
, prod = \tokens -> case tokens of
(token:Token TimeGrain grain:_) -> do
n <- getIntValue token
tt . cycleN True grain $ n
_ -> Nothing
}
ruleSoir :: Rule
ruleSoir = Rule
{ name = "soir"
, pattern =
[ regex "soir(\x00e9|e)?e?"
]
, prod = \_ -> tt . mkLatent . partOfDay $
interval TTime.Open (hour False 18, hour False 0)
}
ruleDbutDeSoire :: Rule
ruleDbutDeSoire = Rule
{ name = "début de soirée"
, pattern =
[ regex "d(\x00e9|e)but de soir(\x00e9|e)e?"
]
, prod = \_ -> tt . mkLatent . partOfDay $
interval TTime.Open (hour False 18, hour False 21)
}
ruleFinDeSoire :: Rule
ruleFinDeSoire = Rule
{ name = "fin de soirée"
, pattern =
[ regex "fin de soir(\x00e9|e)e?"
]
, prod = \_ -> tt . mkLatent . partOfDay $
interval TTime.Open (hour False 21, hour False 0)
}
ruleDbutDeMatine :: Rule
ruleDbutDeMatine = Rule
{ name = "début de matinée"
, pattern =
[ regex "le matin (tr(e|\x00e8)s )?t(\x00f4|o)t|(tr(e|\x00e8)s )?t(\x00f4|o)t le matin|d(\x00e9|e)but de matin(\x00e9|e)e"
]
, prod = \_ -> tt . mkLatent . partOfDay $
interval TTime.Open (hour False 7, hour False 9)
}
ruleNamedday5 :: Rule
ruleNamedday5 = Rule
{ name = "named-day"
, pattern =
[ regex "ven\\.?(dredi)?"
]
, prod = \_ -> tt $ dayOfWeek 5
}
ruleDdddMonthinterval :: Rule
ruleDdddMonthinterval = Rule
{ name = "dd-dd <month>(interval)"
, pattern =
[ regex "(3[01]|[12]\\d|0?[1-9])"
, regex "\\-|au|jusqu'au"
, regex "(3[01]|[12]\\d|0?[1-9])"
, Predicate isAMonth
]
, prod = \tokens -> case tokens of
(Token RegexMatch (GroupMatch (m1:_)):_:Token RegexMatch (GroupMatch (m2:_)):Token Time td:_) -> do
d1 <- parseInt m1
d2 <- parseInt m2
from <- intersect td (dayOfMonth d1)
to <- intersect td (dayOfMonth d2)
tt $ interval TTime.Closed (from, to)
_ -> Nothing
}
ruleTimeofdayLatent :: Rule
ruleTimeofdayLatent = Rule
{ name = "time-of-day (latent)"
, pattern =
[ Predicate $ isIntegerBetween 0 23
]
, prod = \tokens -> case tokens of
(token:_) -> do
n <- getIntValue token
tt . mkLatent $ hour (n < 12) n
_ -> Nothing
}
ruleDuDddayofweekDdMonthinterval :: Rule
ruleDuDddayofweekDdMonthinterval = Rule
{ name = "du dd-<day-of-week> dd <month>(interval)"
, pattern =
[ regex "du"
, regex "(3[01]|[12]\\d|0?[1-9])"
, regex "\\-|au|jusqu'au"
, Predicate isADayOfWeek
, regex "(3[01]|[12]\\d|0?[1-9])"
, Predicate isAMonth
]
, prod = \tokens -> case tokens of
(_:Token RegexMatch (GroupMatch (m1:_)):_:_:Token RegexMatch (GroupMatch (m2:_)):Token Time td:_) -> do
d1 <- parseInt m1
d2 <- parseInt m2
from <- intersect (dayOfMonth d1) td
to <- intersect (dayOfMonth d2) td
tt $ interval TTime.Closed (from, to)
_ -> Nothing
}
ruleDbutNamedmonthinterval :: Rule
ruleDbutNamedmonthinterval = Rule
{ name = "début <named-month>(interval)"
, pattern =
[ regex "d(\x00e9|e)but( du mois d[e'] ?)?"
, Predicate isAMonth
]
, prod = \tokens -> case tokens of
(_:Token Time td:_) -> do
from <- intersect (dayOfMonth 1) td
to <- intersect (dayOfMonth 5) td
tt $ interval TTime.Closed (from, to)
_ -> Nothing
}
ruleNamedmonth2 :: Rule
ruleNamedmonth2 = Rule
{ name = "named-month"
, pattern =
[ regex "f(\x00e9|e)vrier|f(\x00e9|e)v\\.?"
]
, prod = \_ -> tt $ month 2
}
ruleMilieuDeJourne :: Rule
ruleMilieuDeJourne = Rule
{ name = "milieu de journée"
, pattern =
[ regex "milieu de journ(\x00e9|e)e"
]
, prod = \_ -> tt . mkLatent . partOfDay $
interval TTime.Open (hour False 11, hour False 16)
}
ruleFinDeJourne :: Rule
ruleFinDeJourne = Rule
{ name = "fin de journée"
, pattern =
[ regex "fin de journ(\x00e9|e)e"
]
, prod = \_ -> tt . mkLatent . partOfDay $
interval TTime.Open (hour False 17, hour False 21)
}
ruleLeCycleDeTime :: Rule
ruleLeCycleDeTime = Rule
{ name = "le <cycle> de <time>"
, pattern =
[ regex "l[ea]"
, dimension TimeGrain
, regex "d['eu]|en"
, dimension Time
]
, prod = \tokens -> case tokens of
(_:Token TimeGrain grain:_:Token Time td:_) ->
tt $ cycleNthAfter True grain 0 td
_ -> Nothing
}
ruleSeason3 :: Rule
ruleSeason3 = Rule
{ name = "season"
, pattern =
[ regex "(cet )?hiver"
]
, prod = \_ -> tt $
interval TTime.Open (monthDay 12 21, monthDay 3 20)
}
ruleSeason :: Rule
ruleSeason = Rule
{ name = "season"
, pattern =
[ regex "(cet )?(\x00e9|e)t(\x00e9|e)"
]
, prod = \_ -> tt $
interval TTime.Open (monthDay 6 21, monthDay 9 23)
}
ruleAprsmidi :: Rule
ruleAprsmidi = Rule
{ name = "après-midi"
, pattern =
[ regex "apr(e|\x00e9|\x00e8)s?[ \\-]?midi"
]
, prod = \_ -> tt . mkLatent . partOfDay $
interval TTime.Open (hour False 12, hour False 19)
}
ruleNoel :: Rule
ruleNoel = Rule
{ name = "noel"
, pattern =
[ regex "(jour de )?no(e|\x00eb)l"
]
, prod = \_ -> tt $ monthDay 12 25
}
ruleDayofweekProchain :: Rule
ruleDayofweekProchain = Rule
{ name = "<day-of-week> prochain"
, pattern =
[ Predicate isADayOfWeek
, regex "prochain"
]
, prod = \tokens -> case tokens of
(Token Time td:_) ->
tt $ predNth 0 True td
_ -> Nothing
}
ruleDemain :: Rule
ruleDemain = Rule
{ name = "demain"
, pattern =
[ regex "(demain)|(le lendemain)"
]
, prod = \_ -> tt $ cycleNth TG.Day 1
}
ruleNamedmonthnameddaySuivantdaprs :: Rule
ruleNamedmonthnameddaySuivantdaprs = Rule
{ name = "<named-month|named-day> suivant|d'après"
, pattern =
[ dimension Time
, regex "suivante?s?|d'apr(e|\x00e9|\x00e8)s"
]
, prod = \tokens -> case tokens of
(Token Time td:_) ->
tt $ predNth 1 False td
_ -> Nothing
}
ruleNameddayEnHuit :: Rule
ruleNameddayEnHuit = Rule
{ name = "<named-day> en huit"
, pattern =
[ Predicate isADayOfWeek
, regex "en (huit|8)"
]
, prod = \tokens -> case tokens of
(Token Time td:_) ->
tt $ predNth 1 False td
_ -> Nothing
}
ruleHhmmMilitaryTimeofday :: Rule
ruleHhmmMilitaryTimeofday = Rule
{ name = "hhmm (military time-of-day)"
, pattern =
[ regex "((?:[01]?\\d)|(?:2[0-3]))([0-5]\\d)"
]
, prod = \tokens -> case tokens of
(Token RegexMatch (GroupMatch (m1:m2:_)):_) -> do
h <- parseInt m1
m <- parseInt m2
tt . mkLatent $ hourMinute False h m
_ -> Nothing
}
ruleDimTimeDuSoir :: Rule
ruleDimTimeDuSoir = Rule
{ name = "<dim time> du soir"
, pattern =
[ Predicate isATimeOfDay
, regex "((du|dans|de) )?((au|le|la) )?soir(\x00e9|e)?e?"
]
, prod = \tokens -> case tokens of
(Token Time td:_) ->
let td2 = mkLatent . partOfDay $
interval TTime.Open (hour False 16, hour False 0)
in Token Time <$> intersect td td2
_ -> Nothing
}
ruleAprsTimeofday :: Rule
ruleAprsTimeofday = Rule
{ name = "après <time-of-day>"
, pattern =
[ regex "(apr(e|\x00e8)s|(a|\x00e0) partir de)"
, dimension Time
]
, prod = \tokens -> case tokens of
(_:Token Time td:_) ->
tt $ withDirection TTime.After td
_ -> Nothing
}
ruleAprsLeDjeuner :: Rule
ruleAprsLeDjeuner = Rule
{ name = "après le déjeuner"
, pattern =
[ regex "apr(e|\x00e8)s (le )?d(e|\x00e9|\x00e8)jeuner"
]
, prod = \_ ->
let td1 = cycleNth TG.Day 0
td2 = interval TTime.Open (hour False 13, hour False 17)
in Token Time . partOfDay <$> intersect td1 td2
}
ruleIntersect :: Rule
ruleIntersect = Rule
{ name = "intersect"
, pattern =
[ Predicate isNotLatent
, Predicate isNotLatent
]
, prod = \tokens -> case tokens of
(Token Time td1:Token Time td2:_) ->
Token Time <$> intersect td1 td2
_ -> Nothing
}
ruleErMai :: Rule
ruleErMai = Rule
{ name = "1er mai"
, pattern =
[ regex "f(e|\x00ea)te du travail"
]
, prod = \_ -> tt $ monthDay 5 1
}
rulePremireQuinzaineDeNamedmonthinterval :: Rule
rulePremireQuinzaineDeNamedmonthinterval = Rule
{ name = "première quinzaine de <named-month>(interval)"
, pattern =
[ regex "(premi(\x00e8|e)re|1 ?(\x00e8|e)re) (quinzaine|15 ?aine) d[e']"
, Predicate isAMonth
]
, prod = \tokens -> case tokens of
(_:Token Time td:_) -> do
from <- intersect (dayOfMonth 1) td
to <- intersect (dayOfMonth 14) td
tt $ interval TTime.Closed (from, to)
_ -> Nothing
}
ruleDeDatetimeDatetimeInterval :: Rule
ruleDeDatetimeDatetimeInterval = Rule
{ name = "de <datetime> - <datetime> (interval)"
, pattern =
[ regex "de|depuis|du"
, dimension Time
, regex "\\-|au|jusqu'(au?|\x00e0)"
, dimension Time
]
, prod = \tokens -> case tokens of
(_:Token Time td1:_:Token Time td2:_) ->
tt $ interval TTime.Closed (td1, td2)
_ -> Nothing
}
ruleAvanthier :: Rule
ruleAvanthier = Rule
{ name = "avant-hier"
, pattern =
[ regex "avant[- ]?hier"
]
, prod = \_ -> tt . cycleNth TG.Day $ 2
}
ruleCycleProchainsuivantdaprs :: Rule
ruleCycleProchainsuivantdaprs = Rule
{ name = "<cycle> prochain|suivant|d'après"
, pattern =
[ dimension TimeGrain
, regex "prochaine?|suivante?|qui suit|(d')? ?apr(e|\x00e8|\x00e9)s"
]
, prod = \tokens -> case tokens of
(Token TimeGrain grain:_) ->
tt $ cycleNth grain 1
_ -> Nothing
}
ruleNamedmonth6 :: Rule
ruleNamedmonth6 = Rule
{ name = "named-month"
, pattern =
[ regex "juin|jun\\.?"
]
, prod = \_ -> tt $ month 6
}
ruleAprsLeTravail :: Rule
ruleAprsLeTravail = Rule
{ name = "après le travail"
, pattern =
[ regex "apr(e|\x00e8)s (le )?travail"
]
, prod = \_ ->
let td1 = cycleNth TG.Day 0
td2 = interval TTime.Open (hour False 17, hour False 21)
in Token Time . partOfDay <$> intersect td1 td2
}
ruleNamedmonth8 :: Rule
ruleNamedmonth8 = Rule
{ name = "named-month"
, pattern =
[ regex "ao(\x00fb|u)t|aou\\.?"
]
, prod = \_ -> tt $ month 8
}
ruleLeDayofmonthDatetime :: Rule
ruleLeDayofmonthDatetime = Rule
{ name = "le <day-of-month> à <datetime>"
, pattern =
[ regex "le"
, Predicate isDOMInteger
, regex "(a|\x00e0)"
, dimension Time
]
, prod = \tokens -> case tokens of
(_:token:_:Token Time td:_) -> do
n <- getIntValue token
Token Time <$> intersect (dayOfMonth n) td
_ -> Nothing
}
ruleWeekend :: Rule
ruleWeekend = Rule
{ name = "week-end"
, pattern =
[ regex "week(\\s|-)?end"
]
, prod = \_ -> do
from <- intersect (dayOfWeek 5) (hour False 18)
to <- intersect (dayOfWeek 1) (hour False 0)
tt $ interval TTime.Open (from, to)
}
ruleCedansLeCycle :: Rule
ruleCedansLeCycle = Rule
{ name = "ce|dans le <cycle>"
, pattern =
[ regex "(cet?t?e?s?)|(dans l[ae']? ?)"
, dimension TimeGrain
]
, prod = \tokens -> case tokens of
(_:Token TimeGrain grain:_) ->
tt $ cycleNth grain 0
_ -> Nothing
}
ruleDansDuration :: Rule
ruleDansDuration = Rule
{ name = "dans <duration>"
, pattern =
[ regex "dans"
, dimension Duration
]
, prod = \tokens -> case tokens of
(_:Token Duration dd:_) ->
tt $ inDuration dd
_ -> Nothing
}
ruleOrdinalCycleDeTime :: Rule
ruleOrdinalCycleDeTime = Rule
{ name = "<ordinal> <cycle> de <time>"
, pattern =
[ dimension Ordinal
, dimension TimeGrain
, regex "d['eu]|en"
, dimension Time
]
, prod = \tokens -> case tokens of
(token:Token TimeGrain grain:_:Token Time td:_) -> do
n <- getIntValue token
tt $ cycleNthAfter True grain (n 1) td
_ -> Nothing
}
ruleAvantLeDjeuner :: Rule
ruleAvantLeDjeuner = Rule
{ name = "avant le déjeuner"
, pattern =
[ regex "avant (le )?d(e|\x00e9|\x00e8)jeuner"
]
, prod = \_ ->
let td1 = cycleNth TG.Day 0
td2 = interval TTime.Open (hour False 10, hour False 12)
in Token Time . partOfDay <$> intersect td1 td2
}
ruleDernierWeekendDeTime :: Rule
ruleDernierWeekendDeTime = Rule
{ name = "dernier week-end de <time>"
, pattern =
[ regex "dernier week(\\s|-)?end (d['eu]|en|du mois de)"
, Predicate isAMonth
]
, prod = \tokens -> case tokens of
(_:Token Time td:_) -> do
from <- intersect (dayOfWeek 5) (hour False 18)
to <- intersect (dayOfWeek 1) (hour False 0)
tt $ predLastOf (interval TTime.Open (from, to)) td
_ -> Nothing
}
ruleLeCycleProchainsuivantdaprs :: Rule
ruleLeCycleProchainsuivantdaprs = Rule
{ name = "le <cycle> prochain|suivant|d'après"
, pattern =
[ regex "l[ae']? ?|une? ?"
, dimension TimeGrain
, regex "prochaine?|suivante?|qui suit|(d'? ?)?apr(e|\x00e8|\x00e9)s"
]
, prod = \tokens -> case tokens of
(_:Token TimeGrain grain:_) ->
tt $ cycleNth grain 1
_ -> Nothing
}
ruleDimTimePartofday :: Rule
ruleDimTimePartofday = Rule
{ name = "<dim time> <part-of-day>"
, pattern =
[ dimension Time
, Predicate isAPartOfDay
]
, prod = \tokens -> case tokens of
(Token Time td1:Token Time td2:_) ->
Token Time <$> intersect td1 td2
_ -> Nothing
}
ruleEnNamedmonth :: Rule
ruleEnNamedmonth = Rule
{ name = "en <named-month>"
, pattern =
[ regex "en|au mois de?'?"
, Predicate isAMonth
]
, prod = \tokens -> case tokens of
(_:x:_) -> Just x
_ -> Nothing
}
ruleEntreTimeofdayEtTimeofdayInterval :: Rule
ruleEntreTimeofdayEtTimeofdayInterval = Rule
{ name = "entre <time-of-day> et <time-of-day> (interval)"
, pattern =
[ regex "entre"
, Predicate isATimeOfDay
, regex "et"
, Predicate isATimeOfDay
]
, prod = \tokens -> case tokens of
(_:Token Time td1:_:Token Time td2:_) ->
tt $ interval TTime.Closed (td1, td2)
_ -> Nothing
}
ruleIntersectByDeOr :: Rule
ruleIntersectByDeOr = Rule
{ name = "intersect by 'de' or ','"
, pattern =
[ Predicate isNotLatent
, regex "de|,"
, Predicate isNotLatent
]
, prod = \tokens -> case tokens of
(Token Time td1:_:Token Time td2:_) ->
Token Time <$> intersect td1 td2
_ -> Nothing
}
ruleDeuximeQuinzaineDeNamedmonthinterval :: Rule
ruleDeuximeQuinzaineDeNamedmonthinterval = Rule
{ name = "deuxième quinzaine de <named-month>(interval)"
, pattern =
[ regex "(deuxi(\x00e8|e)me|2 ?(\x00e8|e)me) (quinzaine|15 ?aine) d[e']"
, Predicate isAMonth
]
, prod = \tokens -> case tokens of
(_:Token Time td:_) -> do
from <- intersect (dayOfMonth 15) td
let to = cycleLastOf TG.Day td
tt $ interval TTime.Closed (from, to)
_ -> Nothing
}
rulePartofdayDuDimTime :: Rule
rulePartofdayDuDimTime = Rule
{ name = "<part-of-day> du <dim time>"
, pattern =
[ Predicate isAPartOfDay
, regex "du"
, dimension Time
]
, prod = \tokens -> case tokens of
(Token Time td1:_:Token Time td2:_) ->
Token Time <$> intersect td1 td2
_ -> Nothing
}
ruleYyyymmdd :: Rule
ruleYyyymmdd = Rule
{ name = "yyyy-mm-dd"
, pattern =
[ regex "(\\d{2,4})-(1[0-2]|0?[1-9])-(3[01]|[12]\\d|0?[1-9])"
]
, prod = \tokens -> case tokens of
(Token RegexMatch (GroupMatch (m1:m2:m3:_)):_) -> do
y <- parseInt m1
m <- parseInt m2
d <- parseInt m3
tt $ yearMonthDay y m d
_ -> Nothing
}
ruleMilieuDeSemaine :: Rule
ruleMilieuDeSemaine = Rule
{ name = "milieu de semaine"
, pattern =
[ regex "(en |au )?milieu de (cette |la )?semaine"
]
, prod = \_ -> tt $
interval TTime.Open (dayOfWeek 3, dayOfWeek 4)
}
ruleDbutDeSemaine :: Rule
ruleDbutDeSemaine = Rule
{ name = "début de semaine"
, pattern =
[ regex "(en |au )?d(\x00e9|e)but de (cette |la )?semaine"
]
, prod = \_ -> tt $
interval TTime.Open (dayOfWeek 1, dayOfWeek 2)
}
ruleTimeofdayHeures :: Rule
ruleTimeofdayHeures = Rule
{ name = "<time-of-day> heures"
, pattern =
[ Predicate isATimeOfDay
, regex "h\\.?(eure)?s?"
]
, prod = \tokens -> case tokens of
(Token Time td:_) ->
tt $ notLatent td
_ -> Nothing
}
ruleDernierDayofweekDeTimeLatent :: Rule
ruleDernierDayofweekDeTimeLatent = Rule
{ name = "dernier <day-of-week> de <time> (latent)"
, pattern =
[ regex "derni(e|\x00e9|\x00e8)re?"
, Predicate isADayOfWeek
, regex "d['e]"
, dimension Time
]
, prod = \tokens -> case tokens of
(_:Token Time td1:_:Token Time td2:_) ->
tt $ predLastOf td1 td2
_ -> Nothing
}
ruleCeDayofweek :: Rule
ruleCeDayofweek = Rule
{ name = "ce <day-of-week>"
, pattern =
[ regex "ce"
, Predicate isADayOfWeek
]
, prod = \tokens -> case tokens of
(_:Token Time td:_) ->
tt $ predNth 0 True td
_ -> Nothing
}
ruleDuDatetimedayofweekDdMonthinterval :: Rule
ruleDuDatetimedayofweekDdMonthinterval = Rule
{ name = "du <datetime>-<day-of-week> dd <month>(interval)"
, pattern =
[ regex "du"
, dimension Time
, regex "\\-|au|jusqu'au"
, Predicate isADayOfWeek
, regex "(3[01]|[12]\\d|0?[1-9])"
, Predicate isAMonth
]
, prod = \tokens -> case tokens of
(_:Token Time td1:_:_:Token RegexMatch (GroupMatch (m:_)):Token Time td2:_) -> do
n <- parseInt m
from <- intersect td2 td1
to <- intersect (dayOfMonth n) td2
tt $ interval TTime.Closed (from, to)
_ -> Nothing
}
ruleDuDdAuDdinterval :: Rule
ruleDuDdAuDdinterval = Rule
{ name = "du dd au dd(interval)"
, pattern =
[ regex "du"
, regex "(3[01]|[12]\\d|0?[1-9])"
, regex "au|jusqu'au"
, regex "(3[01]|[12]\\d|0?[1-9])"
]
, prod = \tokens -> case tokens of
(_:Token RegexMatch (GroupMatch (m1:_)):_:Token RegexMatch (GroupMatch (m2:_)):_) -> do
n1 <- parseInt m1
n2 <- parseInt m2
tt $ interval TTime.Closed (dayOfMonth n1, dayOfMonth n2)
_ -> Nothing
}
ruleMatin :: Rule
ruleMatin = Rule
{ name = "matin"
, pattern =
[ regex "mat(in(\x00e9|e)?e?)?"
]
, prod = \_ -> tt . mkLatent . partOfDay $
interval TTime.Open (hour False 4, hour False 12)
}
ruleYearLatent :: Rule
ruleYearLatent = Rule
{ name = "year (latent)"
, pattern =
[ Predicate $ isIntegerBetween ( 10000) 999
]
, prod = \tokens -> case tokens of
(token:_) -> do
n <- getIntValue token
tt . mkLatent $ year n
_ -> Nothing
}
ruleSeason2 :: Rule
ruleSeason2 = Rule
{ name = "season"
, pattern =
[ regex "(cet )?automne"
]
, prod = \_ -> tt $
interval TTime.Open (monthDay 9 23, monthDay 12 21)
}
ruleVersTimeofday :: Rule
ruleVersTimeofday = Rule
{ name = "à|vers <time-of-day>"
, pattern =
[ regex "(vers|autour de|(a|\x00e0) environ|aux alentours de|(a|\x00e0))"
, Predicate isATimeOfDay
]
, prod = \tokens -> case tokens of
(_:Token Time td:_) ->
tt $ notLatent td
_ -> Nothing
}
ruleFinNamedmonthinterval :: Rule
ruleFinNamedmonthinterval = Rule
{ name = "fin <named-month>(interval)"
, pattern =
[ regex "fin( du mois d[e']? ?)?"
, Predicate isAMonth
]
, prod = \tokens -> case tokens of
(_:Token Time td:_) -> do
from <- intersect (dayOfMonth 25) td
let to = cycleLastOf TG.Day td
tt $ interval TTime.Closed (from, to)
_ -> Nothing
}
ruleDayofweekDayofmonth :: Rule
ruleDayofweekDayofmonth = Rule
{ name = "<day-of-week> <day-of-month>"
, pattern =
[ Predicate isADayOfWeek
, Predicate isDOMInteger
]
, prod = \tokens -> case tokens of
(Token Time td:token:_) -> Token Time <$> intersectDOM td token
_ -> Nothing
}
ruleNameddayEnQuinze :: Rule
ruleNameddayEnQuinze = Rule
{ name = "<named-day> en quinze"
, pattern =
[ Predicate isADayOfWeek
, regex "en (quinze|15)"
]
, prod = \tokens -> case tokens of
(Token Time td:_) ->
tt $ predNth 2 False td
_ -> Nothing
}
ruleLeDayofmonthNonOrdinal :: Rule
ruleLeDayofmonthNonOrdinal = Rule
{ name = "le <day-of-month> (non ordinal)"
, pattern =
[ regex "le"
, Predicate isDOMInteger
]
, prod = \tokens -> case tokens of
(_:token:_) -> do
n <- getIntValue token
tt $ dayOfMonth n
_ -> Nothing
}
ruleIntersectByMaisparExempleplutt :: Rule
ruleIntersectByMaisparExempleplutt = Rule
{ name = "intersect by 'mais/par exemple/plutôt'"
, pattern =
[ Predicate isNotLatent
, regex "mais|par exemple|plut(\x00f4|o)t"
, Predicate isNotLatent
]
, prod = \tokens -> case tokens of
(Token Time td1:_:Token Time td2:_) ->
Token Time <$> intersect td1 td2
_ -> Nothing
}
ruleLeCycleAprssuivantTime :: Rule
ruleLeCycleAprssuivantTime = Rule
{ name = "le <cycle> après|suivant <time>"
, pattern =
[ regex "l[ea']? ?"
, dimension TimeGrain
, regex "suivante?|apr(e|\x00e8|\x00e9)s"
, dimension Time
]
, prod = \tokens -> case tokens of
(_:Token TimeGrain grain:_:Token Time td:_) ->
tt $ cycleNthAfter False grain 1 td
_ -> Nothing
}
ruleEntreDdEtDdMonthinterval :: Rule
ruleEntreDdEtDdMonthinterval = Rule
{ name = "entre dd et dd <month>(interval)"
, pattern =
[ regex "entre( le)?"
, regex "(3[01]|[12]\\d|0?[1-9])"
, regex "et( le)?"
, regex "(3[01]|[12]\\d|0?[1-9])"
, Predicate isAMonth
]
, prod = \tokens -> case tokens of
(_:Token RegexMatch (GroupMatch (m1:_)):_:Token RegexMatch (GroupMatch (m2:_)):Token Time td:_) -> do
n1 <- parseInt m1
n2 <- parseInt m2
from <- intersect (dayOfMonth n1) td
to <- intersect (dayOfMonth n2) td
tt $ interval TTime.Closed (from, to)
_ -> Nothing
}
ruleAprsdemain :: Rule
ruleAprsdemain = Rule
{ name = "après-demain"
, pattern =
[ regex "apr(e|\x00e8)s[- ]?demain"
]
, prod = \_ -> tt $ cycleNth TG.Day 2
}
ruleNamedmonth5 :: Rule
ruleNamedmonth5 = Rule
{ name = "named-month"
, pattern =
[ regex "mai"
]
, prod = \_ -> tt $ month 5
}
ruleNamedday7 :: Rule
ruleNamedday7 = Rule
{ name = "named-day"
, pattern =
[ regex "dim\\.?(anche)?"
]
, prod = \_ -> tt $ dayOfWeek 7
}
ruleFinDeSemaine :: Rule
ruleFinDeSemaine = Rule
{ name = "fin de semaine"
, pattern =
[ regex "(en |(\x00e0|a) la )?fin de (cette |la )?semaine"
]
, prod = \_ -> tt $
interval TTime.Open (dayOfWeek 4, dayOfWeek 7)
}
ruleIlYADuration :: Rule
ruleIlYADuration = Rule
{ name = "il y a <duration>"
, pattern =
[ regex "il y a"
, dimension Duration
]
, prod = \tokens -> case tokens of
(_:Token Duration dd:_) ->
tt $ durationAgo dd
_ -> Nothing
}
ruleDudansLePartofday :: Rule
ruleDudansLePartofday = Rule
{ name = "du|dans le <part-of-day>"
, pattern =
[ regex "du|dans l[ae']? ?|au|en|l[ae' ]|d(\x00e8|e)s l?[ae']? ?"
, Predicate isAPartOfDay
]
, prod = \tokens -> case tokens of
(_:Token Time td:_) ->
tt $ notLatent td
_ -> Nothing
}
ruleAuDjeuner :: Rule
ruleAuDjeuner = Rule
{ name = "au déjeuner"
, pattern =
[ regex "((\x00e0|a) l(')?heure du|pendant( le)?|au)? d(e|\x00e9|\x00e8)jeuner"
]
, prod = \_ -> tt . mkLatent . partOfDay $
interval TTime.Open (hour False 12, hour False 14)
}
ruleYear :: Rule
ruleYear = Rule
{ name = "year"
, pattern =
[ Predicate $ isIntegerBetween 1000 2100
]
, prod = \tokens -> case tokens of
(token:_) -> do
n <- getIntValue token
tt $ year n
_ -> Nothing
}
ruleNamedmonth10 :: Rule
ruleNamedmonth10 = Rule
{ name = "named-month"
, pattern =
[ regex "octobre|oct\\.?"
]
, prod = \_ -> tt $ month 10
}
ruleMaintenant :: Rule
ruleMaintenant = Rule
{ name = "maintenant"
, pattern =
[ regex "maintenant|(tout de suite)"
]
, prod = \_ -> tt $ cycleNth TG.Second 0
}
ruleMilieuDeMatine :: Rule
ruleMilieuDeMatine = Rule
{ name = "milieu de matinée"
, pattern =
[ regex "milieu de matin(\x00e9|e)e"
]
, prod = \_ -> tt . mkLatent . partOfDay $
interval TTime.Open (hour False 9, hour False 11)
}
ruleFinDeMatine :: Rule
ruleFinDeMatine = Rule
{ name = "fin de matinée"
, pattern =
[ regex "fin de matin(\x00e9|e)e"
]
, prod = \_ -> tt . mkLatent . partOfDay $
interval TTime.Open (hour False 10, hour False 12)
}
ruleDdmmyyyy :: Rule
ruleDdmmyyyy = Rule
{ name = "dd/-mm/-yyyy"
, pattern =
[ regex "(3[01]|[12]\\d|0?[1-9])[/-](1[0-2]|0?[1-9])[-/](\\d{2,4})"
]
, prod = \tokens -> case tokens of
(Token RegexMatch (GroupMatch (m1:m2:m3:_)):_) -> do
y <- parseInt m3
m <- parseInt m2
d <- parseInt m1
tt $ yearMonthDay y m d
_ -> Nothing
}
ruleLeCycleAvantprcdentTime :: Rule
ruleLeCycleAvantprcdentTime = Rule
{ name = "le <cycle> avant|précédent <time>"
, pattern =
[ regex "l[ea']? ?"
, dimension TimeGrain
, regex "avant|pr(\x00e9|e)c(\x00e9|e)dent"
, dimension Time
]
, prod = \tokens -> case tokens of
(_:Token TimeGrain grain:_:Token Time td:_) ->
tt $ cycleNthAfter False grain (1) td
_ -> Nothing
}
ruleDayOfMonthPremier :: Rule
ruleDayOfMonthPremier = Rule
{ name = "day of month (premier)"
, pattern =
[ regex "premier|prem\\.?|1er|1 er"
]
, prod = \_ -> tt $ dayOfMonth 1
}
ruleTimeofdayTimeofdayInterval :: Rule
ruleTimeofdayTimeofdayInterval = Rule
{ name = "<time-of-day> - <time-of-day> (interval)"
, pattern =
[ Predicate isATimeOfDay
, regex "\\-|(jusqu')?(au?|\x00e0)"
, Predicate isATimeOfDay
]
, prod = \tokens -> case tokens of
(Token Time td1:_:Token Time td2:_) ->
tt $ interval TTime.Closed (td1, td2)
_ -> Nothing
}
ruleLeVeilleDuTime :: Rule
ruleLeVeilleDuTime = Rule
{ name = "le veille du <time>"
, pattern =
[ regex "(la )?veille du"
, dimension Time
]
, prod = \tokens -> case tokens of
(_:Token Time td:_) ->
tt $ cycleNthAfter True TG.Day (1) td
_ -> Nothing
}
ruleNamedmonth11 :: Rule
ruleNamedmonth11 = Rule
{ name = "named-month"
, pattern =
[ regex "novembre|nov\\.?"
]
, prod = \_ -> tt $ month 11
}
ruleDbutDaprsmidi :: Rule
ruleDbutDaprsmidi = Rule
{ name = "début d'après-midi"
, pattern =
[ regex "d(\x00e9|e)but d'apr(e|\x00e9|\x00e8)s?[ \\-]?midi"
]
, prod = \_ -> tt . mkLatent . partOfDay $
interval TTime.Open (hour False 12, hour False 14)
}
ruleLeTime :: Rule
ruleLeTime = Rule
{ name = "le <time>"
, pattern =
[ regex "l[ea]"
, Predicate isNotLatent
]
, prod = \tokens -> case tokens of
(_:x:_) -> Just x
_ -> Nothing
}
ruleSoirDeNol :: Rule
ruleSoirDeNol = Rule
{ name = "soir de noël"
, pattern =
[ regex "soir(\x00e9e)? de no(e|\x00eb)l"
]
, prod = \_ -> do
from <- intersect (monthDay 12 24) (hour False 18)
to <- intersect (monthDay 12 25) (hour False 0)
tt $ interval TTime.Open (from, to)
}
ruleDayofweekDayofmonthTimeofday :: Rule
ruleDayofweekDayofmonthTimeofday = Rule
{ name = "<day-of-week> <day-of-month> à <time-of-day>)"
, pattern =
[ Predicate isADayOfWeek
, Predicate isDOMInteger
, Predicate isATimeOfDay
]
, prod = \tokens -> case tokens of
(Token Time td1:token:Token Time td2:_) -> do
dom <- intersectDOM td1 token
Token Time <$> intersect dom td2
_ -> Nothing
}
ruleMilieuDaprsmidi :: Rule
ruleMilieuDaprsmidi = Rule
{ name = "fin d'après-midi"
, pattern =
[ regex "milieu d'apr(e|\x00e9|\x00e8)s?[ \\-]?midi"
]
, prod = \_ -> tt . mkLatent . partOfDay $
interval TTime.Open (hour False 15, hour False 17)
}
ruleFinDaprsmidi :: Rule
ruleFinDaprsmidi = Rule
{ name = "fin d'après-midi"
, pattern =
[ regex "fin d'apr(e|\x00e9|\x00e8)s?[ \\-]?midi"
]
, prod = \_ -> tt . mkLatent . partOfDay $
interval TTime.Open (hour False 17, hour False 19)
}
ruleJourDeLan :: Rule
ruleJourDeLan = Rule
{ name = "jour de l'an"
, pattern =
[ regex "(jour de l'|nouvel )an"
]
, prod = \_ -> tt $ monthDay 1 1
}
ruleNamedday3 :: Rule
ruleNamedday3 = Rule
{ name = "named-day"
, pattern =
[ regex "mer\\.?(credi)?"
]
, prod = \_ -> tt $ dayOfWeek 3
}
ruleMinuit :: Rule
ruleMinuit = Rule
{ name = "minuit"
, pattern =
[ regex "minuit"
]
, prod = \_ -> tt $ hour False 0
}
ruleNCycleSuivants :: Rule
ruleNCycleSuivants = Rule
{ name = "n <cycle> suivants"
, pattern =
[ Predicate $ isIntegerBetween 2 9999
, dimension TimeGrain
, regex "prochaine?s?|suivante?s?|apr(e|\x00e8|\x00e9)s|qui sui(t|ves?)|plus tard"
]
, prod = \tokens -> case tokens of
(token:Token TimeGrain grain:_) -> do
n <- getIntValue token
tt $ cycleN True grain n
_ -> Nothing
}
ruleNamedmonth13 :: Rule
ruleNamedmonth13 = Rule
{ name = "<named-month>"
, pattern =
[ regex "mi[- ]"
, Predicate isAMonth
]
, prod = \tokens -> case tokens of
(_:Token Time td:_) -> do
from <- intersect (dayOfMonth 10) td
to <- intersect (dayOfMonth 19) td
tt $ interval TTime.Open (from, to)
_ -> Nothing
}
ruleDayofweekErdayofweekDdMonthinterval :: Rule
ruleDayofweekErdayofweekDdMonthinterval = Rule
{ name = "<day-of-week> 1er-<day-of-week> dd <month>(interval)"
, pattern =
[ Predicate isADayOfWeek
, regex "premier|prem\\.?|1er|1 er"
, regex "\\-|au|jusqu'au"
, Predicate isADayOfWeek
, regex "(3[01]|[12]\\d|0?[1-9])"
, Predicate isAMonth
]
, prod = \tokens -> case tokens of
(_:_:_:_:Token RegexMatch (GroupMatch (m:_)):Token Time td:_) -> do
n <- parseInt m
from <- intersect (dayOfMonth 1) td
to <- intersect (dayOfMonth n) td
tt $ interval TTime.Closed (from, to)
_ -> Nothing
}
ruleNamedmonth9 :: Rule
ruleNamedmonth9 = Rule
{ name = "named-month"
, pattern =
[ regex "septembre|sept?\\.?"
]
, prod = \_ -> tt $ month 9
}
ruleFinDuMois :: Rule
ruleFinDuMois = Rule
{ name = "fin du mois"
, pattern =
[ regex "(((a|\x00e0) )?la )?fin (du|de) mois"
]
, prod = \_ -> do
let from = cycleNthAfter False TG.Day ( 10) $ cycleNth TG.Month 1
to = cycleNth TG.Month 1
tt . mkLatent . partOfDay $ interval TTime.Open (from, to)
}
ruleTimezone :: Rule
ruleTimezone = Rule
{ name = "<time> timezone"
, pattern =
[ Predicate $ liftM2 (&&) isATimeOfDay isNotLatent
, regex "\\b(YEKT|YEKST|YAKT|YAKST|WITA|WIT|WIB|WGT|WGST|WFT|WET|WEST|WAT|WAST|VUT|VLAT|VLAST|VET|UZT|UYT|UYST|UTC|ULAT|TVT|TMT|TLT|TKT|TJT|TFT|TAHT|SST|SRT|SGT|SCT|SBT|SAST|SAMT|RET|PYT|PYST|PWT|PST|PONT|PMST|PMDT|PKT|PHT|PHOT|PGT|PETT|PETST|PET|PDT|OMST|OMSST|NZST|NZDT|NUT|NST|NPT|NOVT|NOVST|NFT|NDT|NCT|MYT|MVT|MUT|MST|MSK|MSD|MMT|MHT|MDT|MAWT|MART|MAGT|MAGST|LINT|LHST|LHDT|KUYT|KST|KRAT|KRAST|KGT|JST|IST|IRST|IRKT|IRKST|IRDT|IOT|IDT|ICT|HOVT|HKT|GYT|GST|GMT|GILT|GFT|GET|GAMT|GALT|FNT|FKT|FKST|FJT|FJST|EST|EGT|EGST|EET|EEST|EDT|ECT|EAT|EAST|EASST|DAVT|ChST|CXT|CVT|CST|COT|CLT|CLST|CKT|CHAST|CHADT|CET|CEST|CDT|CCT|CAT|CAST|BTT|BST|BRT|BRST|BOT|BNT|AZT|AZST|AZOT|AZOST|AWST|AWDT|AST|ART|AQTT|ANAT|ANAST|AMT|AMST|ALMT|AKST|AKDT|AFT|AEST|AEDT|ADT|ACST|ACDT)\\b"
]
, prod = \tokens -> case tokens of
(Token Time td:
Token RegexMatch (GroupMatch (tz:_)):
_) -> Token Time <$> inTimezone tz td
_ -> Nothing
}
rules :: [Rule]
rules =
[ ruleAprsLeDayofmonth
, ruleAprsLeDjeuner
, ruleAprsLeTravail
, ruleAprsTimeofday
, ruleAprsdemain
, ruleAprsmidi
, ruleAuDjeuner
, ruleAujourdhui
, ruleAvantLeDjeuner
, ruleAvantTimeofday
, ruleAvanthier
, ruleCeDayofweek
, ruleCePartofday
, ruleCeTime
, ruleCedansLeCycle
, ruleCycleDernier
, ruleCycleProchainsuivantdaprs
, ruleDansDuration
, ruleDatetimeDatetimeInterval
, ruleDatetimedayofweekDdMonthinterval
, ruleDatetimeddMonthinterval
, ruleDayOfMonthPremier
, ruleDayofmonthNamedmonth
, ruleDayofweekDayofmonth
, ruleDayofweekDayofmonthTimeofday
, ruleDayofweekErdayofweekDdMonthinterval
, ruleDayofweekProchain
, ruleDbutDaprsmidi
, ruleDbutDeJourne
, ruleDbutDeMatine
, ruleDbutDeSemaine
, ruleDbutNamedmonthinterval
, ruleDdMm
, ruleDdMmYyyy
, ruleDdddMonthinterval
, ruleDdmm
, ruleDdmmyyyy
, ruleDeDatetimeDatetimeInterval
, ruleDeTimeofdayTimeofdayInterval
, ruleDemain
, ruleDernierCycleDeTimeLatent
, ruleDernierDayofweekDeTimeLatent
, ruleDernierWeekendDeTime
, ruleDeuximeQuinzaineDeNamedmonthinterval
, ruleDiciDuration
, ruleDimTimeDuMatin
, ruleDimTimeDuSoir
, ruleDimTimePartofday
, ruleDuDatetimedayofweekDdMonthinterval
, ruleDuDdAuDdinterval
, ruleDuDddayofweekDdMonthinterval
, ruleDudansLePartofday
, ruleDurationApresTime
, ruleDurationAvantTime
, ruleEnNamedmonth
, ruleEnSemaine
, ruleEntreDatetimeEtDatetimeInterval
, ruleEntreDdEtDdMonthinterval
, ruleEntreTimeofdayEtTimeofdayInterval
, ruleErMai
, ruleMilieuDaprsmidi
, ruleFinDaprsmidi
, ruleMilieuDeJourne
, ruleFinDeJourne
, ruleMilieuDeMatine
, ruleFinDeMatine
, ruleFinDeSemaine
, ruleFinNamedmonthinterval
, ruleHhhmmTimeofday
, ruleHhmmMilitaryTimeofday
, ruleHier
, ruleIlYADuration
, ruleIntersect
, ruleIntersectByDeOr
, ruleIntersectByMaisparExempleplutt
, ruleJourDeLan
, ruleLeCycleAprssuivantTime
, ruleLeCycleAvantprcdentTime
, ruleLeCycleDeTime
, ruleLeCycleDernier
, ruleLeCycleProchainsuivantdaprs
, ruleLeDayofmonthDatetime
, ruleLeDayofmonthNonOrdinal
, ruleLeLendemainDuTime
, ruleLeOrdinalCycleDeTime
, ruleLeTime
, ruleLeVeilleDuTime
, ruleMaintenant
, ruleMatin
, ruleMidi
, ruleMilieuDeSemaine
, ruleMinuit
, ruleNCycleAprs
, ruleNCycleAvant
, ruleNCyclePassesprecedents
, ruleNCycleSuivants
, ruleNDerniersCycle
, ruleNProchainsCycle
, ruleNamedday
, ruleNamedday2
, ruleNamedday3
, ruleNamedday4
, ruleNamedday5
, ruleNamedday6
, ruleNamedday7
, ruleNameddayEnHuit
, ruleNameddayEnQuinze
, ruleNamedmonth
, ruleNamedmonth10
, ruleNamedmonth11
, ruleNamedmonth12
, ruleNamedmonth13
, ruleNamedmonth2
, ruleNamedmonth3
, ruleNamedmonth4
, ruleNamedmonth5
, ruleNamedmonth6
, ruleNamedmonth7
, ruleNamedmonth8
, ruleNamedmonth9
, ruleNamedmonthProchain
, ruleNamedmonthnameddayDernierpass
, ruleNamedmonthnameddaySuivantdaprs
, ruleNoel
, ruleOrdinalCycleDeTime
, ruleOrdinalWeekendDeTime
, rulePartofdayDuDimTime
, rulePremireQuinzaineDeNamedmonthinterval
, ruleSeason
, ruleSeason2
, ruleSeason3
, ruleSeason4
, ruleSoir
, ruleDbutDeSoire
, ruleFinDeSoire
, ruleSoirDeNol
, ruleTimeofdayHeures
, ruleTimeofdayLatent
, ruleTimeofdayTimeofdayInterval
, ruleToussaint
, ruleVersTimeofday
, ruleWeekend
, ruleYear
, ruleYearLatent
, ruleYearLatent2
, ruleYyyymmdd
, ruleHourofdayMoinsQuart
, ruleHourofdayMoinsIntegerAsRelativeMinutes
, ruleHourofdayIntegerMinutes
, ruleHourofdayInteger
, ruleHourofdayEtpassDeNumeral
, ruleHourofdayEtpassDeNumeralMinutes
, ruleHourofdayEtTroisQuart
, ruleHourofdayEtQuart
, ruleHourofdayEtDemi
, ruleFinDuMois
, ruleTimezone
]