{-# LANGUAGE TypeFamilies #-} -- | -- Module: Data.Greskell.AsLabel -- Description: Label string used in .as step -- Maintainer: Toshio Ito -- -- @since 0.2.2.0 module Data.Greskell.AsLabel ( -- * AsLabel AsLabel(..), SelectedMap, -- * Re-exports lookup, lookupM, lookupAs, lookupAsM, PMapLookupException(..) ) where import Prelude hiding (lookup) import Control.Exception (Exception) import Control.Monad.Catch (MonadThrow(..)) import Data.Foldable (Foldable) import Data.HashMap.Strict (HashMap) import qualified Data.HashMap.Strict as HM import Data.Greskell.GraphSON (GValue, GraphSONTyped(..), FromGraphSON(..), parseEither) import Data.Greskell.Greskell (ToGreskell(..)) import qualified Data.Greskell.Greskell as Greskell import Data.String (IsString(..)) import Data.Text (Text) import Data.Traversable (Traversable) import Data.Greskell.PMap ( PMap, PMapKey(..), Single, lookup, lookupM, lookupAs, lookupAsM, PMapLookupException(..) ) -- | 'AsLabel' @a@ represents a label string used in @.as@ step -- pointing to the data of type @a@. newtype AsLabel a = AsLabel { unAsLabel :: Text } deriving (Show,Eq,Ord) -- | @since 1.0.0.0 instance IsString (AsLabel a) where fromString = AsLabel . fromString -- | Returns the 'Text' as a Gremlin string. instance ToGreskell (AsLabel a) where type GreskellReturn (AsLabel a) = Text toGreskell (AsLabel t) = Greskell.string t -- | Unsafely convert the phantom type. instance Functor AsLabel where fmap _ (AsLabel t) = AsLabel t -- | @since 1.0.0.0 instance PMapKey (AsLabel a) where type PMapValue (AsLabel a) = a keyText = unAsLabel -- | A map keyed with 'AsLabel'. Obtained from @.select@ step, for -- example. type SelectedMap = PMap Single