Copyright | Will Thompson Iñaki García Etxebarria and Jonas Platte |
---|---|
License | LGPL-2.1 |
Maintainer | Iñaki García Etxebarria (inaki@blueleaf.cc) |
Safe Haskell | None |
Language | Haskell2010 |
Context
is a container object used to store contexts like a device
context, a display server connection and similar concepts that should
be shared between multiple elements.
Applications can set a context on a complete pipeline by using
elementSetContext
, which will then be propagated to all
child elements. Elements can handle these in ElementClass
.set_context
()
and merge them with the context information they already have.
When an element needs a context it will do the following actions in this order until one step succeeds: 1. Check if the element already has a context 2. Query downstream with GST_QUERY_CONTEXT for the context 3. Query upstream with GST_QUERY_CONTEXT for the context 4. Post a GST_MESSAGE_NEED_CONTEXT message on the bus with the required context types and afterwards check if a usable context was set now 5. Create a context by itself and post a GST_MESSAGE_HAVE_CONTEXT message on the bus.
Bins will catch GST_MESSAGE_NEED_CONTEXT messages and will set any previously known context on the element that asks for it if possible. Otherwise the application should provide one if it can.
Context
<!-- -->s can be persistent.
A persistent Context
is kept in elements when they reach
StateNull
, non-persistent ones will be removed.
Also, a non-persistent context won't override a previous persistent
context set to an element.
Since: 1.2
Synopsis
- newtype Context = Context (ManagedPtr Context)
- noContext :: Maybe Context
- contextGetContextType :: (HasCallStack, MonadIO m) => Context -> m Text
- contextGetStructure :: (HasCallStack, MonadIO m) => Context -> m Structure
- contextHasContextType :: (HasCallStack, MonadIO m) => Context -> Text -> m Bool
- contextIsPersistent :: (HasCallStack, MonadIO m) => Context -> m Bool
- contextNew :: (HasCallStack, MonadIO m) => Text -> Bool -> m Context
- contextWritableStructure :: (HasCallStack, MonadIO m) => Context -> m Structure
Exported types
Memory-managed wrapper type.
Instances
BoxedObject Context Source # | |
Methods
getContextType
contextGetContextType Source #
:: (HasCallStack, MonadIO m) | |
=> Context |
|
-> m Text | Returns: The type of the context. |
Get the type of context
.
Since: 1.2
getStructure
:: (HasCallStack, MonadIO m) | |
=> Context |
|
-> m Structure | Returns: The structure of the context. The structure is still owned by the context, which means that you should not modify it, free it and that the pointer becomes invalid when you free the context. |
Access the structure of the context.
Since: 1.2
hasContextType
contextHasContextType Source #
:: (HasCallStack, MonadIO m) | |
=> Context |
|
-> Text |
|
-> m Bool | Returns: |
Checks if context
has contextType
.
Since: 1.2
isPersistent
:: (HasCallStack, MonadIO m) | |
=> Context |
|
-> m Bool | Returns: |
Check if context
is persistent.
Since: 1.2
new
:: (HasCallStack, MonadIO m) | |
=> Text |
|
-> Bool |
|
-> m Context | Returns: The new context. |
Create a new context.
Since: 1.2
writableStructure
contextWritableStructure Source #
:: (HasCallStack, MonadIO m) | |
=> Context |
|
-> m Structure | Returns: The structure of the context. The structure is still
owned by the context, which means that you should not free it and
that the pointer becomes invalid when you free the context.
This function checks if |
Get a writable version of the structure.
Since: 1.2