:: Ord a => [a] -> [a] -package:list-t -package:Cabal-syntax -package:vector-algorithms is:exact -package:safe -package:errors -package:lifted-base -package:extra -package:base package:parsers

Take a parser that may consume input, and on failure, go back to where we started and fail as if we didn't consume input.