module System.USB.IDDB.Misc
( eitherMaybe
, swap
, restOfLine
) where
import "base" Data.Either ( Either, either )
import "base" Data.Function ( ($), const, flip )
import "base" Data.Maybe ( Maybe(..) )
import "base" Data.Tuple ( uncurry )
import "base" Prelude ( String )
import "parsimony" Parsimony (Parser, manyTill)
import "parsimony" Parsimony.Char (anyChar, newline)
eitherMaybe ∷ Either r α → Maybe α
eitherMaybe = either (const Nothing) Just
swap ∷ (α, β) → (β, α)
swap = uncurry $ flip (,)
restOfLine ∷ Parser String String
restOfLine = manyTill anyChar newline