Attoparsec提供了消耗至少一个字符的函数takeWhile1
。在attoparsec中实现skipWhile1
但是,skipWhile
没有模拟。我如何实现这个功能skipWhile1
?
注意:这个问题故意显示没有研究工作,因为它被回答Q & A-样式。
Attoparsec提供了消耗至少一个字符的函数takeWhile1
。在attoparsec中实现skipWhile1
但是,skipWhile
没有模拟。我如何实现这个功能skipWhile1
?
注意:这个问题故意显示没有研究工作,因为它被回答Q & A-样式。
另一种可能的实现:
import Control.Applicative
skipWhile1 p = skip p *> skipWhile p
这实际上可能比@快乌利的答案,因为takeWhile
构建一个结果字符串,而skipWhile
没有。懒惰可能会使它们等价(也就是说,如果不使用它,也许takeWhile
实际上并不构建该字符串);目前我无法测试以验证这一点。
您可以使用Control.Monad.void
与takeWhile1
一起简单地忽略结果:
import Data.Attoparsec.Char8
import Control.Monad (void)
skipWhile1 :: (Char -> Bool) -> Parser()
skipWhile1 = void . takeWhile1