module Bio.PDB.EventParser.ParseFORMUL(parseFORMUL)
where
import Prelude hiding(String)
import qualified Data.ByteString.Char8 as BS
import Bio.PDB.EventParser.PDBEvents
import Bio.PDB.EventParser.PDBParsingAbstractions
formulFields = [(6, mKeyword "record header" "FORMUL"),
(8, mSpc 2 ),
(10, mInt "component number" ),
(12, mSpc 2 ),
(15, mStr "hetero group identifier" ),
(16, mSpc 1 ),
(18, dInt "continuation" 0 ),
(19, mChr "asterisk for water" ),
(70, mStr "chemical formula" )]
parseFORMUL :: (Monad m) => String -> Int -> m [PDBEvent]
parseFORMUL line line_no = return $ if errs == []
then [result]
else errs
where
errs = fErrs ++ watErr
(fields, fErrs) = parseFields formulFields line line_no
[fRec, _, fCompNum, _, fHetId, _, fCont, fAsterisk, fFormula] = fields
IFInt compNum = fCompNum
IFStr hetId = fHetId
IFInt cont = fCont
IFChar asterisk = fAsterisk
IFStr formula = fFormula
watErr = if asterisk `elem` " *"
then []
else [PDBParseError line_no 19 $
BS.concat ["Expecting asterisk for water or space, but found: '",
BS.pack [asterisk], "'."]]
isWater = asterisk == '*'
result = FORMUL compNum hetId cont isWater [formula]