/*****************************************************************************
* dvb.c : DVB channel list import (szap/tzap/czap compatible channel lists)
*****************************************************************************
- * Copyright (C) 2005 the VideoLAN team
+ * Copyright (C) 2005-20009 the VideoLAN team
* $Id$
*
* Authors: Gildas Bazin <gbazin@videolan.org>
/*****************************************************************************
* Preamble
*****************************************************************************/
-#include <vlc/vlc.h>
+#ifdef HAVE_CONFIG_H
+# include "config.h"
+#endif
+
+#include <vlc_common.h>
#include <vlc_demux.h>
-#include <vlc_interface.h>
#include <vlc_charset.h>
#include "playlist.h"
/*****************************************************************************
* Import_DVB: main import function
*****************************************************************************/
-int E_(Import_DVB)( vlc_object_t *p_this )
+int Import_DVB( vlc_object_t *p_this )
{
demux_t *p_demux = (demux_t *)p_this;
- uint8_t *p_peek;
+ const uint8_t *p_peek;
int i_peek;
- vlc_bool_t b_valid = VLC_FALSE;
+ bool b_valid = false;
- if( !demux2_IsPathExtension( p_demux, ".conf" ) && !p_demux->b_force )
+ if( !demux_IsPathExtension( p_demux, ".conf" ) && !p_demux->b_force )
return VLC_EGENERIC;
/* Check if this really is a channels file */
}
psz_line[i] = 0;
- if( ParseLine( psz_line, 0, 0, 0 ) ) b_valid = VLC_TRUE;
+ if( ParseLine( psz_line, 0, 0, 0 ) ) b_valid = true;
}
if( !b_valid ) return VLC_EGENERIC;
/*****************************************************************************
* Deactivate: frees unused data
*****************************************************************************/
-void E_(Close_DVB)( vlc_object_t *p_this )
+void Close_DVB( vlc_object_t *p_this )
{
+ VLC_UNUSED(p_this);
}
/*****************************************************************************
{
char *psz_line;
input_item_t *p_input;
- INIT_PLAYLIST_STUFF;
+ input_item_t *p_current_input = GetCurrentItem(p_demux);
while( (psz_line = stream_ReadLine( p_demux->s )) )
{
char **ppsz_options = NULL;
- int i, i_options = 0;
+ int i_options = 0;
char *psz_name = NULL;
if( !ParseLine( psz_line, &psz_name, &ppsz_options, &i_options ) )
}
EnsureUTF8( psz_name );
-
- p_input = input_ItemNewExt( p_playlist, "dvb:", psz_name, 0, NULL, -1 );
- for( i = 0; i< i_options; i++ )
- {
+ for( int i = 0; i< i_options; i++ )
EnsureUTF8( ppsz_options[i] );
- input_ItemAddOption( p_input, ppsz_options[i] );
- }
- playlist_BothAddInput( p_playlist, p_input, p_item_in_category,
- PLAYLIST_APPEND | PLAYLIST_SPREPARSE,
- PLAYLIST_END, NULL, NULL, VLC_FALSE );
- while( i_options-- ) free( ppsz_options[i_options] );
- if( ppsz_options ) free( ppsz_options );
+ p_input = input_item_NewExt( p_demux, "dvb://", psz_name,
+ i_options, (const char**)ppsz_options, VLC_INPUT_OPTION_TRUSTED, -1 );
+ input_item_AddSubItem( p_current_input, p_input );
+ vlc_gc_decref( p_input );
+
+ while( i_options-- )
+ free( ppsz_options[i_options] );
+ free( ppsz_options );
free( psz_line );
}
- HANDLE_PLAY_AND_RELEASE;
- return -1; /* Needed for correct operation of go back */
+ vlc_gc_decref(p_current_input);
+ return 0; /* Needed for correct operation of go back */
}
-static struct
+static const struct
{
const char *psz_name;
const char *psz_option;
{ "QAM_64", "dvb-modulation=64" },
{ "QAM_128", "dvb-modulation=128" },
{ "QAM_256", "dvb-modulation=256" },
+ { "8VSB", "dvb-modulation=8" },
+ { "16VSB", "dvb-modulation=16" },
{ "TRANSMISSION_MODE_AUTO", "dvb-transmission=0" },
{ "TRANSMISSION_MODE_2K", "dvb-transmission=2" },
static int ParseLine( char *psz_line, char **ppsz_name,
char ***pppsz_options, int *pi_options )
{
- char *psz_name = 0, *psz_parse = psz_line;
- int i_count = 0, i_program = 0, i_frequency = 0;
- vlc_bool_t b_valid = VLC_FALSE;
+ char *psz_name = NULL, *psz_parse = psz_line;
+ int i_count = 0, i_program = 0, i_frequency = 0, i_symbolrate = 0;
+ bool b_valid = false;
- if( pppsz_options ) *pppsz_options = 0;
+ if( pppsz_options ) *pppsz_options = NULL;
if( pi_options ) *pi_options = 0;
- if( ppsz_name ) *ppsz_name = 0;
+ if( ppsz_name ) *ppsz_name = NULL;
/* Skip leading tabs and spaces */
while( *psz_parse == ' ' || *psz_parse == '\t' ||
*psz_parse == '\n' || *psz_parse == '\r' ) psz_parse++;
/* Ignore comments */
- if( *psz_parse == '#' ) return VLC_FALSE;
+ if( *psz_parse == '#' ) return false;
while( psz_parse )
{
- const char *psz_option = 0;
- char *psz_end = strchr( psz_parse, ':' );
- if( psz_end ) { *psz_end = 0; psz_end++; }
+ const char *psz_option = NULL;
+ char *psz_option_end = strchr( psz_parse, ':' );
+ if( psz_option_end ) { *psz_option_end = 0; psz_option_end++; }
if( i_count == 0 )
{
/* If we recognize one of the strings, then we are sure
* the data is really valid (ie. a channels file). */
- b_valid = VLC_TRUE;
+ b_valid = true;
break;
}
}
i_value = strtol( psz_parse, &psz_end, 10 );
if( psz_end != psz_parse &&
+ i_value != LONG_MAX && i_value != LONG_MIN &&
+ !i_symbolrate )
+ {
+ i_symbolrate = i_value;
+ }
+ else if( psz_end != psz_parse &&
i_value != LONG_MAX && i_value != LONG_MIN )
{
i_program = i_value;
psz_dup );
}
- psz_parse = psz_end;
+ psz_parse = psz_option_end;
i_count++;
}
{
/* This isn't a valid channels file, cleanup everything */
while( (*pi_options)-- ) free( (*pppsz_options)[*pi_options] );
- if( *pppsz_options ) free( *pppsz_options );
- *pppsz_options = 0; *pi_options = 0;
+ free( *pppsz_options );
+ *pppsz_options = NULL; *pi_options = 0;
}
if( i_program && pppsz_options && pi_options )
{
char *psz_option;
- asprintf( &psz_option, "program=%i", i_program );
- INSERT_ELEM( *pppsz_options, (*pi_options), (*pi_options),
- psz_option );
+ if( asprintf( &psz_option, "program=%i", i_program ) != -1 )
+ INSERT_ELEM( *pppsz_options, (*pi_options), (*pi_options),
+ psz_option );
}
if( i_frequency && pppsz_options && pi_options )
{
char *psz_option;
- asprintf( &psz_option, "dvb-frequency=%i", i_frequency );
- INSERT_ELEM( *pppsz_options, (*pi_options), (*pi_options),
- psz_option );
+ if( asprintf( &psz_option, "dvb-frequency=%i", i_frequency ) != -1 )
+ INSERT_ELEM( *pppsz_options, (*pi_options), (*pi_options),
+ psz_option );
+ }
+ if( i_symbolrate && pppsz_options && pi_options )
+ {
+ char *psz_option;
+
+ if( asprintf( &psz_option, "dvb-srate=%i", i_symbolrate ) != -1 )
+ INSERT_ELEM( *pppsz_options, (*pi_options), (*pi_options),
+ psz_option );
}
if( ppsz_name && psz_name ) *ppsz_name = strdup( psz_name );
static int Control( demux_t *p_demux, int i_query, va_list args )
{
+ VLC_UNUSED(p_demux); VLC_UNUSED(i_query); VLC_UNUSED(args);
return VLC_EGENERIC;
}