|  |  |  | librygel-server Reference Manual |  | 
|---|---|---|---|---|
| Top | Description | Object Hierarchy | Known Derived Interfaces | Properties | Signals | ||||
| RygelMediaContainerRygelMediaContainer — This is a container (folder) for media items and child containers. | 
#define RYGEL_TYPE_MEDIA_CONTAINER void rygel_media_container_get_children (RygelMediaContainer *self,guint offset,guint max_count,const gchar *sort_criteria,GCancellable *cancellable,GAsyncReadyCallback _callback_,gpointer _user_data_); RygelMediaObjects * rygel_media_container_get_children_finish (RygelMediaContainer *self,GAsyncResult *_res_,GError **error); void rygel_media_container_find_object (RygelMediaContainer *self,const gchar *id,GCancellable *cancellable,GAsyncReadyCallback _callback_,gpointer _user_data_); RygelMediaObject * rygel_media_container_find_object_finish (RygelMediaContainer *self,GAsyncResult *_res_,GError **error); void rygel_media_container_updated (RygelMediaContainer *self,RygelMediaObject *object,RygelObjectEventType event_type,gboolean sub_tree_update); #define RYGEL_MEDIA_CONTAINER_ANY #define RYGEL_MEDIA_CONTAINER_UPNP_CLASS #define RYGEL_MEDIA_CONTAINER_STORAGE_FOLDER #define RYGEL_MEDIA_CONTAINER_MUSIC_ALBUM #define RYGEL_MEDIA_CONTAINER_MUSIC_ARTIST #define RYGEL_MEDIA_CONTAINER_MUSIC_GENRE #define RYGEL_MEDIA_CONTAINER_PLAYLIST #define RYGEL_MEDIA_CONTAINER_ALBUM_SORT_CRITERIA gint rygel_media_container_get_child_count (RygelMediaContainer *self); void rygel_media_container_set_child_count (RygelMediaContainer *self,gint value); gint rygel_media_container_get_empty_child_count (RygelMediaContainer *self); void rygel_media_container_set_empty_child_count (RygelMediaContainer *self,gint value); gint rygel_media_container_get_all_child_count (RygelMediaContainer *self); gboolean rygel_media_container_get_create_mode_enabled (RygelMediaContainer *self); void rygel_media_container_set_create_mode_enabled (RygelMediaContainer *self,gboolean value); const gchar * rygel_media_container_get_sort_criteria (RygelMediaContainer *self); void rygel_media_container_set_sort_criteria (RygelMediaContainer *self,const gchar *value); struct RygelMediaContainer; struct RygelMediaContainerClass; enum RygelObjectEventType;
GObject +----RygelMediaObject +----RygelMediaContainer +----RygelSimpleContainer
GEnum +----RygelObjectEventType
RygelMediaContainer is required by RygelSearchableContainer, RygelTrackableContainer and RygelWritableContainer.
"all-child-count" gint : Read "child-count" gint : Read / Write / Construct "create-mode-enabled" gboolean : Read / Write "empty-child-count" gint : Read / Write "ocm-flags" GUPnPOCMFlags : Read "sort-criteria" gchar* : Read / Write
It provides a basic serialization implementation (to DIDLLiteWriter).
A derived class should provide a working implementation of get_children and should emit the container_updated signal.
When used as a root container, you may wish to use the variables, such as REALNAME, in in the title. See the title property of the RygelMediaObject.
If the container should support UPnP search operations then you also implement the RygelSearchableContainer interface.
If the container should be writable, meaning that it allows adding (via upload), removal and editing of items then you should also implement the RygelWritableContainer interface.
If the container should support the change tracking profile of the UPnP ContentDirectory:3 specification then you should also implement the RygelTrackableContainer interface.
The RygelSimpleContainer class contains a simple memory-based container implementation, but most real-world uses will require custom container implementations.
#define RYGEL_TYPE_MEDIA_CONTAINER (rygel_media_container_get_type ())
The type for RygelMediaContainer.
void rygel_media_container_get_children (RygelMediaContainer *self,guint offset,guint max_count,const gchar *sort_criteria,GCancellable *cancellable,GAsyncReadyCallback _callback_,gpointer _user_data_);
Fetches the list of media objects directly under this container.
See also: rygel_media_container_get_children_finish()
| 
 | the RygelMediaContainer instance | 
| 
 | . zero-based index of the first item to return. [in] | 
| 
 | . maximum number of objects to return. [in] | 
| 
 | . sorting order of objects to return. [in] | 
| 
 | . optional cancellable for this operation. [in][allow-none] | 
| 
 | callback to call when the request is satisfied. [scope async] | 
| 
 | the data to pass to _callback_function. [closure] | 
