| Top |  |  |  |  | 
| GQuark | rb_encoder_error_quark () | 
| RBEncoderFactory * | rb_encoder_factory_get () | 
| RBEncoder * | rb_encoder_new () | 
| void | rb_encoder_encode () | 
| void | rb_encoder_cancel () | 
| gboolean | rb_encoder_get_missing_plugins () | 
The RBEncoder interface provides transcoding between audio formats based on encoding profiles. The encoder implementation operates asynchronously and provides status updates in the form of signals emitted on the main thread. A new encoder instance should be created for each file that is transcoded or copied.
RBEncoderFactory *
rb_encoder_factory_get (void);
Returns the RBEncoderFactory instance.
void rb_encoder_encode (RBEncoder *encoder,RhythmDBEntry *entry,const char *dest,gboolean overwrite,GstEncodingProfile *profile);
Initiates encoding, transcoding to the specified profile if specified.
Encoding and error reporting takes place asynchronously. The caller should wait for the 'completed' signal which indicates it has either completed or failed.
| encoder | the RBEncoder | |
| entry | the RhythmDBEntry to transcode | |
| dest | destination file URI | |
| overwrite | if  | |
| profile | encoding profile to use, or NULL to just copy | 
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.
gboolean rb_encoder_get_missing_plugins (RBEncoder *encoder,GstEncodingProfile *profile,char ***details,char ***descriptions);
Retrieves the plugin installer detail strings and descriptions for any missing plugins required to use the specified encoding profile.
| encoder | a RBEncoder | |
| profile | an encoding profile | |
| details | returns plugin installer detail strings. | [out callee-allocates] | 
| descriptions | returns plugin descriptions. | [out callee-allocates] | 
struct RBEncoderIface {
	GTypeInterface g_iface;
	/* vtable */
	void		(*encode) (RBEncoder *encoder,
					 RhythmDBEntry *entry,
					 const char *dest,
					 gboolean overwrite,
					 GstEncodingProfile *profile);
	void		(*cancel) (RBEncoder *encoder);
	gboolean (*get_missing_plugins) (RBEncoder *encoder,
					 GstEncodingProfile *profile,
					 char ***details,
					 char ***descriptions);
	/* signals */
	void (*progress) (RBEncoder *encoder,  double fraction);
	void (*completed) (RBEncoder *encoder, guint64 dest_size, const char *mediatype, GError *error);
};