module Hdis86.Pure
(
disassemble
, disassembleMetadata
, Metadata(..)
) where
import Hdis86.Types
import Hdis86.IO ( UD )
import qualified Hdis86.IO as I
import Data.Typeable ( Typeable )
import Data.Data ( Data )
import Control.Applicative
import Data.Word
import System.IO.Unsafe ( unsafePerformIO )
import qualified Data.ByteString as BS
disWith :: (UD -> IO a) -> Config -> BS.ByteString -> [a]
disWith f cfg bs = unsafePerformIO $ do
ud <- I.newUD
I.setInputBuffer ud bs
I.setConfig ud cfg
I.unsafeRunLazy ud (f ud)
disassemble :: Config -> BS.ByteString -> [Instruction]
disassemble = disWith I.getInstruction
data Metadata = Metadata
{ mdOffset :: Word64
, mdLength :: Word
, mdHex :: String
, mdBytes :: BS.ByteString
, mdAssembly :: String
, mdInst :: Instruction
} deriving (Eq, Ord, Show, Read, Typeable, Data)
disassembleMetadata :: Config -> BS.ByteString -> [Metadata]
disassembleMetadata = disWith $ \ud -> Metadata
<$> I.getOffset ud
<*> I.getLength ud
<*> I.getHex ud
<*> I.getBytes ud
<*> I.getAssembly ud
<*> I.getInstruction ud