diff options
author | Ben Sima <ben@bsima.me> | 2019-09-04 07:08:46 -0700 |
---|---|---|
committer | Ben Sima <ben@bsima.me> | 2019-09-04 07:08:46 -0700 |
commit | 291a40f56ccc937a1f0c6735efb795e28c5c360b (patch) | |
tree | b8ea764ac0802e3d79cb9f2a14061aa30e966359 /lore/Biz/Ibb/Keep.hs | |
parent | 481fa104753d51de9df060ff77ed68790c774955 (diff) |
[ibb] implement keep
Diffstat (limited to 'lore/Biz/Ibb/Keep.hs')
-rw-r--r-- | lore/Biz/Ibb/Keep.hs | 54 |
1 files changed, 52 insertions, 2 deletions
diff --git a/lore/Biz/Ibb/Keep.hs b/lore/Biz/Ibb/Keep.hs index 533dab8..03ec143 100644 --- a/lore/Biz/Ibb/Keep.hs +++ b/lore/Biz/Ibb/Keep.hs @@ -13,10 +13,29 @@ module Biz.Ibb.Keep where import Biz.Ibb.Core (Person(..), Book(..)) -import Data.SafeCopy +import Control.Monad.State (get, put) +import Data.Acid (Update) import Data.Data (Data, Typeable) +import Data.IxSet (Indexable(..), IxSet, ixFun, ixSet) +import qualified Data.IxSet as IxSet +import Data.SafeCopy import Data.Text (Text) -import Data.IxSet (Indexable(..), ixFun, ixSet) +import qualified Data.Text as Text + +-- * Keep + +-- | Main database. Need to think of a better name for this. +data IbbKeep = IbbKeep + { _people :: IxSet Person + } + deriving (Data, Typeable) + +$(deriveSafeCopy 0 'base ''IbbKeep) + +initialIbbKeep :: IbbKeep +initialIbbKeep = IbbKeep + { _people = empty + } -- * Index @Person@ @@ -38,6 +57,23 @@ instance Indexable Person where , ixFun $ \p -> [ PersonBlurb $ _blurb p ] ] +-- | updates the `IbbKeep` with a new `Person` +newPerson :: Text -> Text -> Update IbbKeep Person +newPerson name blurb = do + k <- get + put $ k { _people = IxSet.insert p (_people k) + } + return p + where + p = Person + { _name = name + , _pic = Text.empty + , _twitter = Text.empty + , _website = Text.empty + , _books = [] + , _blurb = blurb + } + -- * Index @Book@ $(deriveSafeCopy 0 'base ''Book) @@ -54,3 +90,17 @@ instance Indexable Book where , ixFun $ \b -> [ BookAuthor $ _author b ] , ixFun $ \b -> [ _amznref b ] ] + +-- | updates the `IbbKeep` with a new `Book` +--newBook :: Text -> Text -> Text -> Update IbbKeep Book +--newBook title author amznref = do +-- ibbKeep <- get +-- put $ ibbKeep { _books = IxSet.insert b (_books ibbKeep) +-- , _people = _people ibbKeep +-- } +-- return b +-- where +-- b = Book { _title = title +-- , _author = author +-- , _amznref = amznref +-- } |