{-# OPTIONS_GHC -funbox-strict-fields #-}
{-# LANGUAGE NoImplicitPrelude, BangPatterns #-}

module Phladiprelio.General.Datatype where

import GHC.Base
import GHC.List
import Data.List (groupBy)
import Data.Char (isDigit, isSpace)
import Text.Read (readMaybe)
import Text.Show (Show(..))
import GHC.Num ((*))
import Data.Maybe (fromMaybe)

data Phladiprelio t a b = Phl {
  forall (t :: * -> *) a b. Phladiprelio t a b -> t a
inputData :: t a,
  forall (t :: * -> *) a b. Phladiprelio t a b -> t a -> t b
convF :: t a -> t b
}

-- | Universal data, can be used e. g. for phladiprelio-general series of packages.
data BasicLan a = L1 !a | L2 !Double deriving (BasicLan a -> BasicLan a -> Bool
forall a. Eq a => BasicLan a -> BasicLan a -> Bool
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
/= :: BasicLan a -> BasicLan a -> Bool
$c/= :: forall a. Eq a => BasicLan a -> BasicLan a -> Bool
== :: BasicLan a -> BasicLan a -> Bool
$c== :: forall a. Eq a => BasicLan a -> BasicLan a -> Bool
Eq, BasicLan a -> BasicLan a -> Bool
BasicLan a -> BasicLan a -> Ordering
forall a.
Eq a
-> (a -> a -> Ordering)
-> (a -> a -> Bool)
-> (a -> a -> Bool)
-> (a -> a -> Bool)
-> (a -> a -> Bool)
-> (a -> a -> a)
-> (a -> a -> a)
-> Ord a
forall {a}. Ord a => Eq (BasicLan a)
forall a. Ord a => BasicLan a -> BasicLan a -> Bool
forall a. Ord a => BasicLan a -> BasicLan a -> Ordering
forall a. Ord a => BasicLan a -> BasicLan a -> BasicLan a
min :: BasicLan a -> BasicLan a -> BasicLan a
$cmin :: forall a. Ord a => BasicLan a -> BasicLan a -> BasicLan a
max :: BasicLan a -> BasicLan a -> BasicLan a
$cmax :: forall a. Ord a => BasicLan a -> BasicLan a -> BasicLan a
>= :: BasicLan a -> BasicLan a -> Bool
$c>= :: forall a. Ord a => BasicLan a -> BasicLan a -> Bool
> :: BasicLan a -> BasicLan a -> Bool
$c> :: forall a. Ord a => BasicLan a -> BasicLan a -> Bool
<= :: BasicLan a -> BasicLan a -> Bool
$c<= :: forall a. Ord a => BasicLan a -> BasicLan a -> Bool
< :: BasicLan a -> BasicLan a -> Bool
$c< :: forall a. Ord a => BasicLan a -> BasicLan a -> Bool
compare :: BasicLan a -> BasicLan a -> Ordering
$ccompare :: forall a. Ord a => BasicLan a -> BasicLan a -> Ordering
Ord)

-- | Specific for Ukranian data type for phladiprelio-ukrainian series of packages.
data BasicUkr = U1 {-# UNPACK #-} !Char | U2 !Double deriving (BasicUkr -> BasicUkr -> Bool
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
/= :: BasicUkr -> BasicUkr -> Bool
$c/= :: BasicUkr -> BasicUkr -> Bool
== :: BasicUkr -> BasicUkr -> Bool
$c== :: BasicUkr -> BasicUkr -> Bool
Eq, Eq BasicUkr
BasicUkr -> BasicUkr -> Bool
BasicUkr -> BasicUkr -> Ordering
BasicUkr -> BasicUkr -> BasicUkr
forall a.
Eq a
-> (a -> a -> Ordering)
-> (a -> a -> Bool)
-> (a -> a -> Bool)
-> (a -> a -> Bool)
-> (a -> a -> Bool)
-> (a -> a -> a)
-> (a -> a -> a)
-> Ord a
min :: BasicUkr -> BasicUkr -> BasicUkr
$cmin :: BasicUkr -> BasicUkr -> BasicUkr
max :: BasicUkr -> BasicUkr -> BasicUkr
$cmax :: BasicUkr -> BasicUkr -> BasicUkr
>= :: BasicUkr -> BasicUkr -> Bool
$c>= :: BasicUkr -> BasicUkr -> Bool
> :: BasicUkr -> BasicUkr -> Bool
$c> :: BasicUkr -> BasicUkr -> Bool
<= :: BasicUkr -> BasicUkr -> Bool
$c<= :: BasicUkr -> BasicUkr -> Bool
< :: BasicUkr -> BasicUkr -> Bool
$c< :: BasicUkr -> BasicUkr -> Bool
compare :: BasicUkr -> BasicUkr -> Ordering
$ccompare :: BasicUkr -> BasicUkr -> Ordering
Ord)

readBasic0 
 :: Double
 -> (String -> [a])
 -> ([a] -> [Double])
 -> String 
 -> [Double]
readBasic0 :: forall a.
Double
-> (String -> [a]) -> ([a] -> [Double]) -> String -> [Double]
readBasic0 = forall a.
(String -> Bool)
-> Double
-> (String -> [a])
-> ([a] -> [Double])
-> String
-> [Double]
readBasic0G (Bool -> Bool
not forall b c a. (b -> c) -> (a -> b) -> a -> c
. forall a. [a] -> Bool
null forall b c a. (b -> c) -> (a -> b) -> a -> c
. forall a. (a -> Bool) -> [a] -> [a]
filter (Bool -> Bool
not forall b c a. (b -> c) -> (a -> b) -> a -> c
. Char -> Bool
isSpace))

readBasic :: (String -> [a]) -> ([a] -> [Double]) -> String -> [Double]
readBasic = forall a.
Double
-> (String -> [a]) -> ([a] -> [Double]) -> String -> [Double]
readBasic0 Double
1.0
{-# INLINE readBasic #-}

readBasic0G 
 :: (String -> Bool) -- ^ A special function to check whether the 'String' contains needed information. Must return 'True' for the 'String' that contains the needed for usual processment information, otherwise — 'False'.
 -> Double
 -> (String -> [a])
 -> ([a] -> [Double])
 -> String 
 -> [Double]
readBasic0G :: forall a.
(String -> Bool)
-> Double
-> (String -> [a])
-> ([a] -> [Double])
-> String
-> [Double]
readBasic0G String -> Bool
p Double
temp String -> [a]
fConvA [a] -> [Double]
fConvD xs :: String
xs@(Char
'_':String
ys) = (String -> Double
readU2 String
ws forall a. Num a => a -> a -> a
* Double
temp) forall a. a -> [a] -> [a]
: forall a.
(String -> Bool)
-> Double
-> (String -> [a])
-> ([a] -> [Double])
-> String
-> [Double]
readBasic0G String -> Bool
p Double
temp String -> [a]
fConvA [a] -> [Double]
fConvD String
qs
   where (String
ws, String
qs) = forall a. (a -> Bool) -> [a] -> ([a], [a])
span Char -> Bool
isDigit String
ys
readBasic0G String -> Bool
p Double
temp String -> [a]
fConvA [a] -> [Double]
fConvD xs :: String
xs@(Char
_:String
_) 
 | forall a. [a] -> Bool
null String
us = [Double]
dc
 | Bool
otherwise = [Double]
dc forall a. Monoid a => a -> a -> a
`mappend` ((String -> Double
readU2 String
ws forall a. Num a => a -> a -> a
* Double
d) forall a. a -> [a] -> [a]
: forall a.
(String -> Bool)
-> Double
-> (String -> [a])
-> ([a] -> [Double])
-> String
-> [Double]
readBasic0G String -> Bool
p Double
d String -> [a]
fConvA [a] -> [Double]
fConvD String
qs)
   where (String
ts, String
us) = forall a. (a -> Bool) -> [a] -> ([a], [a])
break (forall a. Eq a => a -> a -> Bool
== Char
'_') String
xs
         dc :: [Double]
dc 
           | forall a. [a] -> Bool
null String
ts Bool -> Bool -> Bool
|| Bool -> Bool
not (String -> Bool
p String
ts) = [Double
temp]
           | Bool
otherwise = [a] -> [Double]
fConvD forall b c a. (b -> c) -> (a -> b) -> a -> c
. String -> [a]
fConvA forall a b. (a -> b) -> a -> b
$ String
ts
         d :: Double
d = forall a. [a] -> a
last [Double]
dc
         vs :: String
vs = forall a. Int -> [a] -> [a]
drop Int
1 String
us
         (String
ws, String
qs) = forall a. (a -> Bool) -> [a] -> ([a], [a])
span Char -> Bool
isDigit String
vs
readBasic0G String -> Bool
_ Double
_ String -> [a]
_ [a] -> [Double]
_ String
_ = []

readBasicG :: (String -> Bool)
-> (String -> [a]) -> ([a] -> [Double]) -> String -> [Double]
readBasicG String -> Bool
p = forall a.
(String -> Bool)
-> Double
-> (String -> [a])
-> ([a] -> [Double])
-> String
-> [Double]
readBasic0G String -> Bool
p Double
1.0
{-# INLINE readBasicG #-}

readHead
 :: (String -> [a])
 -> ([a] -> [Double])
 -> String 
 -> Double
readHead :: forall a. (String -> [a]) -> ([a] -> [Double]) -> String -> Double
readHead String -> [a]
fConvA [a] -> [Double]
fConvD String
xs = Double
h  
   where hs :: [Double]
hs = [a] -> [Double]
fConvD forall b c a. (b -> c) -> (a -> b) -> a -> c
. String -> [a]
fConvA forall a b. (a -> b) -> a -> b
$ String
xs
         h :: Double
h 
           | forall a. [a] -> Bool
null [Double]
hs = Double
1.0
           | Bool
otherwise = forall a. [a] -> a
head [Double]
hs

splF :: String -> [String]
splF js :: String
js@(Char
_:String
_) 
  = case forall a. (a -> Bool) -> [a] -> ([a], [a])
span (forall a. Eq a => a -> a -> Bool
== Char
'_') String
js of
      (~String
is,[]) -> []
      ~(String
is, String
rs) -> let (String
bs, String
ds) = forall a. (a -> Bool) -> [a] -> ([a], [a])
span Char -> Bool
isDigit String
rs in String
bs forall a. a -> [a] -> [a]
: String -> [String]
splF String
ds
splF [] = []

data Read2 = D [Double] | S [Char] deriving (Read2 -> Read2 -> Bool
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
/= :: Read2 -> Read2 -> Bool
$c/= :: Read2 -> Read2 -> Bool
== :: Read2 -> Read2 -> Bool
$c== :: Read2 -> Read2 -> Bool
Eq, Int -> Read2 -> ShowS
[Read2] -> ShowS
Read2 -> String
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
showList :: [Read2] -> ShowS
$cshowList :: [Read2] -> ShowS
show :: Read2 -> String
$cshow :: Read2 -> String
showsPrec :: Int -> Read2 -> ShowS
$cshowsPrec :: Int -> Read2 -> ShowS
Show)

readBasic1G 
 :: String 
 -> [Read2]
readBasic1G :: String -> [Read2]
readBasic1G String
xs = [Read2]
xss
   where f :: String -> Read2
f xs :: String
xs@(Char
'_':String
ys) = [Double] -> Read2
D (forall a b. (a -> b) -> [a] -> [b]
map String -> Double
readU2 forall b c a. (b -> c) -> (a -> b) -> a -> c
. String -> [String]
splF forall a b. (a -> b) -> a -> b
$ String
ys)
         f String
xs = String -> Read2
S String
xs
         xss :: [Read2]
xss = forall a b. (a -> b) -> [a] -> [b]
map String -> Read2
f forall b c a. (b -> c) -> (a -> b) -> a -> c
. forall a. (a -> a -> Bool) -> [a] -> [[a]]
groupBy (\Char
x Char
y -> (Char -> Bool
isDigit Char
y Bool -> Bool -> Bool
|| Char
y forall a. Eq a => a -> a -> Bool
== Char
'_') Bool -> Bool -> Bool
&& (Char -> Bool
isDigit Char
x Bool -> Bool -> Bool
|| Char
x forall a. Eq a => a -> a -> Bool
== Char
'_') Bool -> Bool -> Bool
|| Bool -> Bool
not ([Bool] -> Bool
or [Char -> Bool
isDigit Char
x, Char -> Bool
isDigit Char
y, Char
x forall a. Eq a => a -> a -> Bool
== Char
'_', Char
y forall a. Eq a => a -> a -> Bool
== Char
'_'])) forall a b. (a -> b) -> a -> b
$ String
xs

readBasic2G 
 :: (String -> Bool) -- ^ A special function to check whether the 'String' contains needed information. Must return 'True' for the 'String' that contains the needed for usual processment information, otherwise — 'False'.
 -> (String -> [a])
 -> ([a] -> [Double])
 -> [Read2]
 -> [Double]
readBasic2G :: forall a.
(String -> Bool)
-> (String -> [a]) -> ([a] -> [Double]) -> [Read2] -> [Double]
readBasic2G String -> Bool
p String -> [a]
fConvA [a] -> [Double]
fConvD xs :: [Read2]
xs@(D [Double]
ys:S String
t:[Read2]
ts) = forall a b. (a -> b) -> [a] -> [b]
map (\Double
y -> Double
y forall a. Num a => a -> a -> a
* Double
h) [Double]
ys forall a. Monoid a => a -> a -> a
`mappend` forall a.
(String -> Bool)
-> (String -> [a]) -> ([a] -> [Double]) -> [Read2] -> [Double]
readBasic2G String -> Bool
p String -> [a]
fConvA [a] -> [Double]
fConvD (String -> Read2
S String
tforall a. a -> [a] -> [a]
:[Read2]
ts)
   where h :: Double
h = forall a. (String -> [a]) -> ([a] -> [Double]) -> String -> Double
readHead String -> [a]
fConvA [a] -> [Double]
fConvD String
t
readBasic2G String -> Bool
p String -> [a]
fConvA [a] -> [Double]
fConvD xs :: [Read2]
xs@(S String
ys:D [Double]
ts:[Read2]
ks) = [Double]
dc forall a. Monoid a => a -> a -> a
`mappend` forall a b. (a -> b) -> [a] -> [b]
map (\Double
y -> Double
y forall a. Num a => a -> a -> a
* Double
l) [Double]
ts forall a. Monoid a => a -> a -> a
`mappend` forall a.
(String -> Bool)
-> (String -> [a]) -> ([a] -> [Double]) -> [Read2] -> [Double]
readBasic2G String -> Bool
p String -> [a]
fConvA [a] -> [Double]
fConvD [Read2]
ks
   where dc :: [Double]
dc = [a] -> [Double]
fConvD forall b c a. (b -> c) -> (a -> b) -> a -> c
. String -> [a]
fConvA forall a b. (a -> b) -> a -> b
$ String
ys
         l :: Double
l = forall a. [a] -> a
last [Double]
dc
readBasic2G String -> Bool
p String -> [a]
fConvA [a] -> [Double]
fConvD [S String
ys] = [a] -> [Double]
fConvD forall b c a. (b -> c) -> (a -> b) -> a -> c
. String -> [a]
fConvA forall a b. (a -> b) -> a -> b
$ String
ys
readBasic2G String -> Bool
_ String -> [a]
_ [a] -> [Double]
_ [Read2]
_ = []

readBasic3G :: (String -> Bool)
-> (String -> [a]) -> ([a] -> [Double]) -> String -> [Double]
readBasic3G String -> Bool
p String -> [a]
fConvA [a] -> [Double]
fConvD = forall a.
(String -> Bool)
-> (String -> [a]) -> ([a] -> [Double]) -> [Read2] -> [Double]
readBasic2G String -> Bool
p String -> [a]
fConvA [a] -> [Double]
fConvD forall b c a. (b -> c) -> (a -> b) -> a -> c
.  String -> [Read2]
readBasic1G
{-# INLINABLE readBasic3G #-}

readBasic3 :: (String -> [a]) -> ([a] -> [Double]) -> String -> [Double]
readBasic3 = forall {a}.
(String -> Bool)
-> (String -> [a]) -> ([a] -> [Double]) -> String -> [Double]
readBasic3G (Bool -> Bool
not forall b c a. (b -> c) -> (a -> b) -> a -> c
. forall a. [a] -> Bool
null forall b c a. (b -> c) -> (a -> b) -> a -> c
. forall a. (a -> Bool) -> [a] -> [a]
filter (Bool -> Bool
not forall b c a. (b -> c) -> (a -> b) -> a -> c
. Char -> Bool
isSpace))
{-# INLINABLE readBasic3 #-}

-- | Is a way to read duration of the additional added time period into the line.
readU2 :: String -> Double
readU2 :: String -> Double
readU2 xs :: String
xs@(Char
y:String
ys) = forall a. a -> Maybe a -> a
fromMaybe Double
1.0 (forall a. Read a => String -> Maybe a
readMaybe (Char
yforall a. a -> [a] -> [a]
:Char
'.'forall a. a -> [a] -> [a]
:String
ys)::Maybe Double)
readU2 String
_ = Double
1.0
{-# INLINABLE readU2 #-}

-- | Is a way to read duration of the additional added time period into the line.
readU3 :: Double -> String -> Double
readU3 :: Double -> String -> Double
readU3 Double
def xs :: String
xs@(Char
y:String
ys) = forall a. a -> Maybe a -> a
fromMaybe Double
def (forall a. Read a => String -> Maybe a
readMaybe (Char
yforall a. a -> [a] -> [a]
:Char
'.'forall a. a -> [a] -> [a]
:String
ys)::Maybe Double)
readU3 Double
def String
_ = Double
def
{-# INLINABLE readU3 #-}