27 lines
		
	
	
	
		
			712 B
			
		
	
	
	
		
			Haskell
		
	
	
	
	
	
			
		
		
	
	
			27 lines
		
	
	
	
		
			712 B
			
		
	
	
	
		
			Haskell
		
	
	
	
	
	
{- git-annex assistant commit tracking
 | 
						|
 -
 | 
						|
 - Copyright 2012 Joey Hess <joey@kitenet.net>
 | 
						|
 -
 | 
						|
 - Licensed under the GNU GPL version 3 or higher.
 | 
						|
 -}
 | 
						|
 | 
						|
module Assistant.Commits where
 | 
						|
 | 
						|
import Assistant.Common
 | 
						|
import Assistant.Types.Commits
 | 
						|
 | 
						|
import Utility.TSet
 | 
						|
 | 
						|
{- Gets all unhandled commits.
 | 
						|
 - Blocks until at least one commit is made. -}
 | 
						|
getCommits :: Assistant [Commit]
 | 
						|
getCommits = getTSet <<~ commitChan
 | 
						|
 | 
						|
{- Puts unhandled commits back into the channel.
 | 
						|
 - Note: Original order is not preserved. -}
 | 
						|
refillCommits :: [Commit] -> Assistant ()
 | 
						|
refillCommits cs = flip putTSet cs <<~ commitChan
 | 
						|
 | 
						|
{- Records a commit in the channel. -}
 | 
						|
recordCommit :: Assistant ()
 | 
						|
recordCommit = flip putTSet1 Commit <<~ commitChan
 |