module Bio.PDB.EventParser.ParseHET(parseHET)
where
import Prelude hiding(String)
import qualified Data.ByteString.Char8 as BS
import Bio.PDB.EventParser.PDBEvents
import Bio.PDB.EventParser.PDBParsingAbstractions
hetFields = [(6, mKeyword "record header" "HET " ),
(7, mSpc 1 ),
(10, mStr "hetero group identifier" ),
(12, mSpc 2 ),
(13, mChr "chain identifier" ),
(17, mInt "sequence number" ),
(18, mChr "insertion code" ),
(20, mSpc 2 ),
(25, mInt "number of HETATM records per group" ),
(30, pSpc ),
(70, pStr "text describing HET group" )]
parseHET :: (Monad m) => String -> Int -> m [PDBEvent]
parseHET line line_no = return $ if null errs
then [result]
else errs
where
(fields, errs) = parseFields hetFields line line_no
[fRec, _, fHetId, _, fChain, fSeqNum, fInsCode, _, fAtmNum, _, fText] = fields
IFStr hetId = fHetId
IFChar chain = fChain
IFInt seqNum = fSeqNum
IFChar insCode = fInsCode
IFInt atmNum = fAtmNum
IFStr text = fText
result = HET hetId chain seqNum insCode atmNum text