|  |  |  | Rhythmbox Development Reference Manual |  | 
|---|---|---|---|---|
| Top | Description | Object Hierarchy | Signals | ||||
RBEncoder; RBEncoderIface; RBEncoder* rb_encoder_new (void); void rb_encoder_encode (RBEncoder *encoder,RhythmDBEntry *entry,const char *dest,const char *dest_media_type); void rb_encoder_cancel (RBEncoder *encoder); gboolean rb_encoder_get_media_type (RBEncoder *encoder,RhythmDBEntry *entry,GList *dest_media_types,char **media_type,char **extension); gboolean rb_encoder_get_missing_plugins (RBEncoder *encoder,const char *media_type,char ***details);
The RBEncoder interface provides transcoding between audio formats based on media types. Media types are conceptually similar to MIME types, and overlap in many cases, but the media type for an encoding is not always the same as the MIME type for files using that encoding.
The encoder picks the output format from a list provided by the caller, limited by the available codecs. It operatees asynchronously and provides status updates in the form of signals.
A new encoder instance should be created for each file that is transcoded.
typedef struct {
	GTypeInterface g_iface;
	/* vtable */
	void		(*encode) (RBEncoder *encoder,
					 RhythmDBEntry *entry,
					 const char *dest,
					 const char *dest_media_type);
	void		(*cancel) (RBEncoder *encoder);
	gboolean (*get_media_type) (RBEncoder *encoder,
					 RhythmDBEntry *entry,
					 GList *dest_media_types,
					 char **media_type,
					 char **extension);
	gboolean (*get_missing_plugins) (RBEncoder *encoder,
					 const char *media_type,
					 char ***details);
	/* signals */
	void (*progress) (RBEncoder *encoder,  double fraction);
	gboolean (*overwrite) (RBEncoder *encoder, GFile *file);
	void (*completed) (RBEncoder *encoder, guint64 dest_size, const char *mediatype, GError *error);
} RBEncoderIface;
RBEncoder*          rb_encoder_new                      (void);
Creates a new RBEncoder instance.
| Returns : | the new RBEncoder | 
void rb_encoder_encode (RBEncoder *encoder,RhythmDBEntry *entry,const char *dest,const char *dest_media_type);
Initiates encoding, transcoding to the specified media type if it doesn't match the current media type of the entry. The caller should use rb_encoder_get_media_type to select a destination media type.
Encoding and error reporting takes places asynchronously. The caller should wait for the 'completed' signal which indicates it has either completed or failed.
| 
 | the RBEncoder | 
| 
 | the RhythmDBEntry to transcode | 
| 
 | destination file URI | 
| 
 | destination media type, or NULL to just copy it | 
void                rb_encoder_cancel                   (RBEncoder *encoder);
Attempts to cancel any in progress encoding. The encoder should delete the destination file, if it created one, and emit the 'completed' signal.
| 
 | a RBEncoder | 
gboolean rb_encoder_get_media_type (RBEncoder *encoder,RhythmDBEntry *entry,GList *dest_media_types,char **media_type,char **extension);
Identifies the first media type in the list that the encoder can actually encode to. The file extension (eg. '.mp3' for audio/mpeg) associated with the selected type is also returned.
| 
 | a RBEncoder | 
| 
 | the source RhythmDBEntry | 
| 
 | a GList of media type strings in order of preference | 
| 
 | returns the selected media type, if any | 
| 
 | returns the file extension associated with the selected media type, if any | 
| Returns : | TRUE if a format was identified | 
gboolean rb_encoder_get_missing_plugins (RBEncoder *encoder,const char *media_type,char ***details);
Retrieves the plugin installer detail strings for any missing plugins required to encode the specified media type.
| 
 | a RBEncoder | 
| 
 | the media type required | 
| 
 | returns plugin installer detail strings | 
| Returns : | TRUEif some detail strings are returned,FALSEotherwise | 
"completed" signalvoid user_function (RBEncoder *encoder, guint64 dest_size, gchar *mediatype, gpointer error, gpointer user_data) : Run Last
Emitted when the encoding process is complete, or when a fatal error has occurred. The destination file, if one exists, will be closed and flushed to disk before this signal is emitted.
| 
 | the RBEncoder instance | 
| 
 | size of the output file | 
| 
 | output media type | 
| 
 | encoding error, or NULL if successful | 
| 
 | user data set when the signal handler was connected. | 
"overwrite" signalgboolean user_function (RBEncoder *encoder, GObject *file, gpointer user_data) : Run Last
Emitted when a destination file already exists.  If the
return value if TRUE, the file will be overwritten, otherwise
the transfer will be aborted.
| 
 | the RBEncoder instance | 
| 
 | the GFile that may be overwritten | 
| 
 | user data set when the signal handler was connected. | 
"progress" signalvoid user_function (RBEncoder *encoder, gdouble fraction, gpointer user_data) : Run Last
Emitted regularly during the encoding process to provide progress updates.
| 
 | the RBEncoder instance | 
| 
 | progress as a fraction (0..1) | 
| 
 | user data set when the signal handler was connected. |