X-Git-Url: http://research.m1stereo.tv/gitweb?a=blobdiff_plain;f=src%2Fmiracle%2Fmiracle_unit_commands.c;h=97fb2dd0934aeb3a6e5edc25a08357e682cfcb30;hb=d5d878221c3123ef1d3a335dbc2b1878b3fdb983;hp=98a420d5886044e89113e47436a14e16d5145f04;hpb=f00476101550ec7d8e863f6516aa83bc1b524570;p=melted diff --git a/src/miracle/miracle_unit_commands.c b/src/miracle/miracle_unit_commands.c index 98a420d..97fb2dd 100644 --- a/src/miracle/miracle_unit_commands.c +++ b/src/miracle/miracle_unit_commands.c @@ -181,6 +181,20 @@ int miracle_clean( command_argument cmd_arg ) return RESPONSE_SUCCESS; } +int miracle_wipe( command_argument cmd_arg ) +{ + miracle_unit unit = miracle_get_unit(cmd_arg->unit); + + if (unit == NULL) + return RESPONSE_INVALID_UNIT; + else + { + if ( miracle_unit_wipe( unit ) != valerie_ok ) + return RESPONSE_BAD_FILE; + } + return RESPONSE_SUCCESS; +} + int miracle_clear( command_argument cmd_arg ) { miracle_unit unit = miracle_get_unit(cmd_arg->unit); @@ -265,17 +279,23 @@ int miracle_push( command_argument cmd_arg, mlt_service service ) int miracle_receive( command_argument cmd_arg, char *doc ) { - mlt_producer producer = mlt_factory_producer( "westley-xml", doc ); miracle_unit unit = miracle_get_unit(cmd_arg->unit); - if ( unit != NULL && producer != NULL ) + if ( unit != NULL ) { - if ( miracle_unit_append_service( unit, MLT_PRODUCER_SERVICE( producer ) ) == valerie_ok ) + // Get the consumer's profile + mlt_consumer consumer = mlt_properties_get_data( unit->properties, "consumer", NULL ); + mlt_profile profile = mlt_service_profile( MLT_CONSUMER_SERVICE( consumer ) ); + mlt_producer producer = mlt_factory_producer( profile, "westley-xml", doc ); + if ( producer != NULL ) { + if ( miracle_unit_append_service( unit, MLT_PRODUCER_SERVICE( producer ) ) == valerie_ok ) + { + mlt_producer_close( producer ); + return RESPONSE_SUCCESS; + } mlt_producer_close( producer ); - return RESPONSE_SUCCESS; } } - mlt_producer_close( producer ); return RESPONSE_BAD_FILE; }