{-# LANGUAGE CPP #-}
{-# LANGUAGE DeriveDataTypeable #-}
-----------------------------------------------------------------------------
--
-- Module      :  Language.Javascript.JSaddle.Exception
-- Copyright   :  (c) Hamish Mackenzie
-- License     :  MIT
--
-- Maintainer  :  Hamish Mackenzie <Hamish.K.Mackenzie@googlemail.com>
--
-- |
--
-----------------------------------------------------------------------------

module Language.Javascript.JSaddle.Exception (
    JSException(..)
--  , rethrow
) where

import qualified Control.Exception as E (Exception)
#ifdef ghcjs_HOST_OS
import GHCJS.Prim (JSVal)
#else
import GHCJS.Prim.Internal (JSVal)
#endif
import Data.Typeable (Typeable)

newtype JSException = JSException JSVal deriving (Typeable)

-- | JavaScript exception
-- >>>
instance Show JSException where show :: JSException -> String
show JSException
_ = String
"JSException"
instance E.Exception JSException

---- | Catch JavaScript exceptions and rethrow Haskell ones
--rethrow :: (MutableJSArray -> JSM a) -> JSM a
--rethrow f = f `catchval` \e ->
--    liftIO . E.throwIO $ JSException e