RygelMediaObjects * rygel_media_container_get_children_finish (RygelMediaContainer *self,GAsyncResult *_res_,GError **error);
Fetches the list of media objects directly under this container.
See also: rygel_media_container_get_children()
| 
 | the RygelMediaContainer instance | 
| 
 | a GAsyncResult | 
| 
 | location to store the error occuring, or NULLto ignore | 
| Returns : | A list of media objects. | 
void rygel_media_container_find_object (RygelMediaContainer *self,const gchar *id,GCancellable *cancellable,GAsyncReadyCallback _callback_,gpointer _user_data_);
Recursively searches this container for a media object with the given ID.
See also: rygel_media_container_find_object_finish()
| 
 | the RygelMediaContainer instance | 
| 
 | . ID of the media object to search for. [in] | 
| 
 | . optional cancellable for this operation. [in][allow-none] | 
| 
 | callback to call when the request is satisfied. [scope async] | 
| 
 | the data to pass to _callback_function. [closure] | 
RygelMediaObject * rygel_media_container_find_object_finish (RygelMediaContainer *self,GAsyncResult *_res_,GError **error);
Recursively searches this container for a media object with the given ID.
See also: rygel_media_container_find_object()
| 
 | the RygelMediaContainer instance | 
| 
 | a GAsyncResult | 
| 
 | location to store the error occuring, or NULLto ignore | 
| Returns : | the found media object. | 
void rygel_media_container_updated (RygelMediaContainer *self,RygelMediaObject *object,RygelObjectEventType event_type,gboolean sub_tree_update);
This method should be called each time this container is updated.
For instance, this should be called if there are metadata changes for this container, if items under it are removed or added, if there are metadata changes to items under it, etc.
If sub_tree_update is true then the caller should later emit the sub_tree_updates_finished signal on the root container of the sub-tree that was updated.
It will eventually result in the server emitting a UPnP LastChange event, though that may be for a batch of these calls.
See the "container_updated" signal.
| 
 | the RygelMediaContainer instance | 
| 
 | . The object that has changed, or null to mean the container itself. [in][allow-none] | 
| 
 | . This describes what actually happened to the object. [in] | 
| 
 | . Whether the modification is part of a sub-tree update. [in] | 
#define RYGEL_MEDIA_CONTAINER_STORAGE_FOLDER RYGEL_MEDIA_CONTAINER_UPNP_CLASS ".storageFolder"
#define RYGEL_MEDIA_CONTAINER_MUSIC_ALBUM RYGEL_MEDIA_CONTAINER_UPNP_CLASS ".album.musicAlbum"
#define RYGEL_MEDIA_CONTAINER_MUSIC_ARTIST RYGEL_MEDIA_CONTAINER_UPNP_CLASS ".person.musicArtist"
#define RYGEL_MEDIA_CONTAINER_MUSIC_GENRE RYGEL_MEDIA_CONTAINER_UPNP_CLASS ".genre.musicGenre"
#define RYGEL_MEDIA_CONTAINER_PLAYLIST RYGEL_MEDIA_CONTAINER_UPNP_CLASS ".playlistContainer"
#define RYGEL_MEDIA_CONTAINER_ALBUM_SORT_CRITERIA "+upnp:class," "+rygel:originalVolumeNumber," "+upnp:originalTrackNumber," "+dc:title"
gint                rygel_media_container_get_child_count
                                                        (RygelMediaContainer *self);
Get and return the current value of the "child-count" property.
| 
 | the RygelMediaContainer instance to query | 
| Returns : | the value of the "child-count" property | 
void rygel_media_container_set_child_count (RygelMediaContainer *self,gint value);
Set the value of the "child-count" property to value.
| 
 | the RygelMediaContainer instance to modify | 
| 
 | the new value of the "child-count" property | 
gint                rygel_media_container_get_empty_child_count
                                                        (RygelMediaContainer *self);
Get and return the current value of the "empty-child-count" property.
| 
 | the RygelMediaContainer instance to query | 
| Returns : | the value of the "empty-child-count" property | 
void rygel_media_container_set_empty_child_count (RygelMediaContainer *self,gint value);
Set the value of the "empty-child-count" property to value.
| 
 | the RygelMediaContainer instance to modify | 
| 
 | the new value of the "empty-child-count" property | 
gint                rygel_media_container_get_all_child_count
                                                        (RygelMediaContainer *self);
Get and return the current value of the "all-child-count" property.
| 
 | the RygelMediaContainer instance to query | 
| Returns : | the value of the "all-child-count" property | 
gboolean            rygel_media_container_get_create_mode_enabled
                                                        (RygelMediaContainer *self);
