git-annex/Assistant/Commits.hs

33 lines
945 B
Haskell
Raw Normal View History

2012-06-22 17:39:44 +00:00
{- git-annex assistant commit tracking
-
- Copyright 2012 Joey Hess <id@joeyh.name>
2012-06-23 05:20:40 +00:00
-
- Licensed under the GNU AGPL version 3 or higher.
2012-06-22 17:39:44 +00:00
-}
module Assistant.Commits where
2012-10-29 23:35:18 +00:00
import Assistant.Common
import Assistant.Types.Commits
2013-04-24 21:16:04 +00:00
import Utility.TList
2012-06-22 17:39:44 +00:00
import Control.Concurrent.STM
2012-06-22 17:39:44 +00:00
{- Gets all unhandled commits.
- Blocks until at least one commit is made. -}
2012-10-29 23:35:18 +00:00
getCommits :: Assistant [Commit]
2013-04-24 21:16:04 +00:00
getCommits = (atomically . getTList) <<~ commitChan
2012-06-22 17:39:44 +00:00
{- Records a commit in the channel. -}
2012-10-29 23:35:18 +00:00
recordCommit :: Assistant ()
2013-04-24 21:16:04 +00:00
recordCommit = (atomically . flip consTList Commit) <<~ commitChan
{- Gets all unhandled export commits.
- Blocks until at least one export commit is made. -}
getExportCommits :: Assistant [Commit]
getExportCommits = (atomically . getTList) <<~ exportCommitChan
{- Records an export commit in the channel. -}
recordExportCommit :: Assistant ()
recordExportCommit = (atomically . flip consTList Commit) <<~ exportCommitChan