git-annex/Assistant/Commits.hs

33 lines
945 B
Haskell
Raw Normal View History

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