]> git.sesse.net Git - vlc/commitdiff
Export vlc's xml api.
authorAntoine Cellerier <dionoea@videolan.org>
Sat, 13 Feb 2010 13:54:04 +0000 (14:54 +0100)
committerAntoine Cellerier <dionoea@videolan.org>
Sat, 13 Feb 2010 15:40:46 +0000 (16:40 +0100)
modules/misc/lua/Modules.am
modules/misc/lua/demux.c
modules/misc/lua/extension.c
modules/misc/lua/intf.c
modules/misc/lua/libs.h
modules/misc/lua/libs/xml.c [new file with mode: 0644]
modules/misc/lua/meta.c

index f7c5b1c1a7f092a2f20161fdd6d3260a06d863e2..c2105c7f1dd4419c594cdb661b5e3b9c794c2585 100644 (file)
@@ -33,6 +33,7 @@ SOURCES_lua = \
        libs/video.c \
        libs/vlm.c \
        libs/volume.c \
+       libs/xml.c \
        $(NULL)
 
 libvlc_LTLIBRARIES += liblua_plugin.la
index 66a750157c8787ce20d0fd309f717b8775338216..1ffc049347a7f4d4f71a478004b63ded3882904f 100644 (file)
@@ -138,6 +138,7 @@ static int probe_luascript( vlc_object_t *p_this, const char * psz_filename,
     luaL_register( L, "vlc", p_reg );
     luaopen_msg( L );
     luaopen_strings( L );
+    luaopen_xml( L );
     lua_pushlightuserdata( L, p_demux );
     lua_setfield( L, -2, "private" );
     lua_pushstring( L, p_demux->psz_path );
index 139f5f674a8b1ee48c2957373f21f82b3fcb0356..18a0b30bca0789eb925f33188e6f955eef5c74c3 100644 (file)
@@ -736,6 +736,7 @@ static lua_State* GetLuaState( extensions_manager_t *p_mgr,
             luaopen_video( L );
             luaopen_vlm( L );
             luaopen_volume( L );
+            luaopen_xml( L );
 
             /* Register extension specific functions */
             lua_getglobal( L, "vlc" );
index 6ee073e07797198db4c62c652f0c930a9c4b55aa..ead86d8e5158f851a8301f7e6e55ab8ac85a87db 100644 (file)
@@ -197,6 +197,7 @@ int Open_LuaIntf( vlc_object_t *p_this )
     luaopen_vlm( L );
     luaopen_volume( L );
     luaopen_gettext( L );
+    luaopen_xml( L );
 
     /* clean up */
     lua_pop( L, 1 );
index 60f6ccfafa40a3413d973d93704380e138e5eff6..18f884ec139e15ea695989247ea6f194903bd96b 100644 (file)
@@ -44,5 +44,6 @@ void luaopen_vlm( lua_State * );
 void luaopen_volume( lua_State * );
 void luaopen_gettext( lua_State * );
 void luaopen_input_item( lua_State *L, input_item_t *item );
+void luaopen_xml( lua_State *L );
 
 #endif
diff --git a/modules/misc/lua/libs/xml.c b/modules/misc/lua/libs/xml.c
new file mode 100644 (file)
index 0000000..cd65561
--- /dev/null
@@ -0,0 +1,205 @@
+/*****************************************************************************
+ * xml.c: XML related functions
+ *****************************************************************************
+ * Copyright (C) 2010 Antoine Cellerier
+ * $Id$
+ *
+ * Authors: Antoine Cellerier <dionoea at videolan tod 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
+ *****************************************************************************/
+#ifndef  _GNU_SOURCE
+#   define  _GNU_SOURCE
+#endif
+
+#ifdef HAVE_CONFIG_H
+# include "config.h"
+#endif
+
+#include <vlc_common.h>
+#include <vlc_xml.h>
+
+#include <lua.h>        /* Low level lua C API */
+#include <lauxlib.h>    /* Higher level C API */
+
+#include "../vlc.h"
+#include "../libs.h"
+
+/*****************************************************************************
+ * XML
+ *****************************************************************************/
+static int vlclua_xml_create_reader( lua_State * );
+static int vlclua_xml_load_catalog( lua_State * );
+static int vlclua_xml_add_catalog( lua_State * );
+
+static const luaL_Reg vlclua_xml_reg[] = {
+    { "create_reader", vlclua_xml_create_reader },
+    { "load_catalog", vlclua_xml_load_catalog },
+    { "add_catalog", vlclua_xml_add_catalog },
+    { NULL, NULL }
+};
+
+static int vlclua_xml_delete( lua_State *L )
+{
+    xml_t *p_xml = *(xml_t**)luaL_checkudata( L, 1, "xml" );
+    xml_Delete( p_xml );
+    return 0;
+}
+
+static int vlclua_xml_create( lua_State *L )
+{
+    xml_t *p_xml = xml_Create( vlclua_get_this( L ) );
+    if( !p_xml )
+        return luaL_error( L, "XML module creation failed." );
+
+    xml_t **pp_xml = lua_newuserdata( L, sizeof( xml_t * ) );
+    *pp_xml = p_xml;
+
+    if( luaL_newmetatable( L, "xml" ) )
+    {
+        lua_newtable( L );
+        luaL_register( L, NULL, vlclua_xml_reg );
+        lua_setfield( L, -2, "__index" );
+        lua_pushcfunction( L, vlclua_xml_delete );
+        lua_setfield( L, -2, "__gc" );
+    }
+
+    lua_setmetatable( L, -2 );
+    return 1;
+}
+
+static int vlclua_xml_load_catalog( lua_State *L )
+{
+    xml_t *p_xml = *(xml_t**)luaL_checkudata( L, 1, "xml" );
+    const char *psz_catalog = luaL_checkstring( L, 2 );
+    xml_CatalogLoad( p_xml, psz_catalog );
+    return 0;
+}
+
+static int vlclua_xml_add_catalog( lua_State *L )
+{
+    xml_t *p_xml = *(xml_t**)luaL_checkudata( L, 1, "xml" );
+    const char *psz_str1 = luaL_checkstring( L, 2 );
+    const char *psz_str2 = luaL_checkstring( L, 3 );
+    const char *psz_str3 = luaL_checkstring( L, 4 );
+    xml_CatalogAdd( p_xml, psz_str1, psz_str2, psz_str3 );
+    return 0;
+}
+
+/*****************************************************************************
+ * XML Reader
+ *****************************************************************************/
+static int vlclua_xml_reader_read( lua_State * );
+static int vlclua_xml_reader_node_type( lua_State * );
+static int vlclua_xml_reader_name( lua_State * );
+static int vlclua_xml_reader_value( lua_State * );
+static int vlclua_xml_reader_next_attr( lua_State * );
+static int vlclua_xml_reader_use_dtd( lua_State * );
+
+static const luaL_Reg vlclua_xml_reader_reg[] = {
+    { "read", vlclua_xml_reader_read },
+    { "node_type", vlclua_xml_reader_node_type },
+    { "name", vlclua_xml_reader_name },
+    { "value", vlclua_xml_reader_value },
+    { "next_attr", vlclua_xml_reader_next_attr },
+    { "use_dtd", vlclua_xml_reader_use_dtd },
+    { NULL, NULL }
+};
+
+static int vlclua_xml_reader_delete( lua_State *L )
+{
+    xml_reader_t *p_reader = *(xml_reader_t**)luaL_checkudata( L, 1, "xml_reader" );
+    xml_ReaderDelete( p_reader->p_xml, p_reader );
+    return 0;
+}
+
+static int vlclua_xml_create_reader( lua_State *L )
+{
+    xml_t *p_xml = *(xml_t**)luaL_checkudata( L, 1, "xml" );
+    stream_t *p_stream = *(stream_t **)luaL_checkudata( L, 2, "stream" );
+
+    xml_reader_t *p_reader = xml_ReaderCreate( p_xml, p_stream );
+    if( !p_reader )
+        return luaL_error( L, "XML reader creation failed." );
+
+    xml_reader_t **pp_reader = lua_newuserdata( L, sizeof( xml_reader_t * ) );
+    *pp_reader = p_reader;
+
+    if( luaL_newmetatable( L, "xml_reader" ) )
+    {
+        lua_newtable( L );
+        luaL_register( L, NULL, vlclua_xml_reader_reg );
+        lua_setfield( L, -2, "__index" );
+        lua_pushcfunction( L, vlclua_xml_reader_delete );
+        lua_setfield( L, -2, "__gc" );
+    }
+
+    lua_setmetatable( L, -2 );
+    return 1;
+}
+
+static int vlclua_xml_reader_read( lua_State *L )
+{
+    xml_reader_t *p_reader = *(xml_reader_t**)luaL_checkudata( L, 1, "xml_reader" );
+    lua_pushinteger( L, xml_ReaderRead( p_reader ) );
+    return 1;
+}
+
+static int vlclua_xml_reader_node_type( lua_State *L )
+{
+    xml_reader_t *p_reader = *(xml_reader_t**)luaL_checkudata( L, 1, "xml_reader" );
+    static const char *ppsz_type[] = { "none", "startelem", "endelem", "text" };
+    lua_pushstring( L, ppsz_type[xml_ReaderNodeType( p_reader )] );
+    return 1;
+}
+
+static int vlclua_xml_reader_name( lua_State *L )
+{
+    xml_reader_t *p_reader = *(xml_reader_t**)luaL_checkudata( L, 1, "xml_reader" );
+    lua_pushstring( L, xml_ReaderName( p_reader ) );
+    return 1;
+}
+
+static int vlclua_xml_reader_value( lua_State *L )
+{
+    xml_reader_t *p_reader = *(xml_reader_t**)luaL_checkudata( L, 1, "xml_reader" );
+    lua_pushstring( L, xml_ReaderValue( p_reader ) );
+    return 1;
+}
+
+static int vlclua_xml_reader_next_attr( lua_State *L )
+{
+    xml_reader_t *p_reader = *(xml_reader_t**)luaL_checkudata( L, 1, "xml_reader" );
+    lua_pushinteger( L, xml_ReaderNextAttr( p_reader ) );
+    return 1;
+}
+
+static int vlclua_xml_reader_use_dtd( lua_State *L )
+{
+    xml_reader_t *p_reader = *(xml_reader_t**)luaL_checkudata( L, 1, "xml_reader" );
+    bool b_value = lua_toboolean( L, 2 );
+    lua_pushinteger( L, xml_ReaderUseDTD( p_reader, b_value ) );
+    return 1;
+}
+
+void luaopen_xml( lua_State *L )
+{
+    lua_pushcfunction( L, vlclua_xml_create );
+    lua_setfield( L, -2, "xml" );
+}
index f2b619d90e645f3d522bf34195aecad4ac1b8f0e..0cd6e860d4e50befb4d53e9de26e061a82ac715c 100644 (file)
@@ -71,6 +71,7 @@ static lua_State * init( vlc_object_t *p_this, input_item_t * p_item, const char
     luaopen_variables( L );
     luaopen_object( L );
     luaopen_misc( L );
+    luaopen_xml( L );
     luaopen_input_item( L, p_item );
 
     lua_pushlightuserdata( L, p_this );