{-# LINE 1 "src/Text/Regex/Posix/Wrap.hsc" #-}
{-# OPTIONS_GHC -Wall -fno-warn-unused-imports #-}
module Text.Regex.Posix.Wrap(
Regex,
RegOffset,
RegOffsetT,
(=~),
(=~~),
WrapError,
wrapCompile,
wrapTest,
wrapMatch,
wrapMatchAll,
wrapCount,
unusedRegOffset,
CompOption(CompOption),
compBlank,
compExtended,
compIgnoreCase,
compNoSub,
compNewline,
ExecOption(ExecOption),
execBlank,
execNotBOL,
execNotEOL,
ReturnCode(ReturnCode),
retBadbr,
retBadpat,
retBadrpt,
retEcollate,
retEctype,
retEescape,
retEsubreg,
retEbrack,
retEparen,
retEbrace,
retErange,
retEspace
) where
{-# LINE 95 "src/Text/Regex/Posix/Wrap.hsc" #-}
import Prelude hiding (fail)
import Control.Monad.Fail (MonadFail)
import Control.Monad(liftM)
import Data.Array(Array,listArray)
import Data.Bits(Bits(..))
import Data.Int(Int32,Int64)
import Data.Word(Word32,Word64)
import Foreign(Ptr, FunPtr, nullPtr, newForeignPtr,
addForeignPtrFinalizer, Storable(peekByteOff), allocaArray,
allocaBytes, withForeignPtr,ForeignPtr,plusPtr,peekElemOff)
import Foreign.Marshal.Alloc(mallocBytes)
import Foreign.C(CChar)
{-# LINE 114 "src/Text/Regex/Posix/Wrap.hsc" #-}
import Foreign.C(CSize(CSize),CInt(CInt))
{-# LINE 118 "src/Text/Regex/Posix/Wrap.hsc" #-}
import Foreign.C.String(peekCAString, CString)
import Text.Regex.Base.RegexLike(RegexOptions(..),RegexMaker(..),RegexContext(..),MatchArray)
import qualified Control.Exception(try,IOException)
try :: IO a -> IO (Either Control.Exception.IOException a)
try :: forall a. IO a -> IO (Either IOException a)
try = IO a -> IO (Either IOException a)
forall e a. Exception e => IO a -> IO (Either e a)
Control.Exception.try
data CRegex
type RegOffset = Int64
type RegOffsetT = (Int32)
{-# LINE 145 "src/Text/Regex/Posix/Wrap.hsc" #-}
newtype CompOption = CompOption CInt deriving (CompOption -> CompOption -> Bool
(CompOption -> CompOption -> Bool)
-> (CompOption -> CompOption -> Bool) -> Eq CompOption
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
$c== :: CompOption -> CompOption -> Bool
== :: CompOption -> CompOption -> Bool
$c/= :: CompOption -> CompOption -> Bool
/= :: CompOption -> CompOption -> Bool
Eq,Int -> CompOption -> ShowS
[CompOption] -> ShowS
CompOption -> String
(Int -> CompOption -> ShowS)
-> (CompOption -> String)
-> ([CompOption] -> ShowS)
-> Show CompOption
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
$cshowsPrec :: Int -> CompOption -> ShowS
showsPrec :: Int -> CompOption -> ShowS
$cshow :: CompOption -> String
show :: CompOption -> String
$cshowList :: [CompOption] -> ShowS
showList :: [CompOption] -> ShowS
Show,Integer -> CompOption
CompOption -> CompOption
CompOption -> CompOption -> CompOption
(CompOption -> CompOption -> CompOption)
-> (CompOption -> CompOption -> CompOption)
-> (CompOption -> CompOption -> CompOption)
-> (CompOption -> CompOption)
-> (CompOption -> CompOption)
-> (CompOption -> CompOption)
-> (Integer -> CompOption)
-> Num CompOption
forall a.
(a -> a -> a)
-> (a -> a -> a)
-> (a -> a -> a)
-> (a -> a)
-> (a -> a)
-> (a -> a)
-> (Integer -> a)
-> Num a
$c+ :: CompOption -> CompOption -> CompOption
+ :: CompOption -> CompOption -> CompOption
$c- :: CompOption -> CompOption -> CompOption
- :: CompOption -> CompOption -> CompOption
$c* :: CompOption -> CompOption -> CompOption
* :: CompOption -> CompOption -> CompOption
$cnegate :: CompOption -> CompOption
negate :: CompOption -> CompOption
$cabs :: CompOption -> CompOption
abs :: CompOption -> CompOption
$csignum :: CompOption -> CompOption
signum :: CompOption -> CompOption
$cfromInteger :: Integer -> CompOption
fromInteger :: Integer -> CompOption
Num,Eq CompOption
CompOption
Eq CompOption =>
(CompOption -> CompOption -> CompOption)
-> (CompOption -> CompOption -> CompOption)
-> (CompOption -> CompOption -> CompOption)
-> (CompOption -> CompOption)
-> (CompOption -> Int -> CompOption)
-> (CompOption -> Int -> CompOption)
-> CompOption
-> (Int -> CompOption)
-> (CompOption -> Int -> CompOption)
-> (CompOption -> Int -> CompOption)
-> (CompOption -> Int -> CompOption)
-> (CompOption -> Int -> Bool)
-> (CompOption -> Maybe Int)
-> (CompOption -> Int)
-> (CompOption -> Bool)
-> (CompOption -> Int -> CompOption)
-> (CompOption -> Int -> CompOption)
-> (CompOption -> Int -> CompOption)
-> (CompOption -> Int -> CompOption)
-> (CompOption -> Int -> CompOption)
-> (CompOption -> Int -> CompOption)
-> (CompOption -> Int)
-> Bits CompOption
Int -> CompOption
CompOption -> Bool
CompOption -> Int
CompOption -> Maybe Int
CompOption -> CompOption
CompOption -> Int -> Bool
CompOption -> Int -> CompOption
CompOption -> CompOption -> CompOption
forall a.
Eq a =>
(a -> a -> a)
-> (a -> a -> a)
-> (a -> a -> a)
-> (a -> a)
-> (a -> Int -> a)
-> (a -> Int -> a)
-> a
-> (Int -> a)
-> (a -> Int -> a)
-> (a -> Int -> a)
-> (a -> Int -> a)
-> (a -> Int -> Bool)
-> (a -> Maybe Int)
-> (a -> Int)
-> (a -> Bool)
-> (a -> Int -> a)
-> (a -> Int -> a)
-> (a -> Int -> a)
-> (a -> Int -> a)
-> (a -> Int -> a)
-> (a -> Int -> a)
-> (a -> Int)
-> Bits a
$c.&. :: CompOption -> CompOption -> CompOption
.&. :: CompOption -> CompOption -> CompOption
$c.|. :: CompOption -> CompOption -> CompOption
.|. :: CompOption -> CompOption -> CompOption
$cxor :: CompOption -> CompOption -> CompOption
xor :: CompOption -> CompOption -> CompOption
$ccomplement :: CompOption -> CompOption
complement :: CompOption -> CompOption
$cshift :: CompOption -> Int -> CompOption
shift :: CompOption -> Int -> CompOption
$crotate :: CompOption -> Int -> CompOption
rotate :: CompOption -> Int -> CompOption
$czeroBits :: CompOption
zeroBits :: CompOption
$cbit :: Int -> CompOption
bit :: Int -> CompOption
$csetBit :: CompOption -> Int -> CompOption
setBit :: CompOption -> Int -> CompOption
$cclearBit :: CompOption -> Int -> CompOption
clearBit :: CompOption -> Int -> CompOption
$ccomplementBit :: CompOption -> Int -> CompOption
complementBit :: CompOption -> Int -> CompOption
$ctestBit :: CompOption -> Int -> Bool
testBit :: CompOption -> Int -> Bool
$cbitSizeMaybe :: CompOption -> Maybe Int
bitSizeMaybe :: CompOption -> Maybe Int
$cbitSize :: CompOption -> Int
bitSize :: CompOption -> Int
$cisSigned :: CompOption -> Bool
isSigned :: CompOption -> Bool
$cshiftL :: CompOption -> Int -> CompOption
shiftL :: CompOption -> Int -> CompOption
$cunsafeShiftL :: CompOption -> Int -> CompOption
unsafeShiftL :: CompOption -> Int -> CompOption
$cshiftR :: CompOption -> Int -> CompOption
shiftR :: CompOption -> Int -> CompOption
$cunsafeShiftR :: CompOption -> Int -> CompOption
unsafeShiftR :: CompOption -> Int -> CompOption
$crotateL :: CompOption -> Int -> CompOption
rotateL :: CompOption -> Int -> CompOption
$crotateR :: CompOption -> Int -> CompOption
rotateR :: CompOption -> Int -> CompOption
$cpopCount :: CompOption -> Int
popCount :: CompOption -> Int
Bits)
newtype ExecOption = ExecOption CInt deriving (ExecOption -> ExecOption -> Bool
(ExecOption -> ExecOption -> Bool)
-> (ExecOption -> ExecOption -> Bool) -> Eq ExecOption
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
$c== :: ExecOption -> ExecOption -> Bool
== :: ExecOption -> ExecOption -> Bool
$c/= :: ExecOption -> ExecOption -> Bool
/= :: ExecOption -> ExecOption -> Bool
Eq,Int -> ExecOption -> ShowS
[ExecOption] -> ShowS
ExecOption -> String
(Int -> ExecOption -> ShowS)
-> (ExecOption -> String)
-> ([ExecOption] -> ShowS)
-> Show ExecOption
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
$cshowsPrec :: Int -> ExecOption -> ShowS
showsPrec :: Int -> ExecOption -> ShowS
$cshow :: ExecOption -> String
show :: ExecOption -> String
$cshowList :: [ExecOption] -> ShowS
showList :: [ExecOption] -> ShowS
Show,Integer -> ExecOption
ExecOption -> ExecOption
ExecOption -> ExecOption -> ExecOption
(ExecOption -> ExecOption -> ExecOption)
-> (ExecOption -> ExecOption -> ExecOption)
-> (ExecOption -> ExecOption -> ExecOption)
-> (ExecOption -> ExecOption)
-> (ExecOption -> ExecOption)
-> (ExecOption -> ExecOption)
-> (Integer -> ExecOption)
-> Num ExecOption
forall a.
(a -> a -> a)
-> (a -> a -> a)
-> (a -> a -> a)
-> (a -> a)
-> (a -> a)
-> (a -> a)
-> (Integer -> a)
-> Num a
$c+ :: ExecOption -> ExecOption -> ExecOption
+ :: ExecOption -> ExecOption -> ExecOption
$c- :: ExecOption -> ExecOption -> ExecOption
- :: ExecOption -> ExecOption -> ExecOption
$c* :: ExecOption -> ExecOption -> ExecOption
* :: ExecOption -> ExecOption -> ExecOption
$cnegate :: ExecOption -> ExecOption
negate :: ExecOption -> ExecOption
$cabs :: ExecOption -> ExecOption
abs :: ExecOption -> ExecOption
$csignum :: ExecOption -> ExecOption
signum :: ExecOption -> ExecOption
$cfromInteger :: Integer -> ExecOption
fromInteger :: Integer -> ExecOption
Num,Eq ExecOption
ExecOption
Eq ExecOption =>
(ExecOption -> ExecOption -> ExecOption)
-> (ExecOption -> ExecOption -> ExecOption)
-> (ExecOption -> ExecOption -> ExecOption)
-> (ExecOption -> ExecOption)
-> (ExecOption -> Int -> ExecOption)
-> (ExecOption -> Int -> ExecOption)
-> ExecOption
-> (Int -> ExecOption)
-> (ExecOption -> Int -> ExecOption)
-> (ExecOption -> Int -> ExecOption)
-> (ExecOption -> Int -> ExecOption)
-> (ExecOption -> Int -> Bool)
-> (ExecOption -> Maybe Int)
-> (ExecOption -> Int)
-> (ExecOption -> Bool)
-> (ExecOption -> Int -> ExecOption)
-> (ExecOption -> Int -> ExecOption)
-> (ExecOption -> Int -> ExecOption)
-> (ExecOption -> Int -> ExecOption)
-> (ExecOption -> Int -> ExecOption)
-> (ExecOption -> Int -> ExecOption)
-> (ExecOption -> Int)
-> Bits ExecOption
Int -> ExecOption
ExecOption -> Bool
ExecOption -> Int
ExecOption -> Maybe Int
ExecOption -> ExecOption
ExecOption -> Int -> Bool
ExecOption -> Int -> ExecOption
ExecOption -> ExecOption -> ExecOption
forall a.
Eq a =>
(a -> a -> a)
-> (a -> a -> a)
-> (a -> a -> a)
-> (a -> a)
-> (a -> Int -> a)
-> (a -> Int -> a)
-> a
-> (Int -> a)
-> (a -> Int -> a)
-> (a -> Int -> a)
-> (a -> Int -> a)
-> (a -> Int -> Bool)
-> (a -> Maybe Int)
-> (a -> Int)
-> (a -> Bool)
-> (a -> Int -> a)
-> (a -> Int -> a)
-> (a -> Int -> a)
-> (a -> Int -> a)
-> (a -> Int -> a)
-> (a -> Int -> a)
-> (a -> Int)
-> Bits a
$c.&. :: ExecOption -> ExecOption -> ExecOption
.&. :: ExecOption -> ExecOption -> ExecOption
$c.|. :: ExecOption -> ExecOption -> ExecOption
.|. :: ExecOption -> ExecOption -> ExecOption
$cxor :: ExecOption -> ExecOption -> ExecOption
xor :: ExecOption -> ExecOption -> ExecOption
$ccomplement :: ExecOption -> ExecOption
complement :: ExecOption -> ExecOption
$cshift :: ExecOption -> Int -> ExecOption
shift :: ExecOption -> Int -> ExecOption
$crotate :: ExecOption -> Int -> ExecOption
rotate :: ExecOption -> Int -> ExecOption
$czeroBits :: ExecOption
zeroBits :: ExecOption
$cbit :: Int -> ExecOption
bit :: Int -> ExecOption
$csetBit :: ExecOption -> Int -> ExecOption
setBit :: ExecOption -> Int -> ExecOption
$cclearBit :: ExecOption -> Int -> ExecOption
clearBit :: ExecOption -> Int -> ExecOption
$ccomplementBit :: ExecOption -> Int -> ExecOption
complementBit :: ExecOption -> Int -> ExecOption
$ctestBit :: ExecOption -> Int -> Bool
testBit :: ExecOption -> Int -> Bool
$cbitSizeMaybe :: ExecOption -> Maybe Int
bitSizeMaybe :: ExecOption -> Maybe Int
$cbitSize :: ExecOption -> Int
bitSize :: ExecOption -> Int
$cisSigned :: ExecOption -> Bool
isSigned :: ExecOption -> Bool
$cshiftL :: ExecOption -> Int -> ExecOption
shiftL :: ExecOption -> Int -> ExecOption
$cunsafeShiftL :: ExecOption -> Int -> ExecOption
unsafeShiftL :: ExecOption -> Int -> ExecOption
$cshiftR :: ExecOption -> Int -> ExecOption
shiftR :: ExecOption -> Int -> ExecOption
$cunsafeShiftR :: ExecOption -> Int -> ExecOption
unsafeShiftR :: ExecOption -> Int -> ExecOption
$crotateL :: ExecOption -> Int -> ExecOption
rotateL :: ExecOption -> Int -> ExecOption
$crotateR :: ExecOption -> Int -> ExecOption
rotateR :: ExecOption -> Int -> ExecOption
$cpopCount :: ExecOption -> Int
popCount :: ExecOption -> Int
Bits)
newtype ReturnCode = ReturnCode CInt deriving (ReturnCode -> ReturnCode -> Bool
(ReturnCode -> ReturnCode -> Bool)
-> (ReturnCode -> ReturnCode -> Bool) -> Eq ReturnCode
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
$c== :: ReturnCode -> ReturnCode -> Bool
== :: ReturnCode -> ReturnCode -> Bool
$c/= :: ReturnCode -> ReturnCode -> Bool
/= :: ReturnCode -> ReturnCode -> Bool
Eq,Int -> ReturnCode -> ShowS
[ReturnCode] -> ShowS
ReturnCode -> String
(Int -> ReturnCode -> ShowS)
-> (ReturnCode -> String)
-> ([ReturnCode] -> ShowS)
-> Show ReturnCode
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
$cshowsPrec :: Int -> ReturnCode -> ShowS
showsPrec :: Int -> ReturnCode -> ShowS
$cshow :: ReturnCode -> String
show :: ReturnCode -> String
$cshowList :: [ReturnCode] -> ShowS
showList :: [ReturnCode] -> ShowS
Show)
data Regex = Regex (ForeignPtr CRegex) CompOption ExecOption
compBlank :: CompOption
compBlank :: CompOption
compBlank = CInt -> CompOption
CompOption CInt
0
execBlank :: ExecOption
execBlank :: ExecOption
execBlank = CInt -> ExecOption
ExecOption CInt
0
unusedRegOffset :: RegOffset
unusedRegOffset :: RegOffset
unusedRegOffset = (-RegOffset
1)
type WrapError = (ReturnCode,String)
wrapCompile :: CompOption
-> ExecOption
-> CString
-> IO (Either WrapError Regex)
wrapTest :: Regex -> CString
-> IO (Either WrapError Bool)
wrapMatch :: Regex -> CString
-> IO (Either WrapError (Maybe [(RegOffset,RegOffset)]))
wrapMatchAll :: Regex -> CString
-> IO (Either WrapError [MatchArray])
wrapCount :: Regex -> CString
-> IO (Either WrapError Int)
(=~) :: (RegexMaker Regex CompOption ExecOption source,RegexContext Regex source1 target)
=> source1 -> source -> target
(=~~) :: (RegexMaker Regex CompOption ExecOption source,RegexContext Regex source1 target,MonadFail m)
=> source1 -> source -> m target
instance RegexOptions Regex CompOption ExecOption where
blankCompOpt :: CompOption
blankCompOpt = CompOption
compBlank
blankExecOpt :: ExecOption
blankExecOpt = ExecOption
execBlank
defaultCompOpt :: CompOption
defaultCompOpt = CompOption
compExtended CompOption -> CompOption -> CompOption
forall a. Bits a => a -> a -> a
.|. CompOption
compNewline
defaultExecOpt :: ExecOption
defaultExecOpt = ExecOption
execBlank
setExecOpts :: ExecOption -> Regex -> Regex
setExecOpts ExecOption
e' (Regex ForeignPtr CRegex
r CompOption
c ExecOption
_) = ForeignPtr CRegex -> CompOption -> ExecOption -> Regex
Regex ForeignPtr CRegex
r CompOption
c ExecOption
e'
getExecOpts :: Regex -> ExecOption
getExecOpts (Regex ForeignPtr CRegex
_ CompOption
_ ExecOption
e) = ExecOption
e
=~ :: forall source source1 target.
(RegexMaker Regex CompOption ExecOption source,
RegexContext Regex source1 target) =>
source1 -> source -> target
(=~) source1
x source
r = let make :: RegexMaker Regex CompOption ExecOption a => a -> Regex
make :: forall a. RegexMaker Regex CompOption ExecOption a => a -> Regex
make = a -> Regex
forall regex compOpt execOpt source.
RegexMaker regex compOpt execOpt source =>
source -> regex
makeRegex
in Regex -> source1 -> target
forall regex source target.
RegexContext regex source target =>
regex -> source -> target
match (source -> Regex
forall a. RegexMaker Regex CompOption ExecOption a => a -> Regex
make source
r) source1
x
=~~ :: forall source source1 target (m :: * -> *).
(RegexMaker Regex CompOption ExecOption source,
RegexContext Regex source1 target, MonadFail m) =>
source1 -> source -> m target
(=~~) source1
x source
r = let make :: RegexMaker Regex CompOption ExecOption a => a -> Regex
make :: forall a. RegexMaker Regex CompOption ExecOption a => a -> Regex
make = a -> Regex
forall regex compOpt execOpt source.
RegexMaker regex compOpt execOpt source =>
source -> regex
makeRegex
in Regex -> source1 -> m target
forall regex source target (m :: * -> *).
(RegexContext regex source target, MonadFail m) =>
regex -> source -> m target
forall (m :: * -> *). MonadFail m => Regex -> source1 -> m target
matchM (source -> Regex
forall a. RegexMaker Regex CompOption ExecOption a => a -> Regex
make source
r) source1
x
type CRegMatch = ()
foreign import ccall unsafe "memset"
c_memset :: Ptr CRegex -> CInt -> CSize -> IO (Ptr CRegex)
foreign import ccall unsafe "&hs_regex_regfree"
c_myregfree :: FunPtr (Ptr CRegex -> IO ())
foreign import ccall unsafe "regex.h regcomp"
c_regcomp :: Ptr CRegex -> CString -> CompOption -> IO ReturnCode
foreign import ccall unsafe "regex.h regexec"
c_regexec :: Ptr CRegex -> CString -> CSize
-> Ptr CRegMatch -> ExecOption -> IO ReturnCode
foreign import ccall unsafe "regex.h regerror"
c_regerror :: ReturnCode -> Ptr CRegex
-> CString -> CSize -> IO CSize
retOk :: ReturnCode
retOk :: ReturnCode
retOk = CInt -> ReturnCode
ReturnCode CInt
0
execNotBOL :: ExecOption
execNotBOL :: ExecOption
execNotBOL = CInt -> ExecOption
ExecOption CInt
1
execNotEOL :: ExecOption
execNotEOL :: ExecOption
execNotEOL = CInt -> ExecOption
ExecOption CInt
2
{-# LINE 314 "src/Text/Regex/Posix/Wrap.hsc" #-}
compExtended :: CompOption
compExtended :: CompOption
compExtended = CInt -> CompOption
CompOption CInt
1
compIgnoreCase :: CompOption
compIgnoreCase :: CompOption
compIgnoreCase = CInt -> CompOption
CompOption CInt
2
compNoSub :: CompOption
compNoSub :: CompOption
compNoSub = CInt -> CompOption
CompOption CInt
8
compNewline :: CompOption
compNewline :: CompOption
compNewline = CInt -> CompOption
CompOption CInt
4
{-# LINE 321 "src/Text/Regex/Posix/Wrap.hsc" #-}
retNoMatch :: ReturnCode
retNoMatch :: ReturnCode
retNoMatch = CInt -> ReturnCode
ReturnCode CInt
1
retBadbr :: ReturnCode
retBadbr :: ReturnCode
retBadbr = CInt -> ReturnCode
ReturnCode CInt
10
retBadpat :: ReturnCode
retBadpat :: ReturnCode
retBadpat = CInt -> ReturnCode
ReturnCode CInt
2
retBadrpt :: ReturnCode
retBadrpt :: ReturnCode
retBadrpt = CInt -> ReturnCode
ReturnCode CInt
13
retEcollate :: ReturnCode
retEcollate :: ReturnCode
retEcollate = CInt -> ReturnCode
ReturnCode CInt
3
retEctype :: ReturnCode
retEctype :: ReturnCode
retEctype = CInt -> ReturnCode
ReturnCode CInt
4
retEescape :: ReturnCode
retEescape :: ReturnCode
retEescape = CInt -> ReturnCode
ReturnCode CInt
5
retEsubreg :: ReturnCode
retEsubreg :: ReturnCode
retEsubreg = CInt -> ReturnCode
ReturnCode CInt
6
retEbrack :: ReturnCode
retEbrack :: ReturnCode
retEbrack = CInt -> ReturnCode
ReturnCode CInt
7
retEparen :: ReturnCode
retEparen :: ReturnCode
retEparen = ReturnCode 8
retEbrace :: ReturnCode
retEbrace :: ReturnCode
retEbrace = CInt -> ReturnCode
ReturnCode CInt
9
retErange :: ReturnCode
retErange :: ReturnCode
retErange = CInt -> ReturnCode
ReturnCode CInt
11
retEspace :: ReturnCode
retEspace :: ReturnCode
isNewline :: Ptr CChar -> Int -> IO Bool
retEspace = CInt -> ReturnCode
ReturnCode CInt
12
{-# LINE 339 "src/Text/Regex/Posix/Wrap.hsc" #-}
nullTest :: Ptr a -> String -> IO (Either WrapError b) -> IO (Either WrapError b)
{-# INLINE nullTest #-}
nullTest ptr msg io = do
if nullPtr == ptr
then return (Left (retOk,"Ptr parameter was nullPtr in Text.Regex.TRE.Wrap."++msg))
else io
isNewline,isNull :: Ptr CChar -> Int -> IO Bool
isNewline cstr pos = liftM (newline ==) (peekElemOff cstr pos)
where newline = toEnum 10
isNull cstr pos = liftM (nullChar ==) (peekElemOff cstr pos)
where nullChar = toEnum 0
wrapError :: ReturnCode -> Ptr CRegex -> IO (Either WrapError b)
wrapError :: forall b. ReturnCode -> Ptr CRegex -> IO (Either WrapError b)
wrapError ReturnCode
errCode Ptr CRegex
regex_ptr = do
CSize
errBufSize <- ReturnCode -> Ptr CRegex -> Ptr CChar -> CSize -> IO CSize
c_regerror ReturnCode
errCode Ptr CRegex
regex_ptr Ptr CChar
forall a. Ptr a
nullPtr CSize
0
Int
-> (Ptr CChar -> IO (Either WrapError b))
-> IO (Either WrapError b)
forall a b. Storable a => Int -> (Ptr a -> IO b) -> IO b
allocaArray (CSize -> Int
forall a b. (Integral a, Num b) => a -> b
fromIntegral CSize
errBufSize) ((Ptr CChar -> IO (Either WrapError b)) -> IO (Either WrapError b))
-> (Ptr CChar -> IO (Either WrapError b))
-> IO (Either WrapError b)
forall a b. (a -> b) -> a -> b
$ \Ptr CChar
errBuf -> do
Ptr CChar
-> String -> IO (Either WrapError b) -> IO (Either WrapError b)
forall a b.
Ptr a
-> String -> IO (Either WrapError b) -> IO (Either WrapError b)
nullTest Ptr CChar
errBuf String
"wrapError errBuf" (IO (Either WrapError b) -> IO (Either WrapError b))
-> IO (Either WrapError b) -> IO (Either WrapError b)
forall a b. (a -> b) -> a -> b
$ do
CSize
_ <- ReturnCode -> Ptr CRegex -> Ptr CChar -> CSize -> IO CSize
c_regerror ReturnCode
errCode Ptr CRegex
regex_ptr Ptr CChar
errBuf CSize
errBufSize
String
msg <- Ptr CChar -> IO String
peekCAString Ptr CChar
errBuf :: IO String
Either WrapError b -> IO (Either WrapError b)
forall a. a -> IO a
forall (m :: * -> *) a. Monad m => a -> m a
return (WrapError -> Either WrapError b
forall a b. a -> Either a b
Left (ReturnCode
errCode, String
msg))
wrapCompile :: CompOption
-> ExecOption -> Ptr CChar -> IO (Either WrapError Regex)
wrapCompile CompOption
flags ExecOption
e Ptr CChar
pattern = do
Ptr CChar
-> String
-> IO (Either WrapError Regex)
-> IO (Either WrapError Regex)
forall a b.
Ptr a
-> String -> IO (Either WrapError b) -> IO (Either WrapError b)
nullTest Ptr CChar
pattern String
"wrapCompile pattern" (IO (Either WrapError Regex) -> IO (Either WrapError Regex))
-> IO (Either WrapError Regex) -> IO (Either WrapError Regex)
forall a b. (a -> b) -> a -> b
$ do
Either IOException (Ptr CRegex)
e_regex_ptr <- IO (Ptr CRegex) -> IO (Either IOException (Ptr CRegex))
forall a. IO a -> IO (Either IOException a)
try (IO (Ptr CRegex) -> IO (Either IOException (Ptr CRegex)))
-> IO (Ptr CRegex) -> IO (Either IOException (Ptr CRegex))
forall a b. (a -> b) -> a -> b
$ Int -> IO (Ptr CRegex)
forall a. Int -> IO (Ptr a)
mallocBytes (Int
64)
{-# LINE 375 "src/Text/Regex/Posix/Wrap.hsc" #-}
case e_regex_ptr of
Left ioerror -> return (Left (retOk,"Text.Regex.Posix.Wrap.wrapCompile: IOError from mallocBytes(regex_t) : "++show ioerror))
Right raw_regex_ptr -> do
zero_regex_ptr <- c_memset raw_regex_ptr 0 (64)
{-# LINE 379 "src/Text/Regex/Posix/Wrap.hsc" #-}
regex_fptr <- newForeignPtr c_myregfree zero_regex_ptr
withForeignPtr regex_fptr $ \regex_ptr -> do
errCode <- c_regcomp regex_ptr pattern flags
if (errCode == retOk)
then return . Right $ Regex regex_fptr flags e
else wrapError errCode regex_ptr
wrapTest :: Regex -> Ptr CChar -> IO (Either WrapError Bool)
wrapTest (Regex ForeignPtr CRegex
regex_fptr CompOption
_ ExecOption
flags) Ptr CChar
cstr = do
Ptr CChar
-> String
-> IO (Either WrapError Bool)
-> IO (Either WrapError Bool)
forall a b.
Ptr a
-> String -> IO (Either WrapError b) -> IO (Either WrapError b)
nullTest Ptr CChar
cstr String
"wrapTest" (IO (Either WrapError Bool) -> IO (Either WrapError Bool))
-> IO (Either WrapError Bool) -> IO (Either WrapError Bool)
forall a b. (a -> b) -> a -> b
$ do
ForeignPtr CRegex
-> (Ptr CRegex -> IO (Either WrapError Bool))
-> IO (Either WrapError Bool)
forall a b. ForeignPtr a -> (Ptr a -> IO b) -> IO b
withForeignPtr ForeignPtr CRegex
regex_fptr ((Ptr CRegex -> IO (Either WrapError Bool))
-> IO (Either WrapError Bool))
-> (Ptr CRegex -> IO (Either WrapError Bool))
-> IO (Either WrapError Bool)
forall a b. (a -> b) -> a -> b
$ \Ptr CRegex
regex_ptr -> do
ReturnCode
r <- Ptr CRegex
-> Ptr CChar
-> CSize
-> Ptr CRegMatch
-> ExecOption
-> IO ReturnCode
c_regexec Ptr CRegex
regex_ptr Ptr CChar
cstr CSize
0 Ptr CRegMatch
forall a. Ptr a
nullPtr ExecOption
flags
if ReturnCode
r ReturnCode -> ReturnCode -> Bool
forall a. Eq a => a -> a -> Bool
== ReturnCode
retOk
then Either WrapError Bool -> IO (Either WrapError Bool)
forall a. a -> IO a
forall (m :: * -> *) a. Monad m => a -> m a
return (Bool -> Either WrapError Bool
forall a b. b -> Either a b
Right Bool
True)
else if ReturnCode
r ReturnCode -> ReturnCode -> Bool
forall a. Eq a => a -> a -> Bool
== ReturnCode
retNoMatch
then Either WrapError Bool -> IO (Either WrapError Bool)
forall a. a -> IO a
forall (m :: * -> *) a. Monad m => a -> m a
return (Bool -> Either WrapError Bool
forall a b. b -> Either a b
Right Bool
False)
else ReturnCode -> Ptr CRegex -> IO (Either WrapError Bool)
forall b. ReturnCode -> Ptr CRegex -> IO (Either WrapError b)
wrapError ReturnCode
r Ptr CRegex
regex_ptr
wrapMatch :: Regex
-> Ptr CChar
-> IO (Either WrapError (Maybe [(RegOffset, RegOffset)]))
wrapMatch regex :: Regex
regex@(Regex ForeignPtr CRegex
regex_fptr CompOption
compileOptions ExecOption
flags) Ptr CChar
cstr = do
Ptr CChar
-> String
-> IO (Either WrapError (Maybe [(RegOffset, RegOffset)]))
-> IO (Either WrapError (Maybe [(RegOffset, RegOffset)]))
forall a b.
Ptr a
-> String -> IO (Either WrapError b) -> IO (Either WrapError b)
nullTest Ptr CChar
cstr String
"wrapMatch cstr" (IO (Either WrapError (Maybe [(RegOffset, RegOffset)]))
-> IO (Either WrapError (Maybe [(RegOffset, RegOffset)])))
-> IO (Either WrapError (Maybe [(RegOffset, RegOffset)]))
-> IO (Either WrapError (Maybe [(RegOffset, RegOffset)]))
forall a b. (a -> b) -> a -> b
$ do
if (CompOption
0 CompOption -> CompOption -> Bool
forall a. Eq a => a -> a -> Bool
/= CompOption
compNoSub CompOption -> CompOption -> CompOption
forall a. Bits a => a -> a -> a
.&. CompOption
compileOptions)
then do
Either WrapError Bool
r <- Regex -> Ptr CChar -> IO (Either WrapError Bool)
wrapTest Regex
regex Ptr CChar
cstr
case Either WrapError Bool
r of
Right Bool
True -> Either WrapError (Maybe [(RegOffset, RegOffset)])
-> IO (Either WrapError (Maybe [(RegOffset, RegOffset)]))
forall a. a -> IO a
forall (m :: * -> *) a. Monad m => a -> m a
return (Maybe [(RegOffset, RegOffset)]
-> Either WrapError (Maybe [(RegOffset, RegOffset)])
forall a b. b -> Either a b
Right ([(RegOffset, RegOffset)] -> Maybe [(RegOffset, RegOffset)]
forall a. a -> Maybe a
Just []))
Right Bool
False -> Either WrapError (Maybe [(RegOffset, RegOffset)])
-> IO (Either WrapError (Maybe [(RegOffset, RegOffset)]))
forall a. a -> IO a
forall (m :: * -> *) a. Monad m => a -> m a
return (Maybe [(RegOffset, RegOffset)]
-> Either WrapError (Maybe [(RegOffset, RegOffset)])
forall a b. b -> Either a b
Right Maybe [(RegOffset, RegOffset)]
forall a. Maybe a
Nothing)
Left WrapError
err -> Either WrapError (Maybe [(RegOffset, RegOffset)])
-> IO (Either WrapError (Maybe [(RegOffset, RegOffset)]))
forall a. a -> IO a
forall (m :: * -> *) a. Monad m => a -> m a
return (WrapError -> Either WrapError (Maybe [(RegOffset, RegOffset)])
forall a b. a -> Either a b
Left WrapError
err)
else do
ForeignPtr CRegex
-> (Ptr CRegex
-> IO (Either WrapError (Maybe [(RegOffset, RegOffset)])))
-> IO (Either WrapError (Maybe [(RegOffset, RegOffset)]))
forall a b. ForeignPtr a -> (Ptr a -> IO b) -> IO b
withForeignPtr ForeignPtr CRegex
regex_fptr ((Ptr CRegex
-> IO (Either WrapError (Maybe [(RegOffset, RegOffset)])))
-> IO (Either WrapError (Maybe [(RegOffset, RegOffset)])))
-> (Ptr CRegex
-> IO (Either WrapError (Maybe [(RegOffset, RegOffset)])))
-> IO (Either WrapError (Maybe [(RegOffset, RegOffset)]))
forall a b. (a -> b) -> a -> b
$ \Ptr CRegex
regex_ptr -> do
CSize
nsub <- ((\Ptr CRegex
hsc_ptr -> Ptr CRegex -> Int -> IO CSize
forall b. Ptr b -> Int -> IO CSize
forall a b. Storable a => Ptr b -> Int -> IO a
peekByteOff Ptr CRegex
hsc_ptr Int
48)) Ptr CRegex
regex_ptr :: IO CSize
{-# LINE 410 "src/Text/Regex/Posix/Wrap.hsc" #-}
let nsub_int,nsub_bytes :: Int
nsub_int :: Int
nsub_int = CSize -> Int
forall a b. (Integral a, Num b) => a -> b
fromIntegral CSize
nsub
nsub_bytes :: Int
nsub_bytes = ((Int
1 Int -> Int -> Int
forall a. Num a => a -> a -> a
+ Int
nsub_int) Int -> Int -> Int
forall a. Num a => a -> a -> a
* (Int
8))
{-# LINE 413 "src/Text/Regex/Posix/Wrap.hsc" #-}
Int
-> (Ptr CRegMatch
-> IO (Either WrapError (Maybe [(RegOffset, RegOffset)])))
-> IO (Either WrapError (Maybe [(RegOffset, RegOffset)]))
forall a b. Int -> (Ptr a -> IO b) -> IO b
allocaBytes Int
nsub_bytes ((Ptr CRegMatch
-> IO (Either WrapError (Maybe [(RegOffset, RegOffset)])))
-> IO (Either WrapError (Maybe [(RegOffset, RegOffset)])))
-> (Ptr CRegMatch
-> IO (Either WrapError (Maybe [(RegOffset, RegOffset)])))
-> IO (Either WrapError (Maybe [(RegOffset, RegOffset)]))
forall a b. (a -> b) -> a -> b
$ \Ptr CRegMatch
p_match -> do
Ptr CRegMatch
-> String
-> IO (Either WrapError (Maybe [(RegOffset, RegOffset)]))
-> IO (Either WrapError (Maybe [(RegOffset, RegOffset)]))
forall a b.
Ptr a
-> String -> IO (Either WrapError b) -> IO (Either WrapError b)
nullTest Ptr CRegMatch
p_match String
"wrapMatch allocaBytes" (IO (Either WrapError (Maybe [(RegOffset, RegOffset)]))
-> IO (Either WrapError (Maybe [(RegOffset, RegOffset)])))
-> IO (Either WrapError (Maybe [(RegOffset, RegOffset)]))
-> IO (Either WrapError (Maybe [(RegOffset, RegOffset)]))
forall a b. (a -> b) -> a -> b
$ do
Ptr CRegex
-> Ptr CChar
-> CSize
-> Ptr CRegMatch
-> ExecOption
-> IO (Either WrapError (Maybe [(RegOffset, RegOffset)]))
doMatch Ptr CRegex
regex_ptr Ptr CChar
cstr CSize
nsub Ptr CRegMatch
p_match ExecOption
flags
doMatch :: Ptr CRegex -> CString -> CSize -> Ptr CRegMatch -> ExecOption
-> IO (Either WrapError (Maybe [(RegOffset,RegOffset)]))
{-# INLINE doMatch #-}
doMatch :: Ptr CRegex
-> Ptr CChar
-> CSize
-> Ptr CRegMatch
-> ExecOption
-> IO (Either WrapError (Maybe [(RegOffset, RegOffset)]))
doMatch Ptr CRegex
regex_ptr Ptr CChar
cstr CSize
nsub Ptr CRegMatch
p_match ExecOption
flags = do
ReturnCode
r <- Ptr CRegex
-> Ptr CChar
-> CSize
-> Ptr CRegMatch
-> ExecOption
-> IO ReturnCode
c_regexec Ptr CRegex
regex_ptr Ptr CChar
cstr (CSize
1 CSize -> CSize -> CSize
forall a. Num a => a -> a -> a
+ CSize
nsub) Ptr CRegMatch
p_match ExecOption
flags
if ReturnCode
r ReturnCode -> ReturnCode -> Bool
forall a. Eq a => a -> a -> Bool
== ReturnCode
retOk
then do
[(RegOffset, RegOffset)]
regions <- (Ptr CRegMatch -> IO (RegOffset, RegOffset))
-> [Ptr CRegMatch] -> IO [(RegOffset, RegOffset)]
forall (t :: * -> *) (m :: * -> *) a b.
(Traversable t, Monad m) =>
(a -> m b) -> t a -> m (t b)
forall (m :: * -> *) a b. Monad m => (a -> m b) -> [a] -> m [b]
mapM Ptr CRegMatch -> IO (RegOffset, RegOffset)
getOffsets ([Ptr CRegMatch] -> IO [(RegOffset, RegOffset)])
-> (Ptr CRegMatch -> [Ptr CRegMatch])
-> Ptr CRegMatch
-> IO [(RegOffset, RegOffset)]
forall b c a. (b -> c) -> (a -> b) -> a -> c
. Int -> [Ptr CRegMatch] -> [Ptr CRegMatch]
forall a. Int -> [a] -> [a]
take (Int
1Int -> Int -> Int
forall a. Num a => a -> a -> a
+CSize -> Int
forall a b. (Integral a, Num b) => a -> b
fromIntegral CSize
nsub)
([Ptr CRegMatch] -> [Ptr CRegMatch])
-> (Ptr CRegMatch -> [Ptr CRegMatch])
-> Ptr CRegMatch
-> [Ptr CRegMatch]
forall b c a. (b -> c) -> (a -> b) -> a -> c
. (Ptr CRegMatch -> Ptr CRegMatch)
-> Ptr CRegMatch -> [Ptr CRegMatch]
forall a. (a -> a) -> a -> [a]
iterate (Ptr CRegMatch -> Int -> Ptr CRegMatch
forall a b. Ptr a -> Int -> Ptr b
`plusPtr` (Int
8)) (Ptr CRegMatch -> IO [(RegOffset, RegOffset)])
-> Ptr CRegMatch -> IO [(RegOffset, RegOffset)]
forall a b. (a -> b) -> a -> b
$ Ptr CRegMatch
p_match
{-# LINE 430 "src/Text/Regex/Posix/Wrap.hsc" #-}
return (Right (Just regions))
else if ReturnCode
r ReturnCode -> ReturnCode -> Bool
forall a. Eq a => a -> a -> Bool
== ReturnCode
retNoMatch
then Either WrapError (Maybe [(RegOffset, RegOffset)])
-> IO (Either WrapError (Maybe [(RegOffset, RegOffset)]))
forall a. a -> IO a
forall (m :: * -> *) a. Monad m => a -> m a
return (Maybe [(RegOffset, RegOffset)]
-> Either WrapError (Maybe [(RegOffset, RegOffset)])
forall a b. b -> Either a b
Right Maybe [(RegOffset, RegOffset)]
forall a. Maybe a
Nothing)
else ReturnCode
-> Ptr CRegex
-> IO (Either WrapError (Maybe [(RegOffset, RegOffset)]))
forall b. ReturnCode -> Ptr CRegex -> IO (Either WrapError b)
wrapError ReturnCode
r Ptr CRegex
regex_ptr
where
getOffsets :: Ptr CRegMatch -> IO (RegOffset,RegOffset)
{-# INLINE getOffsets #-}
getOffsets :: Ptr CRegMatch -> IO (RegOffset, RegOffset)
getOffsets Ptr CRegMatch
pmatch' = do
Int32
start <- ((\Ptr CRegMatch
hsc_ptr -> Ptr CRegMatch -> Int -> IO Int32
forall b. Ptr b -> Int -> IO Int32
forall a b. Storable a => Ptr b -> Int -> IO a
peekByteOff Ptr CRegMatch
hsc_ptr Int
0)) Ptr CRegMatch
pmatch' :: IO (Int32)
{-# LINE 439 "src/Text/Regex/Posix/Wrap.hsc" #-}
end <- ((\hsc_ptr -> peekByteOff hsc_ptr 4)) pmatch' :: IO (Int32)
{-# LINE 440 "src/Text/Regex/Posix/Wrap.hsc" #-}
return (fromIntegral start,fromIntegral end)
wrapMatchAll :: Regex -> Ptr CChar -> IO (Either WrapError [MatchArray])
wrapMatchAll regex :: Regex
regex@(Regex ForeignPtr CRegex
regex_fptr CompOption
compileOptions ExecOption
flags) Ptr CChar
cstr = do
Ptr CChar
-> String
-> IO (Either WrapError [MatchArray])
-> IO (Either WrapError [MatchArray])
forall a b.
Ptr a
-> String -> IO (Either WrapError b) -> IO (Either WrapError b)
nullTest Ptr CChar
cstr String
"wrapMatchAll cstr" (IO (Either WrapError [MatchArray])
-> IO (Either WrapError [MatchArray]))
-> IO (Either WrapError [MatchArray])
-> IO (Either WrapError [MatchArray])
forall a b. (a -> b) -> a -> b
$ do
if (CompOption
0 CompOption -> CompOption -> Bool
forall a. Eq a => a -> a -> Bool
/= CompOption
compNoSub CompOption -> CompOption -> CompOption
forall a. Bits a => a -> a -> a
.&. CompOption
compileOptions)
then do
Either WrapError Bool
r <- Regex -> Ptr CChar -> IO (Either WrapError Bool)
wrapTest Regex
regex Ptr CChar
cstr
case Either WrapError Bool
r of
Right Bool
True -> Either WrapError [MatchArray] -> IO (Either WrapError [MatchArray])
forall a. a -> IO a
forall (m :: * -> *) a. Monad m => a -> m a
return ([MatchArray] -> Either WrapError [MatchArray]
forall a b. b -> Either a b
Right [(Int -> [(RegOffset, RegOffset)] -> MatchArray
toMA Int
0 [])])
Right Bool
False -> Either WrapError [MatchArray] -> IO (Either WrapError [MatchArray])
forall a. a -> IO a
forall (m :: * -> *) a. Monad m => a -> m a
return ([MatchArray] -> Either WrapError [MatchArray]
forall a b. b -> Either a b
Right [])
Left WrapError
err -> Either WrapError [MatchArray] -> IO (Either WrapError [MatchArray])
forall a. a -> IO a
forall (m :: * -> *) a. Monad m => a -> m a
return (WrapError -> Either WrapError [MatchArray]
forall a b. a -> Either a b
Left WrapError
err)
else do
ForeignPtr CRegex
-> (Ptr CRegex -> IO (Either WrapError [MatchArray]))
-> IO (Either WrapError [MatchArray])
forall a b. ForeignPtr a -> (Ptr a -> IO b) -> IO b
withForeignPtr ForeignPtr CRegex
regex_fptr ((Ptr CRegex -> IO (Either WrapError [MatchArray]))
-> IO (Either WrapError [MatchArray]))
-> (Ptr CRegex -> IO (Either WrapError [MatchArray]))
-> IO (Either WrapError [MatchArray])
forall a b. (a -> b) -> a -> b
$ \Ptr CRegex
regex_ptr -> do
CSize
nsub <- ((\Ptr CRegex
hsc_ptr -> Ptr CRegex -> Int -> IO CSize
forall b. Ptr b -> Int -> IO CSize
forall a b. Storable a => Ptr b -> Int -> IO a
peekByteOff Ptr CRegex
hsc_ptr Int
48)) Ptr CRegex
regex_ptr :: IO CSize
{-# LINE 454 "src/Text/Regex/Posix/Wrap.hsc" #-}
let nsub_int,nsub_bytes :: Int
nsub_int :: Int
nsub_int = CSize -> Int
forall a b. (Integral a, Num b) => a -> b
fromIntegral CSize
nsub
nsub_bytes :: Int
nsub_bytes = ((Int
1 Int -> Int -> Int
forall a. Num a => a -> a -> a
+ Int
nsub_int) Int -> Int -> Int
forall a. Num a => a -> a -> a
* (Int
8))
{-# LINE 457 "src/Text/Regex/Posix/Wrap.hsc" #-}
Int
-> (Ptr CRegMatch -> IO (Either WrapError [MatchArray]))
-> IO (Either WrapError [MatchArray])
forall a b. Int -> (Ptr a -> IO b) -> IO b
allocaBytes Int
nsub_bytes ((Ptr CRegMatch -> IO (Either WrapError [MatchArray]))
-> IO (Either WrapError [MatchArray]))
-> (Ptr CRegMatch -> IO (Either WrapError [MatchArray]))
-> IO (Either WrapError [MatchArray])
forall a b. (a -> b) -> a -> b
$ \Ptr CRegMatch
p_match -> do
Ptr CRegMatch
-> String
-> IO (Either WrapError [MatchArray])
-> IO (Either WrapError [MatchArray])
forall a b.
Ptr a
-> String -> IO (Either WrapError b) -> IO (Either WrapError b)
nullTest Ptr CRegMatch
p_match String
"wrapMatchAll p_match" (IO (Either WrapError [MatchArray])
-> IO (Either WrapError [MatchArray]))
-> IO (Either WrapError [MatchArray])
-> IO (Either WrapError [MatchArray])
forall a b. (a -> b) -> a -> b
$ do
let flagsBOL :: ExecOption
flagsBOL = (ExecOption -> ExecOption
forall a. Bits a => a -> a
complement ExecOption
execNotBOL) ExecOption -> ExecOption -> ExecOption
forall a. Bits a => a -> a -> a
.&. ExecOption
flags
flagsMIDDLE :: ExecOption
flagsMIDDLE = ExecOption
execNotBOL ExecOption -> ExecOption -> ExecOption
forall a. Bits a => a -> a -> a
.|. ExecOption
flags
atBOL :: Int -> IO (Either WrapError (Maybe [(RegOffset, RegOffset)]))
atBOL Int
pos = Ptr CRegex
-> Ptr CChar
-> CSize
-> Ptr CRegMatch
-> ExecOption
-> IO (Either WrapError (Maybe [(RegOffset, RegOffset)]))
doMatch Ptr CRegex
regex_ptr (Ptr CChar -> Int -> Ptr CChar
forall a b. Ptr a -> Int -> Ptr b
plusPtr Ptr CChar
cstr Int
pos) CSize
nsub Ptr CRegMatch
p_match ExecOption
flagsBOL
atMIDDLE :: Int -> IO (Either WrapError (Maybe [(RegOffset, RegOffset)]))
atMIDDLE Int
pos = Ptr CRegex
-> Ptr CChar
-> CSize
-> Ptr CRegMatch
-> ExecOption
-> IO (Either WrapError (Maybe [(RegOffset, RegOffset)]))
doMatch Ptr CRegex
regex_ptr (Ptr CChar -> Int -> Ptr CChar
forall a b. Ptr a -> Int -> Ptr b
plusPtr Ptr CChar
cstr Int
pos) CSize
nsub Ptr CRegMatch
p_match ExecOption
flagsMIDDLE
loop :: ([MatchArray] -> b)
-> Int -> (RegOffset, RegOffset) -> IO (Either WrapError b)
loop [MatchArray] -> b
acc Int
old (RegOffset
s,RegOffset
e) | [MatchArray] -> b
acc ([MatchArray] -> b) -> Bool -> Bool
forall a b. a -> b -> b
`seq` Int
old Int -> Bool -> Bool
forall a b. a -> b -> b
`seq` Bool
False = IO (Either WrapError b)
forall a. HasCallStack => a
undefined
| RegOffset
s RegOffset -> RegOffset -> Bool
forall a. Eq a => a -> a -> Bool
== RegOffset
e = do
let pos :: Int
pos = Int
old Int -> Int -> Int
forall a. Num a => a -> a -> a
+ RegOffset -> Int
forall a b. (Integral a, Num b) => a -> b
fromIntegral RegOffset
e
Bool
atEnd <- Ptr CChar -> Int -> IO Bool
isNull Ptr CChar
cstr Int
pos
if Bool
atEnd then Either WrapError b -> IO (Either WrapError b)
forall a. a -> IO a
forall (m :: * -> *) a. Monad m => a -> m a
return (b -> Either WrapError b
forall a b. b -> Either a b
Right ([MatchArray] -> b
acc []))
else ([MatchArray] -> b)
-> Int -> (RegOffset, RegOffset) -> IO (Either WrapError b)
loop [MatchArray] -> b
acc Int
old (RegOffset
s,RegOffset -> RegOffset
forall a. Enum a => a -> a
succ RegOffset
e)
| Bool
otherwise = do
let pos :: Int
pos = Int
old Int -> Int -> Int
forall a. Num a => a -> a -> a
+ RegOffset -> Int
forall a b. (Integral a, Num b) => a -> b
fromIntegral RegOffset
e
Bool
prev'newline <- Ptr CChar -> Int -> IO Bool
isNewline Ptr CChar
cstr (Int -> Int
forall a. Enum a => a -> a
pred Int
pos)
Either WrapError (Maybe [(RegOffset, RegOffset)])
result <- if Bool
prev'newline then Int -> IO (Either WrapError (Maybe [(RegOffset, RegOffset)]))
atBOL Int
pos else Int -> IO (Either WrapError (Maybe [(RegOffset, RegOffset)]))
atMIDDLE Int
pos
case Either WrapError (Maybe [(RegOffset, RegOffset)])
result of
Right Maybe [(RegOffset, RegOffset)]
Nothing -> Either WrapError b -> IO (Either WrapError b)
forall a. a -> IO a
forall (m :: * -> *) a. Monad m => a -> m a
return (b -> Either WrapError b
forall a b. b -> Either a b
Right ([MatchArray] -> b
acc []))
Right (Just parts :: [(RegOffset, RegOffset)]
parts@((RegOffset, RegOffset)
whole:[(RegOffset, RegOffset)]
_)) -> let ma :: MatchArray
ma = Int -> [(RegOffset, RegOffset)] -> MatchArray
toMA Int
pos [(RegOffset, RegOffset)]
parts
in ([MatchArray] -> b)
-> Int -> (RegOffset, RegOffset) -> IO (Either WrapError b)
loop ([MatchArray] -> b
acc([MatchArray] -> b)
-> ([MatchArray] -> [MatchArray]) -> [MatchArray] -> b
forall b c a. (b -> c) -> (a -> b) -> a -> c
.(MatchArray
maMatchArray -> [MatchArray] -> [MatchArray]
forall a. a -> [a] -> [a]
:)) Int
pos (RegOffset, RegOffset)
whole
Left WrapError
err -> Either WrapError b -> IO (Either WrapError b)
forall a. a -> IO a
forall (m :: * -> *) a. Monad m => a -> m a
return (WrapError -> Either WrapError b
forall a b. a -> Either a b
Left WrapError
err)
Right (Just []) -> Either WrapError b -> IO (Either WrapError b)
forall a. a -> IO a
forall (m :: * -> *) a. Monad m => a -> m a
return (b -> Either WrapError b
forall a b. b -> Either a b
Right ([MatchArray] -> b
acc [(Int -> [(RegOffset, RegOffset)] -> MatchArray
toMA Int
pos [])]))
Either WrapError (Maybe [(RegOffset, RegOffset)])
result <- Ptr CRegex
-> Ptr CChar
-> CSize
-> Ptr CRegMatch
-> ExecOption
-> IO (Either WrapError (Maybe [(RegOffset, RegOffset)]))
doMatch Ptr CRegex
regex_ptr Ptr CChar
cstr CSize
nsub Ptr CRegMatch
p_match ExecOption
flags
case Either WrapError (Maybe [(RegOffset, RegOffset)])
result of
Right Maybe [(RegOffset, RegOffset)]
Nothing -> Either WrapError [MatchArray] -> IO (Either WrapError [MatchArray])
forall a. a -> IO a
forall (m :: * -> *) a. Monad m => a -> m a
return ([MatchArray] -> Either WrapError [MatchArray]
forall a b. b -> Either a b
Right [])
Right (Just parts :: [(RegOffset, RegOffset)]
parts@((RegOffset, RegOffset)
whole:[(RegOffset, RegOffset)]
_)) -> let ma :: MatchArray
ma = Int -> [(RegOffset, RegOffset)] -> MatchArray
toMA Int
0 [(RegOffset, RegOffset)]
parts
in ([MatchArray] -> [MatchArray])
-> Int
-> (RegOffset, RegOffset)
-> IO (Either WrapError [MatchArray])
forall {b}.
([MatchArray] -> b)
-> Int -> (RegOffset, RegOffset) -> IO (Either WrapError b)
loop (MatchArray
maMatchArray -> [MatchArray] -> [MatchArray]
forall a. a -> [a] -> [a]
:) Int
0 (RegOffset, RegOffset)
whole
Left WrapError
err -> Either WrapError [MatchArray] -> IO (Either WrapError [MatchArray])
forall a. a -> IO a
forall (m :: * -> *) a. Monad m => a -> m a
return (WrapError -> Either WrapError [MatchArray]
forall a b. a -> Either a b
Left WrapError
err)
Right (Just []) -> Either WrapError [MatchArray] -> IO (Either WrapError [MatchArray])
forall a. a -> IO a
forall (m :: * -> *) a. Monad m => a -> m a
return ([MatchArray] -> Either WrapError [MatchArray]
forall a b. b -> Either a b
Right [(Int -> [(RegOffset, RegOffset)] -> MatchArray
toMA Int
0 [])])
where
toMA :: Int -> [(RegOffset,RegOffset)] -> Array Int (Int,Int)
toMA :: Int -> [(RegOffset, RegOffset)] -> MatchArray
toMA Int
pos [] = (Int, Int) -> [(Int, Int)] -> MatchArray
forall i e. Ix i => (i, i) -> [e] -> Array i e
listArray (Int
0,Int
0) [(Int
pos,Int
0)]
toMA Int
pos [(RegOffset, RegOffset)]
parts = (Int, Int) -> [(Int, Int)] -> MatchArray
forall i e. Ix i => (i, i) -> [e] -> Array i e
listArray (Int
0,Int -> Int
forall a. Enum a => a -> a
pred ([(RegOffset, RegOffset)] -> Int
forall a. [a] -> Int
forall (t :: * -> *) a. Foldable t => t a -> Int
length [(RegOffset, RegOffset)]
parts))
([(Int, Int)] -> MatchArray)
-> ([(RegOffset, RegOffset)] -> [(Int, Int)])
-> [(RegOffset, RegOffset)]
-> MatchArray
forall b c a. (b -> c) -> (a -> b) -> a -> c
. ((RegOffset, RegOffset) -> (Int, Int))
-> [(RegOffset, RegOffset)] -> [(Int, Int)]
forall a b. (a -> b) -> [a] -> [b]
map (\(RegOffset
s,RegOffset
e)-> if RegOffset
sRegOffset -> RegOffset -> Bool
forall a. Ord a => a -> a -> Bool
>=RegOffset
0 then (Int
posInt -> Int -> Int
forall a. Num a => a -> a -> a
+RegOffset -> Int
forall a b. (Integral a, Num b) => a -> b
fromIntegral RegOffset
s, RegOffset -> Int
forall a b. (Integral a, Num b) => a -> b
fromIntegral (RegOffset
eRegOffset -> RegOffset -> RegOffset
forall a. Num a => a -> a -> a
-RegOffset
s)) else (-Int
1,Int
0))
([(RegOffset, RegOffset)] -> MatchArray)
-> [(RegOffset, RegOffset)] -> MatchArray
forall a b. (a -> b) -> a -> b
$ [(RegOffset, RegOffset)]
parts
wrapCount :: Regex -> Ptr CChar -> IO (Either WrapError Int)
wrapCount regex :: Regex
regex@(Regex ForeignPtr CRegex
regex_fptr CompOption
compileOptions ExecOption
flags) Ptr CChar
cstr = do
Ptr CChar
-> String -> IO (Either WrapError Int) -> IO (Either WrapError Int)
forall a b.
Ptr a
-> String -> IO (Either WrapError b) -> IO (Either WrapError b)
nullTest Ptr CChar
cstr String
"wrapCount cstr" (IO (Either WrapError Int) -> IO (Either WrapError Int))
-> IO (Either WrapError Int) -> IO (Either WrapError Int)
forall a b. (a -> b) -> a -> b
$ do
if (CompOption
0 CompOption -> CompOption -> Bool
forall a. Eq a => a -> a -> Bool
/= CompOption
compNoSub CompOption -> CompOption -> CompOption
forall a. Bits a => a -> a -> a
.&. CompOption
compileOptions)
then do
Either WrapError Bool
r <- Regex -> Ptr CChar -> IO (Either WrapError Bool)
wrapTest Regex
regex Ptr CChar
cstr
case Either WrapError Bool
r of
Right Bool
True -> Either WrapError Int -> IO (Either WrapError Int)
forall a. a -> IO a
forall (m :: * -> *) a. Monad m => a -> m a
return (Int -> Either WrapError Int
forall a b. b -> Either a b
Right Int
1)
Right Bool
False -> Either WrapError Int -> IO (Either WrapError Int)
forall a. a -> IO a
forall (m :: * -> *) a. Monad m => a -> m a
return (Int -> Either WrapError Int
forall a b. b -> Either a b
Right Int
0)
Left WrapError
err -> Either WrapError Int -> IO (Either WrapError Int)
forall a. a -> IO a
forall (m :: * -> *) a. Monad m => a -> m a
return (WrapError -> Either WrapError Int
forall a b. a -> Either a b
Left WrapError
err)
else do
ForeignPtr CRegex
-> (Ptr CRegex -> IO (Either WrapError Int))
-> IO (Either WrapError Int)
forall a b. ForeignPtr a -> (Ptr a -> IO b) -> IO b
withForeignPtr ForeignPtr CRegex
regex_fptr ((Ptr CRegex -> IO (Either WrapError Int))
-> IO (Either WrapError Int))
-> (Ptr CRegex -> IO (Either WrapError Int))
-> IO (Either WrapError Int)
forall a b. (a -> b) -> a -> b
$ \Ptr CRegex
regex_ptr -> do
let nsub_bytes :: Int
nsub_bytes = ((Int
8))
{-# LINE 507 "src/Text/Regex/Posix/Wrap.hsc" #-}
Int
-> (Ptr CRegMatch -> IO (Either WrapError Int))
-> IO (Either WrapError Int)
forall a b. Int -> (Ptr a -> IO b) -> IO b
allocaBytes Int
nsub_bytes ((Ptr CRegMatch -> IO (Either WrapError Int))
-> IO (Either WrapError Int))
-> (Ptr CRegMatch -> IO (Either WrapError Int))
-> IO (Either WrapError Int)
forall a b. (a -> b) -> a -> b
$ \Ptr CRegMatch
p_match -> do
Ptr CRegMatch
-> String -> IO (Either WrapError Int) -> IO (Either WrapError Int)
forall a b.
Ptr a
-> String -> IO (Either WrapError b) -> IO (Either WrapError b)
nullTest Ptr CRegMatch
p_match String
"wrapCount p_match" (IO (Either WrapError Int) -> IO (Either WrapError Int))
-> IO (Either WrapError Int) -> IO (Either WrapError Int)
forall a b. (a -> b) -> a -> b
$ do
let flagsBOL :: ExecOption
flagsBOL = (ExecOption -> ExecOption
forall a. Bits a => a -> a
complement ExecOption
execNotBOL) ExecOption -> ExecOption -> ExecOption
forall a. Bits a => a -> a -> a
.&. ExecOption
flags
flagsMIDDLE :: ExecOption
flagsMIDDLE = ExecOption
execNotBOL ExecOption -> ExecOption -> ExecOption
forall a. Bits a => a -> a -> a
.|. ExecOption
flags
atBOL :: Int -> IO (Either WrapError (Maybe [(RegOffset, RegOffset)]))
atBOL Int
pos = Ptr CRegex
-> Ptr CChar
-> CSize
-> Ptr CRegMatch
-> ExecOption
-> IO (Either WrapError (Maybe [(RegOffset, RegOffset)]))
doMatch Ptr CRegex
regex_ptr (Ptr CChar -> Int -> Ptr CChar
forall a b. Ptr a -> Int -> Ptr b
plusPtr Ptr CChar
cstr Int
pos) CSize
0 Ptr CRegMatch
p_match ExecOption
flagsBOL
atMIDDLE :: Int -> IO (Either WrapError (Maybe [(RegOffset, RegOffset)]))
atMIDDLE Int
pos = Ptr CRegex
-> Ptr CChar
-> CSize
-> Ptr CRegMatch
-> ExecOption
-> IO (Either WrapError (Maybe [(RegOffset, RegOffset)]))
doMatch Ptr CRegex
regex_ptr (Ptr CChar -> Int -> Ptr CChar
forall a b. Ptr a -> Int -> Ptr b
plusPtr Ptr CChar
cstr Int
pos) CSize
0 Ptr CRegMatch
p_match ExecOption
flagsMIDDLE
loop :: t -> Int -> (RegOffset, RegOffset) -> IO (Either WrapError t)
loop t
acc Int
old (RegOffset
s,RegOffset
e) | t
acc t -> Bool -> Bool
forall a b. a -> b -> b
`seq` Int
old Int -> Bool -> Bool
forall a b. a -> b -> b
`seq` Bool
False = IO (Either WrapError t)
forall a. HasCallStack => a
undefined
| RegOffset
s RegOffset -> RegOffset -> Bool
forall a. Eq a => a -> a -> Bool
== RegOffset
e = do
let pos :: Int
pos = Int
old Int -> Int -> Int
forall a. Num a => a -> a -> a
+ RegOffset -> Int
forall a b. (Integral a, Num b) => a -> b
fromIntegral RegOffset
e
Bool
atEnd <- Ptr CChar -> Int -> IO Bool
isNull Ptr CChar
cstr Int
pos
if Bool
atEnd then Either WrapError t -> IO (Either WrapError t)
forall a. a -> IO a
forall (m :: * -> *) a. Monad m => a -> m a
return (t -> Either WrapError t
forall a b. b -> Either a b
Right t
acc)
else t -> Int -> (RegOffset, RegOffset) -> IO (Either WrapError t)
loop t
acc Int
old (RegOffset
s,RegOffset -> RegOffset
forall a. Enum a => a -> a
succ RegOffset
e)
| Bool
otherwise = do
let pos :: Int
pos = Int
old Int -> Int -> Int
forall a. Num a => a -> a -> a
+ RegOffset -> Int
forall a b. (Integral a, Num b) => a -> b
fromIntegral RegOffset
e
Bool
prev'newline <- Ptr CChar -> Int -> IO Bool
isNewline Ptr CChar
cstr (Int -> Int
forall a. Enum a => a -> a
pred Int
pos)
Either WrapError (Maybe [(RegOffset, RegOffset)])
result <- if Bool
prev'newline then Int -> IO (Either WrapError (Maybe [(RegOffset, RegOffset)]))
atBOL Int
pos else Int -> IO (Either WrapError (Maybe [(RegOffset, RegOffset)]))
atMIDDLE Int
pos
case Either WrapError (Maybe [(RegOffset, RegOffset)])
result of
Right Maybe [(RegOffset, RegOffset)]
Nothing -> Either WrapError t -> IO (Either WrapError t)
forall a. a -> IO a
forall (m :: * -> *) a. Monad m => a -> m a
return (t -> Either WrapError t
forall a b. b -> Either a b
Right t
acc)
Right (Just ((RegOffset, RegOffset)
whole:[(RegOffset, RegOffset)]
_)) -> t -> Int -> (RegOffset, RegOffset) -> IO (Either WrapError t)
loop (t -> t
forall a. Enum a => a -> a
succ t
acc) Int
pos (RegOffset, RegOffset)
whole
Left WrapError
err -> Either WrapError t -> IO (Either WrapError t)
forall a. a -> IO a
forall (m :: * -> *) a. Monad m => a -> m a
return (WrapError -> Either WrapError t
forall a b. a -> Either a b
Left WrapError
err)
Right (Just []) -> Either WrapError t -> IO (Either WrapError t)
forall a. a -> IO a
forall (m :: * -> *) a. Monad m => a -> m a
return (t -> Either WrapError t
forall a b. b -> Either a b
Right t
acc)
Either WrapError (Maybe [(RegOffset, RegOffset)])
result <- Ptr CRegex
-> Ptr CChar
-> CSize
-> Ptr CRegMatch
-> ExecOption
-> IO (Either WrapError (Maybe [(RegOffset, RegOffset)]))
doMatch Ptr CRegex
regex_ptr Ptr CChar
cstr CSize
0 Ptr CRegMatch
p_match ExecOption
flags
case Either WrapError (Maybe [(RegOffset, RegOffset)])
result of
Right Maybe [(RegOffset, RegOffset)]
Nothing -> Either WrapError Int -> IO (Either WrapError Int)
forall a. a -> IO a
forall (m :: * -> *) a. Monad m => a -> m a
return (Int -> Either WrapError Int
forall a b. b -> Either a b
Right Int
0)
Right (Just ((RegOffset, RegOffset)
whole:[(RegOffset, RegOffset)]
_)) -> Int -> Int -> (RegOffset, RegOffset) -> IO (Either WrapError Int)
forall {t}.
Enum t =>
t -> Int -> (RegOffset, RegOffset) -> IO (Either WrapError t)
loop Int
1 Int
0 (RegOffset, RegOffset)
whole
Left WrapError
err -> Either WrapError Int -> IO (Either WrapError Int)
forall a. a -> IO a
forall (m :: * -> *) a. Monad m => a -> m a
return (WrapError -> Either WrapError Int
forall a b. a -> Either a b
Left WrapError
err)
Right (Just []) -> Either WrapError Int -> IO (Either WrapError Int)
forall a. a -> IO a
forall (m :: * -> *) a. Monad m => a -> m a
return (Int -> Either WrapError Int
forall a b. b -> Either a b
Right Int
0)