Types.hs 1.98 KB
Newer Older
1 2 3 4 5 6 7 8 9 10 11 12 13
{-|
Module      : Parsers.Types
Description : 
Copyright   : (c) CNRS, 2017-Present
License     : AGPL + CECILL v3
Maintainer  : team@gargantext.org
Stability   : experimental
Portability : POSIX

Here is a longer description of this module, containing some
commentary with @some markup@.
-}

14
{-# OPTIONS_GHC -fno-warn-orphans #-}
15

16
{-# LANGUAGE StandaloneDeriving   #-}
17 18 19 20 21 22

module Parsers.Types where

import Gargantext.Prelude

import Test.QuickCheck
Mael NICOLAS's avatar
Mael NICOLAS committed
23
import Test.QuickCheck.Instances ()
24 25

import Text.Parsec.Pos
26
import Text.Parsec.Error (ParseError, Message(..), newErrorMessage)
Mael NICOLAS's avatar
Mael NICOLAS committed
27
import Data.Time.LocalTime (ZonedTime (..), TimeZone (..), TimeOfDay(..), LocalTime(..))
28
import Data.Eq (Eq(..))
Mael NICOLAS's avatar
Mael NICOLAS committed
29 30
import Data.Either (Either(..))

31
deriving instance Eq ZonedTime
32

Mael NICOLAS's avatar
Mael NICOLAS committed
33
looseTimeOfDayPrecision :: TimeOfDay -> TimeOfDay
34
looseTimeOfDayPrecision (TimeOfDay h m _) = TimeOfDay h m 0
Mael NICOLAS's avatar
Mael NICOLAS committed
35 36 37 38 39 40 41 42 43 44 45 46 47 48

looseLocalTimePrecision :: LocalTime -> LocalTime
looseLocalTimePrecision (LocalTime ld ltd) = LocalTime ld $ looseTimeOfDayPrecision ltd

looseTimeZonePrecision :: TimeZone -> TimeZone
looseTimeZonePrecision (TimeZone zm _ _) = TimeZone zm False "CET"

looseZonedTimePrecision :: ZonedTime -> ZonedTime
looseZonedTimePrecision (ZonedTime lt tz) = ZonedTime (looseLocalTimePrecision lt) $ looseTimeZonePrecision tz

loosePrecisionEitherPEZT :: Either ParseError ZonedTime -> Either ParseError ZonedTime
loosePrecisionEitherPEZT (Right zt) = Right $ looseZonedTimePrecision zt
loosePrecisionEitherPEZT pe = pe

49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69
instance Arbitrary Message where
  arbitrary = do
    msgContent <- arbitrary
    oneof $ return <$> [SysUnExpect msgContent
                       , UnExpect msgContent
                       , Expect msgContent
                       , Message msgContent
                       ]

instance Arbitrary SourcePos where
  arbitrary = do
    sn <- arbitrary
    l <- arbitrary
    c <- arbitrary
    return $ newPos sn l c

instance Arbitrary ParseError where
  arbitrary = do
    sp <- arbitrary
    msg <- arbitrary
    return $ newErrorMessage msg sp