Skip to content

Commit

Permalink
Get rid of voidM
Browse files Browse the repository at this point in the history
  • Loading branch information
norm2782 committed Jan 18, 2012
1 parent 0f13a59 commit 720dd0d
Showing 1 changed file with 7 additions and 12 deletions.
19 changes: 7 additions & 12 deletions src/Application.hs
Original file line number Original file line Diff line number Diff line change
Expand Up @@ -190,7 +190,7 @@ addStoredRuleH = restrict forbiddenH $ do
Left err -> error500H err Left err -> error500H err
Right rl -> do Right rl -> do
uid <- getUserId uid <- getUserId
voidM $ insertRule uid rl void $ insertRule uid rl


loadExampleH :: AppHandler () loadExampleH :: AppHandler ()
loadExampleH = restrict forbiddenH $ do loadExampleH = restrict forbiddenH $ do
Expand Down Expand Up @@ -339,23 +339,18 @@ registrationForm = (\ep pp _ -> FormUser (fst ep) (fst pp) False)
------------------------------------------------------------------------------- -------------------------------------------------------------------------------
-- Database interaction -- Database interaction


voidM :: Monad m => m a -> m () insertRule :: (Functor m, HasHdbc m c s) => UserId -> Rule -> m (Maybe Int)
voidM m = do
_ <- m
return ()

insertRule :: HasHdbc m c s => UserId -> Rule -> m (Maybe Int)
insertRule uid rl = insertRule uid rl =
let sqlVals = [toSql $ unUid uid, toSql $ show rl] let sqlVals = [toSql $ unUid uid, toSql $ show rl]
in do in do
voidM $ query' "INSERT INTO rules (uid, rule_order, rule) VALUES (?, 1, ?)" sqlVals void $ query' "INSERT INTO rules (uid, rule_order, rule) VALUES (?, 1, ?)" sqlVals
rws <- query "SELECT rid FROM rules WHERE uid = ? AND rule = ? ORDER BY rid DESC" sqlVals rws <- query "SELECT rid FROM rules WHERE uid = ? AND rule = ? ORDER BY rid DESC" sqlVals
return $ case rws of return $ case rws of
[] -> Nothing [] -> Nothing
(x:_) -> Just $ fromSql $ x DM.! "rid" (x:_) -> Just $ fromSql $ x DM.! "rid"


deleteRule :: HasHdbc m c s => UserId -> ByteString -> m () deleteRule :: (Functor m, HasHdbc m c s) => UserId -> ByteString -> m ()
deleteRule uid rid = voidM $ query' deleteRule uid rid = void $ query'
"DELETE FROM rules WHERE rid = ? AND uid = ?" [toSql rid, toSql uid] "DELETE FROM rules WHERE rid = ? AND uid = ?" [toSql rid, toSql uid]


getStoredRules :: HasHdbc m c s => UserId -> m [DBRule] getStoredRules :: HasHdbc m c s => UserId -> m [DBRule]
Expand All @@ -369,7 +364,7 @@ getStoredRules uid = do
(rdSql "rule_order") (rdSql "rule_order")
(fst . startParse pRule $ CS (rdSql "rule")) (fst . startParse pRule $ CS (rdSql "rule"))


deleteUserRules :: HasHdbc m c s => UserId -> m () deleteUserRules :: (Functor m, HasHdbc m c s) => UserId -> m ()
deleteUserRules uid = voidM $ query' deleteUserRules uid = void $ query'
"DELETE FROM rules WHERE uid = ?" [toSql uid] "DELETE FROM rules WHERE uid = ?" [toSql uid]


0 comments on commit 720dd0d

Please sign in to comment.