]> git.sesse.net Git - vlc/commitdiff
Remove ZPL demuxer
authorJean-Baptiste Kempf <jb@videolan.org>
Thu, 12 Mar 2015 10:12:45 +0000 (11:12 +0100)
committerJean-Baptiste Kempf <jb@videolan.org>
Thu, 12 Mar 2015 10:16:26 +0000 (11:16 +0100)
This is confusing with Zune Playlists and those are extremely rare

NEWS
modules/demux/Makefile.am
modules/demux/playlist/playlist.c
modules/demux/playlist/playlist.h
modules/demux/playlist/zpl.c [deleted file]

diff --git a/NEWS b/NEWS
index 1e11fd8f8d67bc07ce4819fd9134fc8a87fd523c..1afd6b2c4cae149f1825b4f119405e83e9c22a9a 100644 (file)
--- a/NEWS
+++ b/NEWS
@@ -106,6 +106,7 @@ Logging
 
 Misc
  * remove langfromtelx
+ * remove ZPL playlist format
 
 
 Changes between 2.1.x and 2.2.0:
index 9744282e721c26fa9c557abc465f9337eb0cae34..78dc9156ef015e37cf3220c333a4478e25b5241f 100644 (file)
@@ -222,7 +222,6 @@ libplaylist_plugin_la_SOURCES = \
        demux/playlist/shoutcast.c \
        demux/playlist/wpl.c \
        demux/playlist/xspf.c \
-       demux/playlist/zpl.c \
        demux/playlist/directory.c \
        demux/playlist/playlist.c demux/playlist/playlist.h
 demux_LTLIBRARIES += libplaylist_plugin.la
index f50d8b5d12d55404575b25c64112dbbbd33d1ea0..07e47e1b057d64f503fbce19ba46c9763584aacd 100644 (file)
@@ -140,11 +140,6 @@ vlc_module_begin ()
         add_shortcut( "playlist", "wpl" )
         set_capability( "demux", 10 )
         set_callbacks( Import_WPL, Close_WPL )
-    add_submodule ()
-        set_description( N_("ZPL playlist import") )
-        add_shortcut( "playlist", "zpl" )
-        set_capability( "demux", 10 )
-        set_callbacks( Import_ZPL, Close_ZPL )
     add_submodule ()
         set_description( N_("Directory import") )
         add_shortcut( "playlist", "directory" )
index 052e7c577c4c81024bc7a3ceed36e4db12ae1ce7..64245f2f8955a8117b98535bf26e7b8c2a0a165e 100644 (file)
@@ -74,9 +74,6 @@ void Close_iTML ( vlc_object_t * );
 int Import_WPL ( vlc_object_t * );
 void Close_WPL ( vlc_object_t * );
 
-int Import_ZPL ( vlc_object_t * );
-void Close_ZPL ( vlc_object_t * );
-
 int Import_Dir ( vlc_object_t * );
 void Close_Dir ( vlc_object_t * );
 
