| Safe Haskell | None |
|---|
Yesod.Core.Content
Contents
- data Content
- = ContentBuilder !Builder !(Maybe Int)
- | ContentSource !(Source (ResourceT IO) (Flush Builder))
- | ContentFile !FilePath !(Maybe FilePart)
- | ContentDontEvaluate !Content
- emptyContent :: Content
- class ToContent a where
- class ToFlushBuilder a where
- toFlushBuilder :: a -> Flush Builder
- type ContentType = ByteString
- typeHtml :: ContentType
- typePlain :: ContentType
- typeJson :: ContentType
- typeXml :: ContentType
- typeAtom :: ContentType
- typeRss :: ContentType
- typeJpeg :: ContentType
- typePng :: ContentType
- typeGif :: ContentType
- typeSvg :: ContentType
- typeJavascript :: ContentType
- typeCss :: ContentType
- typeFlv :: ContentType
- typeOgv :: ContentType
- typeOctet :: ContentType
- simpleContentType :: ContentType -> ContentType
- contentTypeTypes :: ContentType -> (ByteString, ByteString)
- newtype DontFullyEvaluate a = DontFullyEvaluate {
- unDontFullyEvaluate :: a
- data TypedContent = TypedContent !ContentType !Content
- class ToContent a => ToTypedContent a where
- toTypedContent :: a -> TypedContent
- class ToTypedContent a => HasContentType a where
- getContentType :: Monad m => m a -> ContentType
- type RepHtml = Html
- newtype RepJson = RepJson Content
- newtype RepPlain = RepPlain Content
- newtype RepXml = RepXml Content
- repJson :: ToContent a => a -> RepJson
- repPlain :: ToContent a => a -> RepPlain
- repXml :: ToContent a => a -> RepXml
Content
Constructors
| ContentBuilder !Builder !(Maybe Int) | The content and optional content length. |
| ContentSource !(Source (ResourceT IO) (Flush Builder)) | |
| ContentFile !FilePath !(Maybe FilePart) | |
| ContentDontEvaluate !Content |
Instances
Zero-length enumerator.
Anything which can be converted into Content. Most of the time, you will
want to use the ContentBuilder constructor. An easier approach will be to use
a pre-defined toContent function, such as converting your data into a lazy
bytestring and then calling toContent on that.
Please note that the built-in instances for lazy data structures (String,
lazy ByteString, lazy Text and Html) will not automatically include
the content length for the ContentBuilder constructor.
Instances
| ToContent String | |
| ToContent () | |
| ToContent ByteString | |
| ToContent ByteString | |
| ToContent Text | |
| ToContent Value | |
| ToContent Text | |
| ToContent Builder | |
| ToContent Html | |
| ToContent RepXml | |
| ToContent RepPlain | |
| ToContent RepJson | |
| ToContent TypedContent | |
| ToContent Content | |
| ToContent a => ToContent (DontFullyEvaluate a) | |
| ToContent (ContentType, Content) | |
| ToFlushBuilder builder => ToContent (Source (ResourceT IO) builder) | |
| ToFlushBuilder builder => ToContent (ResumableSource (ResourceT IO) builder) |
class ToFlushBuilder a whereSource
A class for all data which can be sent in a streaming response. Note that for textual data, instances must use UTF-8 encoding.
Since 1.2.0
Methods
toFlushBuilder :: a -> Flush BuilderSource
Instances
Mime types
Data type
type ContentType = ByteStringSource
Utilities
simpleContentType :: ContentType -> ContentTypeSource
Removes "extra" information at the end of a content type string. In particular, removes everything after the semicolon, if present.
For example, "text/html; charset=utf-8" is commonly used to specify the character encoding for HTML data. This function would return "text/html".
Evaluation strategy
newtype DontFullyEvaluate a Source
Prevents a response body from being fully evaluated before sending the request.
Since 1.1.0
Constructors
| DontFullyEvaluate | |
Fields
| |
Instances
| ToTypedContent a => ToTypedContent (DontFullyEvaluate a) | |
| HasContentType a => HasContentType (DontFullyEvaluate a) | |
| ToContent a => ToContent (DontFullyEvaluate a) |
Representations
class ToContent a => ToTypedContent a whereSource
Any type which can be converted to TypedContent.
Since 1.2.0
Methods
toTypedContent :: a -> TypedContentSource
Instances
class ToTypedContent a => HasContentType a whereSource
Methods
getContentType :: Monad m => m a -> ContentTypeSource
Specific content types
Instances