{
char *temp = NULL;
int port = atoi( strchr( arg, ':' ) + 1 );
- mlt_properties_set( mlt_consumer_properties( this ), "server", arg );
- temp = mlt_properties_get( mlt_consumer_properties( this ), "server" );
+ mlt_properties_set( MLT_CONSUMER_PROPERTIES( this ), "server", arg );
+ temp = mlt_properties_get( MLT_CONSUMER_PROPERTIES( this ), "server" );
*( strchr( temp, ':' ) ) = '\0';
- mlt_properties_set_int( mlt_consumer_properties( this ), "port", port );
+ mlt_properties_set_int( MLT_CONSUMER_PROPERTIES( this ), "port", port );
}
else
{
- mlt_properties_set( mlt_consumer_properties( this ), "server", arg == NULL ? "localhost" : arg );
- mlt_properties_set_int( mlt_consumer_properties( this ), "port", 5250 );
+ mlt_properties_set( MLT_CONSUMER_PROPERTIES( this ), "server", arg == NULL ? "localhost" : arg );
+ mlt_properties_set_int( MLT_CONSUMER_PROPERTIES( this ), "port", 5250 );
}
- mlt_properties_set_int( mlt_consumer_properties( this ), "unit", 0 );
- mlt_properties_set( mlt_consumer_properties( this ), "command", "append" );
+ mlt_properties_set_int( MLT_CONSUMER_PROPERTIES( this ), "unit", 0 );
+ mlt_properties_set( MLT_CONSUMER_PROPERTIES( this ), "command", "append" );
// Allow thread to be started/stopped
this->start = consumer_start;
static int consumer_start( mlt_consumer this )
{
// Get the producer service
- mlt_service service = mlt_service_producer( mlt_consumer_service( this ) );
+ mlt_service service = mlt_service_producer( MLT_CONSUMER_SERVICE( this ) );
// Get the properties object
- mlt_properties properties = mlt_consumer_properties( this );
+ mlt_properties properties = MLT_CONSUMER_PROPERTIES( this );
// Get all the properties now
char *server = mlt_properties_get( properties, "server" );
int port = mlt_properties_get_int( properties, "port" );
- char *command = mlt_properties_get( properties, "command" );
+ char *cmd = mlt_properties_get( properties, "command" );
int unit = mlt_properties_get_int( properties, "unit" );
char *title = mlt_properties_get( properties, "title" );
+ char command[ 2048 ];
// If this is a reuse, then a valerie object will exist
valerie connection = mlt_properties_get_data( properties, "connection", NULL );
+ // Special case - we can get a doc too...
+ char *doc = mlt_properties_get( properties, "westley" );
+
+ // Set the title if provided
if ( service != NULL )
{
+ if ( title != NULL )
+ mlt_properties_set( MLT_SERVICE_PROPERTIES( service ), "title", title );
+ else if ( mlt_properties_get( MLT_SERVICE_PROPERTIES( service ), "title" ) == NULL )
+ mlt_properties_set( MLT_SERVICE_PROPERTIES( service ), "title", "Anonymous Submission" );
+ title = mlt_properties_get( MLT_SERVICE_PROPERTIES( service ), "title" );
+ }
+
+ strcpy( command, cmd == NULL ? "" : cmd );
+ if ( strstr( command, "title=" ) == NULL && title != NULL )
+ {
+ strcat( command, " title=\"" );
+ strcat( command, title );
+ strcat( command, "\"" );
+ }
+
+ if ( service != NULL || doc != NULL )
+ {
// Initiate the connection if required
if ( connection == NULL )
{
else
{
fprintf( stderr, "Unable to connect to the server at %s:%d\n", server, port );
+ mlt_properties_set_int( properties, "_error", 1 );
valerie_close( connection );
valerie_parser_close( parser );
connection = NULL;
// If we have connection, push the service over
if ( connection != NULL )
{
- int error;
+ if ( doc == NULL )
+ {
+ int error;
- // Set the title if provided
- if ( title != NULL )
- mlt_properties_set( mlt_service_properties( service ), "title", title );
- else if ( mlt_properties_get( mlt_service_properties( service ), "title" ) == NULL )
- mlt_properties_set( mlt_service_properties( service ), "title", "Anonymous Submission" );
+ // Push the service
+ error = valerie_unit_push( connection, unit, command, service );
- // Push the service
- error = valerie_unit_push( connection, unit, command, service );
+ // Report error
+ if ( error != valerie_ok )
+ fprintf( stderr, "Push failed on %s:%d %s u%d (%d)\n", server, port, command, unit, error );
+ }
+ else
+ {
+ // Push the service
+ int error = valerie_unit_receive( connection, unit, command, doc );
- // Report error
- if ( error != valerie_ok )
- fprintf( stderr, "Push failed on %s:%d %s u%d (%d)\n", server, port, command, unit, error );
+ // Report error
+ if ( error != valerie_ok )
+ fprintf( stderr, "Send failed on %s:%d %s u%d (%d)\n", server, port, command, unit, error );
+ }
}
}