diff --git a/modules/demux/playlist/zpl.c b/modules/demux/playlist/zpl.c
deleted file mode 100644 (file)
index 12bbb8a..0000000
+++ /dev/null
@@ -1,246 +0,0 @@
-/*****************************************************************************
- * zpl.c : ZPL playlist format import
- *****************************************************************************
- * Copyright (C) 2009 the VideoLAN team
- *
- * Authors: Su Heaven <suheaven@gmail.com>
- *          RĂ©mi Duraffort <ivoire@videolan.org>
- *
- * This program is free software; you can redistribute it and/or modify it
- * under the terms of the GNU General Public License as published by the Free
- * Software Foundation; either version 2 of the License, or (at your option)
- * any later version.
- *
- * This program is distributed in the hope that it will be useful, but WITHOUT
- * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
- * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for
- * more details.
- *
- * You should have received a copy of the GNU General Public License along with
- * this program; if not, write to the Free Software Foundation, Inc., 51
- * Franklin Street, Fifth Floor, Boston MA 02110-1301, USA.
- *****************************************************************************/
-
-/*****************************************************************************
- * Preamble
- *****************************************************************************/
-
-#ifdef HAVE_CONFIG_H
-# include "config.h"
-#endif
-
-#include <vlc_common.h>
-#include <vlc_demux.h>
-
-#include "playlist.h"
-
-struct demux_sys_t
-{
-    char *psz_prefix;
-};
-
-/*****************************************************************************
- * Local prototypes
- *****************************************************************************/
-static int Demux( demux_t *p_demux);
-static char* ParseTabValue(char* psz_string);
-
-/*****************************************************************************
- * Import_ZPL: main import function
- *****************************************************************************/
-int Import_ZPL( vlc_object_t *p_this )
-{
-    demux_t *p_demux = (demux_t *)p_this;
-
-    if(! ( demux_IsPathExtension( p_demux, ".zpl" ) || demux_IsForced( p_demux,  "zpl" )))
-        return VLC_EGENERIC;
-
-    STANDARD_DEMUX_INIT_MSG( "found valid ZPL playlist" );
-    p_demux->p_sys->psz_prefix = FindPrefix( p_demux );
-
-    return VLC_SUCCESS;
-}
-
-
-/*****************************************************************************
- * Deactivate: frees unused data
- *****************************************************************************/
-void Close_ZPL( vlc_object_t *p_this )
-{
-    demux_t *p_demux = (demux_t *)p_this;
-    free( p_demux->p_sys->psz_prefix );
-    free( p_demux->p_sys );
-}
-
-static int Demux( demux_t *p_demux )
-{
-    char       *psz_line;
-
-    mtime_t i_duration = -1;
-    char *psz_title = NULL,       *psz_genre = NULL,      *psz_tracknum = NULL,
-         *psz_language = NULL,    *psz_artist = NULL,     *psz_album = NULL,
-         *psz_date = NULL,        *psz_publisher = NULL,  *psz_encodedby = NULL,
-         *psz_description = NULL, *psz_url = NULL,        *psz_copyright = NULL,
-         *psz_mrl = NULL;
-
-    input_item_t *p_current_input = GetCurrentItem(p_demux);
-
-    psz_line = stream_ReadLine( p_demux->s );
-    if( !psz_line )
-        return -1;
-
-    char *psz_parse = psz_line;
-
-    /* Skip leading tabs and spaces */
-    while( *psz_parse == ' '  || *psz_parse == '\t' ||
-           *psz_parse == '\n' || *psz_parse == '\r' )
-        psz_parse++;
-
-    /* if the 1st line is "AC", skip it */
-    /* TODO: using this information ? */
-    if( !strncasecmp( psz_parse, "AC", strlen( "AC" ) ) )
-    {
-        free( psz_line );
-        psz_line = stream_ReadLine( p_demux->s );
-    }
-
-    input_item_node_t *p_subitems = input_item_node_Create( p_current_input );
-
-    /* Loop on all lines */
-    while( psz_line )
-    {
-        psz_parse = psz_line;
-
-        /* Skip leading tabs and spaces */
-        while( *psz_parse == ' '  || *psz_parse == '\t' ||
-               *psz_parse == '\n' || *psz_parse == '\r' )
-            psz_parse++;
-
-        /* filename */
-        if( !strncasecmp( psz_parse, "NM", strlen( "NM" ) ) )
-        {
-            char *psz_tabvalue = ParseTabValue( psz_parse );
-            if( !EMPTY_STR(psz_tabvalue) )
-            {
-                free( psz_mrl );
-                psz_mrl = ProcessMRL( psz_tabvalue, p_demux->p_sys->psz_prefix );
-            }
-            free( psz_tabvalue );
-        }
-
-        /* duration */
-        else if( !strncasecmp( psz_parse, "DR", strlen( "DR" ) ) )
-        {
-            char *psz_tabvalue = ParseTabValue( psz_parse );
-            if( !EMPTY_STR(psz_tabvalue) )
-            {
-                int i_parsed_duration = atoi( psz_tabvalue );
-                if( i_parsed_duration >= 0 )
-                    i_duration = i_parsed_duration * INT64_C(1000);
-            }
-            free( psz_tabvalue );
-        }
-
-#define PARSE(tag,variable)                                     \
-    else if( !strncasecmp( psz_parse, tag, strlen( tag ) ) )    \
-    {                                                           \
-        free( variable );                                       \
-        variable = ParseTabValue( psz_parse );                  \
-    }
-
-        PARSE( "TT", psz_title )
-        PARSE( "TG", psz_genre )
-        PARSE( "TR", psz_tracknum )
-        PARSE( "TL", psz_language )
-        PARSE( "TA", psz_artist )
-        PARSE( "TB", psz_album )
-        PARSE( "TY", psz_date )
-        PARSE( "TH", psz_publisher )
-        PARSE( "TE", psz_encodedby )
-        PARSE( "TC", psz_description )
-        PARSE( "TU", psz_url )
-        PARSE( "TO", psz_copyright )
-
-#undef PARSE
-
-        /* force a duration ? */
-        else if( !strncasecmp( psz_parse, "FD", strlen( "FD" ) ) )
-        {}
-
-        /* end of file entry */
-        else if( !strncasecmp( psz_parse, "BR!", strlen( "BR!" ) ) )
-        {
-            /* create the input item */
-            input_item_t *p_input = input_item_NewExt( psz_mrl,
-                                        psz_title, 0, NULL, 0, i_duration );
-            input_item_node_AppendItem( p_subitems, p_input );
-            FREENULL( psz_mrl );
-            FREENULL( psz_title );
-            i_duration = -1;
-
-#define SET(variable, type)                             \
-    if( !EMPTY_STR(variable) )                          \
-    {                                                   \
-        input_item_Set##type( p_input, variable );      \
-    }                                                   \
-    FREENULL( variable );
-            /* set the meta */
-            SET( psz_genre, Genre );
-            SET( psz_tracknum, TrackNum );
-            SET( psz_language, Language );
-            SET( psz_artist, Artist );
-            SET( psz_album, Album );
-            SET( psz_date, Date );
-            SET( psz_encodedby, EncodedBy );
-            SET( psz_description, Description );
-            SET( psz_copyright, Copyright );
-            SET( psz_url, URL );
-            SET( psz_publisher, Publisher );
-#undef SET
-
-            vlc_gc_decref( p_input );
-        }
-        else
-            msg_Warn( p_demux, "invalid line '%s'", psz_parse );
-
-        /* Fetch another line */
-        free( psz_line );
-        psz_line = stream_ReadLine( p_demux->s );
-    }
-
-    input_item_node_PostAndDelete( p_subitems );
-
-    vlc_gc_decref(p_current_input);
-
-    // Free everything if the file is wrongly formated
-    free( psz_title );
-    free( psz_genre );
-    free( psz_tracknum );
-    free( psz_language );
-    free( psz_artist );
-    free( psz_album );
-    free( psz_date );
-    free( psz_publisher );
-    free( psz_encodedby );
-    free( psz_description );
-    free( psz_url );
-    free( psz_copyright );
-    free( psz_mrl );
-
-    var_Destroy( p_demux, "zpl-extvlcopt" );
-    return 0; /* Needed for correct operation of go back */
-}
-
-static char* ParseTabValue(char* psz_string)
-{
-    int i_len = strlen( psz_string );
-    if(i_len <= 3 )
-        return NULL;
-    char* psz_value = calloc( i_len, 1 );
-    if( ! psz_value )
-        return NULL;
-
-    sscanf( psz_string,"%*[^=]=%[^\r\t\n]", psz_value );
-
-    return psz_value;
-}