module Biobase.Primary.Nuc.XNA where
import Data.Aeson
import Data.Char (toUpper)
import Data.Ix (Ix(..))
import Data.Primitive.Types
import Data.String
import Data.Tuple (swap)
import qualified Data.ByteString.Char8 as BS
import qualified Data.ByteString.Lazy.Char8 as BSL
import qualified Data.Text as T
import qualified Data.Text.Lazy as TL
import qualified Data.Vector.Generic as VG
import qualified Data.Vector.Generic.Mutable as VGM
import qualified Data.Vector.Unboxed as VU
import Control.Category ((>>>))
import Biobase.Types.BioSequence
import Biobase.Primary.Bounds
import Biobase.Primary.Letter
pattern A = Letter 0 :: Letter XNA n
pattern C = Letter 1 :: Letter XNA n
pattern G = Letter 2 :: Letter XNA n
pattern T = Letter 3 :: Letter XNA n
pattern U = Letter 4 :: Letter XNA n
pattern N = Letter 5 :: Letter XNA n
instance Bounded (Letter XNA n) where
minBound = A
maxBound = N
instance Enum (Letter XNA n) where
succ N = error "succ/N:XNA"
succ (Letter x) = Letter $ x+1
pred A = error "pred/A:XNA"
pred (Letter x) = Letter $ x-1
toEnum k | k>=0 && k<=5 = Letter k
toEnum k = error $ "toEnum/Letter XNA " ++ show k
fromEnum (Letter k) = k
instance LetterChar XNA n where
letterChar = xnaChar
charLetter = charXNA
charXNA = toUpper >>> \case
'A' -> A
'C' -> C
'G' -> G
'T' -> T
'U' -> U
_ -> N
{-# INLINE charXNA #-}
xnaChar = \case
A -> 'A'
C -> 'C'
G -> 'G'
T -> 'T'
U -> 'U'
N -> 'N'
{-# INLINE xnaChar #-}
instance Show (Letter XNA n) where
show c = [xnaChar c]
instance Read (Letter XNA n) where
readsPrec p [] = []
readsPrec p (x:xs)
| x==' ' = readsPrec p xs
| otherwise = [(charXNA x, xs)]
xnaSeq :: MkPrimary p XNA n => p -> Primary XNA n
xnaSeq = primary
instance MkPrimary (VU.Vector Char) XNA n where
primary = VU.map charXNA
instance IsString [Letter XNA n] where
fromString = map charXNA