{-# LANGUAGE GADTs #-}
module DataFrame.Lazy.Internal.LogicalPlan where
import qualified Data.Text as T
import qualified DataFrame.Internal.DataFrame as D
import qualified DataFrame.Internal.Expression as E
import DataFrame.Internal.Schema (Schema)
import DataFrame.Operations.Join (JoinType)
data DataSource
=
CsvSource FilePath Char
| ParquetSource FilePath
deriving (Int -> DataSource -> ShowS
[DataSource] -> ShowS
DataSource -> String
(Int -> DataSource -> ShowS)
-> (DataSource -> String)
-> ([DataSource] -> ShowS)
-> Show DataSource
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
$cshowsPrec :: Int -> DataSource -> ShowS
showsPrec :: Int -> DataSource -> ShowS
$cshow :: DataSource -> String
show :: DataSource -> String
$cshowList :: [DataSource] -> ShowS
showList :: [DataSource] -> ShowS
Show)
data SortOrder = Ascending | Descending
deriving (Int -> SortOrder -> ShowS
[SortOrder] -> ShowS
SortOrder -> String
(Int -> SortOrder -> ShowS)
-> (SortOrder -> String)
-> ([SortOrder] -> ShowS)
-> Show SortOrder
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
$cshowsPrec :: Int -> SortOrder -> ShowS
showsPrec :: Int -> SortOrder -> ShowS
$cshow :: SortOrder -> String
show :: SortOrder -> String
$cshowList :: [SortOrder] -> ShowS
showList :: [SortOrder] -> ShowS
Show, SortOrder -> SortOrder -> Bool
(SortOrder -> SortOrder -> Bool)
-> (SortOrder -> SortOrder -> Bool) -> Eq SortOrder
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
$c== :: SortOrder -> SortOrder -> Bool
== :: SortOrder -> SortOrder -> Bool
$c/= :: SortOrder -> SortOrder -> Bool
/= :: SortOrder -> SortOrder -> Bool
Eq, Eq SortOrder
Eq SortOrder =>
(SortOrder -> SortOrder -> Ordering)
-> (SortOrder -> SortOrder -> Bool)
-> (SortOrder -> SortOrder -> Bool)
-> (SortOrder -> SortOrder -> Bool)
-> (SortOrder -> SortOrder -> Bool)
-> (SortOrder -> SortOrder -> SortOrder)
-> (SortOrder -> SortOrder -> SortOrder)
-> Ord SortOrder
SortOrder -> SortOrder -> Bool
SortOrder -> SortOrder -> Ordering
SortOrder -> SortOrder -> SortOrder
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
$ccompare :: SortOrder -> SortOrder -> Ordering
compare :: SortOrder -> SortOrder -> Ordering
$c< :: SortOrder -> SortOrder -> Bool
< :: SortOrder -> SortOrder -> Bool
$c<= :: SortOrder -> SortOrder -> Bool
<= :: SortOrder -> SortOrder -> Bool
$c> :: SortOrder -> SortOrder -> Bool
> :: SortOrder -> SortOrder -> Bool
$c>= :: SortOrder -> SortOrder -> Bool
>= :: SortOrder -> SortOrder -> Bool
$cmax :: SortOrder -> SortOrder -> SortOrder
max :: SortOrder -> SortOrder -> SortOrder
$cmin :: SortOrder -> SortOrder -> SortOrder
min :: SortOrder -> SortOrder -> SortOrder
Ord)
data LogicalPlan
=
Scan DataSource Schema
|
Project [T.Text] LogicalPlan
|
Filter (E.Expr Bool) LogicalPlan
|
Derive T.Text E.UExpr LogicalPlan
|
Join JoinType T.Text T.Text LogicalPlan LogicalPlan
|
Aggregate [T.Text] [(T.Text, E.UExpr)] LogicalPlan
|
Sort [(T.Text, SortOrder)] LogicalPlan
|
Limit Int LogicalPlan
|
SourceDF D.DataFrame
deriving (Int -> LogicalPlan -> ShowS
[LogicalPlan] -> ShowS
LogicalPlan -> String
(Int -> LogicalPlan -> ShowS)
-> (LogicalPlan -> String)
-> ([LogicalPlan] -> ShowS)
-> Show LogicalPlan
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
$cshowsPrec :: Int -> LogicalPlan -> ShowS
showsPrec :: Int -> LogicalPlan -> ShowS
$cshow :: LogicalPlan -> String
show :: LogicalPlan -> String
$cshowList :: [LogicalPlan] -> ShowS
showList :: [LogicalPlan] -> ShowS
Show)