Get and return the current value of the "create-mode-enabled" property.
| 
 | the RygelMediaContainer instance to query | 
| Returns : | the value of the "create-mode-enabled" property | 
void rygel_media_container_set_create_mode_enabled (RygelMediaContainer *self,gboolean value);
Set the value of the "create-mode-enabled" property to value.
| 
 | the RygelMediaContainer instance to modify | 
| 
 | the new value of the "create-mode-enabled" property | 
const gchar *       rygel_media_container_get_sort_criteria
                                                        (RygelMediaContainer *self);
Get and return the current value of the "sort-criteria" property.
| 
 | the RygelMediaContainer instance to query | 
| Returns : | the value of the "sort-criteria" property | 
void rygel_media_container_set_sort_criteria (RygelMediaContainer *self,const gchar *value);
Set the value of the "sort-criteria" property to value.
| 
 | the RygelMediaContainer instance to modify | 
| 
 | the new value of the "sort-criteria" property | 
struct RygelMediaContainer;
This is a container (folder) for media items and child containers.
It provides a basic serialization implementation (to DIDLLiteWriter).
A derived class should provide a working implementation of get_children and should emit the container_updated signal.
When used as a root container, you may wish to use the variables, such as REALNAME, in in the title. See the title property of the RygelMediaObject.
If the container should support UPnP search operations then you also implement the RygelSearchableContainer interface.
If the container should be writable, meaning that it allows adding (via upload), removal and editing of items then you should also implement the RygelWritableContainer interface.
If the container should support the change tracking profile of the UPnP ContentDirectory:3 specification then you should also implement the RygelTrackableContainer interface.
The RygelSimpleContainer class contains a simple memory-based container implementation, but most real-world uses will require custom container implementations.
struct RygelMediaContainerClass {
	RygelMediaObjectClass parent_class;
	void (*get_children) (RygelMediaContainer* self, guint offset, guint max_count, const gchar* sort_criteria, GCancellable* cancellable, GAsyncReadyCallback _callback_, gpointer _user_data_);
	RygelMediaObjects* (*get_children_finish) (RygelMediaContainer* self, GAsyncResult* _res_, GError** error);
	void (*find_object) (RygelMediaContainer* self, const gchar* id, GCancellable* cancellable, GAsyncReadyCallback _callback_, gpointer _user_data_);
	RygelMediaObject* (*find_object_finish) (RygelMediaContainer* self, GAsyncResult* _res_, GError** error);
};
The class structure for RYGEL_TYPE_MEDIA_CONTAINER. All the fields in this structure are private and should never be accessed directly.
| RygelMediaObjectClass  | the parent class structure | 
| virtual method called by rygel_media_container_get_children() | |
| asynchronous finish function for get_children, called byrygel_media_container_get_children() | |
| virtual method called by rygel_media_container_find_object() | |
| asynchronous finish function for find_object, called byrygel_media_container_find_object() | 
"child-count" property"child-count" gint : Read / Write / Construct
child-count.
Default value: 0
"create-mode-enabled" property"create-mode-enabled" gboolean : Read / Write
create-mode-enabled.
Default value: FALSE
"empty-child-count" property"empty-child-count" gint : Read / Write
empty-child-count.
Default value: 0
"sort-criteria" property"sort-criteria" gchar* : Read / Write
sort-criteria.
Default value: NULL
"container-updated" signalvoid                user_function                      (RygelMediaContainer *media_container,
                                                        RygelMediaContainer *container,
                                                        RygelMediaObject    *object,
                                                        RygelObjectEventType event_type,
                                                        gboolean             sub_tree_update,
                                                        gpointer             user_data)            : Run Last
The container_updated signal is emitted if a child container under the tree of this container has been updated. The object parameter is set to the MediaObject that is the source of the container update. Note that it may even be set to the container itself.
See also: rygel_media_container_updated().
| 
 | the RygelMediaContainer instance that received the signal | 
| 
 | . The child container that has been updated. | 
| 
 | . The object that has changed. This may be the container itself, or a child item. | 
| 
 | . This describes what actually happened to the object. | 
| 
 | . Whether the modification is part of a sub-tree update. See the "sub_tree_updates_finished" signal. | 
| 
 | user data set when the signal handler was connected. | 
"sub-tree-updates-finished" signalvoid                user_function                      (RygelMediaContainer *media_container,
                                                        RygelMediaObject    *sub_tree_root,
                                                        gpointer             user_data)            : Run Last
The sub_tree_updates_finished signal is emitted when all of the sub-tree operations are finished. See the "container_updated" signal.
| 
 | the RygelMediaContainer instance that received the signal | 
| 
 | . - root of a sub-tree where all operations were performed. | 
| 
 | user data set when the signal handler was connected. |