2 * MltFilteredConsumer.cpp - MLT Wrapper
3 * Copyright (C) 2004-2005 Charles Yates
4 * Author: Charles Yates <charles.yates@pandora.be>
6 * This program is free software; you can redistribute it and/or modify
7 * it under the terms of the GNU Lesser General Public License as published
8 * by the Free Software Foundation; either version 2 of the License, or
9 * (at your option) any later version.
11 * This program is distributed in the hope that it will be useful,
12 * but WITHOUT ANY WARRANTY; without even the implied warranty of
13 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
14 * GNU General Public License for more details.
16 * You should have received a copy of the GNU General Public License
17 * along with this program; if not, write to the Free Software Foundation,
18 * Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
21 #include "MltFilteredConsumer.h"
24 FilteredConsumer
::FilteredConsumer( char *id
, char *arg
) :
27 // Create a reference to the first service
28 first
= new Service( *this );
31 FilteredConsumer
::FilteredConsumer( Consumer
&consumer
) :
34 // Create a reference to the first service
35 first
= new Service( *this );
38 FilteredConsumer
::~FilteredConsumer( )
40 // Delete the reference to the first service
44 int FilteredConsumer
::connect( Service
&service
)
46 // All producers must connect to the first service, hence the use of the virtual here
47 return first
->connect_producer( service
);
50 int FilteredConsumer
::attach( Filter
&filter
)
53 if ( filter
.is_valid( ) )
55 Service
*producer
= first
->producer( );
56 error
= filter
.connect( *producer
);
59 first
->connect_producer( filter
);
61 first
= new Service( filter
);
72 int FilteredConsumer
::detach( Filter
&filter
)
74 if ( filter
.is_valid( ) )
76 Service
*it
= new Service( *first
);
77 while ( it
->is_valid( ) && it
->get_service( ) != filter
.get_service( ) )
79 Service
*consumer
= it
->consumer( );
83 if ( it
->get_service( ) == filter
.get_service( ) )
85 Service
*producer
= it
->producer( );
86 Service
*consumer
= it
->consumer( );
87 consumer
->connect_producer( *producer
);
88 Service
dummy( NULL
);
89 it
->connect_producer( dummy
);
90 if ( first
->get_service( ) == it
->get_service( ) )
93 first
= new Service( *consumer
);