2006-02-14 23:50:13 +01:00
|
|
|
/*****************************************************************************
|
|
|
|
* vlm.c: libvlc new API VLM handling functions
|
|
|
|
*****************************************************************************
|
LGPL
Re-license almost all of libVLC and libVLCcore to LGPLv2.1+
This move was authorized by the developers, either:
- by e-mail,
- by vote at the VideoLAN Dev Days 2011,
- on the license website,
- in a contract, oral or written.
No objection was raised, so far.
The developers agreeing are:
Justus Piater
Alexis Ballier
Alexander Bethke
Mohammed Adnène Trojette
Alex Converse
Alexey Sokolov
Alexis de Lattre
Andre Pang
Anthony Loiseau
Cyril Deguet
André Weber
Boris Dorès
Brieuc Jeunhomme
Benjamin Drung
Hugo Beauzée-Luyssen
Benoit Steiner
Benjamin Pracht
Bernie Purcell
Przemyslaw Fiala
Arnaud de Bossoreille de Ribou
Brad Smith
Nick Briggs
Christopher Rath
Christophe Courtaut
Christopher Mueller
Clement Chesnin
Andres Krapf
Damien Fouilleul
David Flynn
Sebastien Zwickert
Antoine Cellerier
Jérôme Decoodt
Jérome Decoodt
Dylan Yudaken
Eduard Babayan
Eugenio Jarosiewicz
Elliot Murphy
Eric Petit
Erwan Tulou
Etienne Membrives
Ludovic Fauvet
Fabio Ritrovato
Tobias Güntner
Jakub Wieczorek
Frédéric Crozat
Francois Cartegnie
Laurent Aimar
Florian G. Pflug
Felix Paul Kühne
Frank Enderle
Rafaël Carré
Simon Latapie
Gildas Bazin
Geoffroy Couprie
Julien / Gellule
Gildas Bazin
Arnaud Schauly
Toralf Niebuhr
Vicente Jimenez Aguilar
Derk-Jan Hartman
Henri Fallon
Ilkka Ollakka
Olivier Teulière
Rémi Duraffort
Jakob Leben
Jean-Baptiste Kempf
Jean-Paul Saman
Jean-Philippe Grimaldi
Jean-François Massol
Gaël Hendryckx
Jakob Leben
Jean-Marc Dressler
Jai Menon
Johan Bilien
Johann Ransay
Joris van Rooij
JP Dinger
Jean-Philippe André
Adrien Grand
Juha Jeronen
Juho Vähä-Herttua
Kaarlo Raiha
Kaarlo Raiha
Kamil Baldyga
Keary Griffin
Ken Self
KO Myung-Hun
Pierre Ynard
Filippo Carone
Loïc Minier
Luca Barbato
Lucas C. Villa Real
Lukas Durfina
Adrien Maglo
Marc Ariberti
Mark Lee
Mark Moriarty
Martin Storsjö
Christophe Massiot
Michel Kaempf
Marian Ďurkovič
Mirsal Ennaime
Carlo Calabrò
Damien Lucas
Naohiro Koriyama
Basos G
Pierre Baillet
Vincent Penquerc'h
Olivier Aubert
Pankaj Yadav
Paul Corke
Pierre d'Herbemont
Philippe Morin
Antoine Lejeune
Michael Ploujnikov
Jean-Marc Dressler
Michael Hanselmann
Rafaël Carré
Ramiro Polla
Rémi Denis-Courmont
Renaud Dartus
Richard Shepherd
Faustino Osuna
Arnaud Vallat
Rob Jonson
Robert Jedrzejczyk
Steve Lhomme
Rocky Bernstein
Romain Goyet
Rov Juvano
Sam Hocevar
Martin T. H. Sandsmark
Sebastian Birk
Sébastien Escudier
Vincent Seguin
Fabio Ritrovato
Sigmund Augdal Helberg
Casian Andrei
Srikanth Raju
Hannes Domani
Stéphane Borel
Stephan Krempel
Stephan Assmus
Tony Castley
Pavlov Konstantin
Eric Petit
Tanguy Krotoff
Dennis van Amerongen
Michel Lespinasse
Can Wu
Xavier Marchesini
Sébastien Toque
Christophe Mutricy
Yoann Peronneau
Yohann Martineau
Yuval Tze
Scott Caudle
Clément Stenac
It is possible, that some minor piece of code was badly tracked, for
some reasons (SVN, mainly) or that some small developers did not answer.
However, as an "œuvre collective", defined as in "CPI 113-2 alinéa 3",
and seeing "Cour. Cass. 17 Mai 1978", and seeing that the editor and
the very vast majority of developers have agreed (> 99.99% of the code,
> 99% of developers), we are fine here.
2011-11-27 21:44:15 +01:00
|
|
|
* Copyright (C) 2005 VLC authors and VideoLAN
|
2008-01-16 11:21:11 +01:00
|
|
|
* $Id$
|
2006-02-14 23:50:13 +01:00
|
|
|
*
|
|
|
|
* Authors: Clément Stenac <zorglub@videolan.org>
|
|
|
|
*
|
LGPL
Re-license almost all of libVLC and libVLCcore to LGPLv2.1+
This move was authorized by the developers, either:
- by e-mail,
- by vote at the VideoLAN Dev Days 2011,
- on the license website,
- in a contract, oral or written.
No objection was raised, so far.
The developers agreeing are:
Justus Piater
Alexis Ballier
Alexander Bethke
Mohammed Adnène Trojette
Alex Converse
Alexey Sokolov
Alexis de Lattre
Andre Pang
Anthony Loiseau
Cyril Deguet
André Weber
Boris Dorès
Brieuc Jeunhomme
Benjamin Drung
Hugo Beauzée-Luyssen
Benoit Steiner
Benjamin Pracht
Bernie Purcell
Przemyslaw Fiala
Arnaud de Bossoreille de Ribou
Brad Smith
Nick Briggs
Christopher Rath
Christophe Courtaut
Christopher Mueller
Clement Chesnin
Andres Krapf
Damien Fouilleul
David Flynn
Sebastien Zwickert
Antoine Cellerier
Jérôme Decoodt
Jérome Decoodt
Dylan Yudaken
Eduard Babayan
Eugenio Jarosiewicz
Elliot Murphy
Eric Petit
Erwan Tulou
Etienne Membrives
Ludovic Fauvet
Fabio Ritrovato
Tobias Güntner
Jakub Wieczorek
Frédéric Crozat
Francois Cartegnie
Laurent Aimar
Florian G. Pflug
Felix Paul Kühne
Frank Enderle
Rafaël Carré
Simon Latapie
Gildas Bazin
Geoffroy Couprie
Julien / Gellule
Gildas Bazin
Arnaud Schauly
Toralf Niebuhr
Vicente Jimenez Aguilar
Derk-Jan Hartman
Henri Fallon
Ilkka Ollakka
Olivier Teulière
Rémi Duraffort
Jakob Leben
Jean-Baptiste Kempf
Jean-Paul Saman
Jean-Philippe Grimaldi
Jean-François Massol
Gaël Hendryckx
Jakob Leben
Jean-Marc Dressler
Jai Menon
Johan Bilien
Johann Ransay
Joris van Rooij
JP Dinger
Jean-Philippe André
Adrien Grand
Juha Jeronen
Juho Vähä-Herttua
Kaarlo Raiha
Kaarlo Raiha
Kamil Baldyga
Keary Griffin
Ken Self
KO Myung-Hun
Pierre Ynard
Filippo Carone
Loïc Minier
Luca Barbato
Lucas C. Villa Real
Lukas Durfina
Adrien Maglo
Marc Ariberti
Mark Lee
Mark Moriarty
Martin Storsjö
Christophe Massiot
Michel Kaempf
Marian Ďurkovič
Mirsal Ennaime
Carlo Calabrò
Damien Lucas
Naohiro Koriyama
Basos G
Pierre Baillet
Vincent Penquerc'h
Olivier Aubert
Pankaj Yadav
Paul Corke
Pierre d'Herbemont
Philippe Morin
Antoine Lejeune
Michael Ploujnikov
Jean-Marc Dressler
Michael Hanselmann
Rafaël Carré
Ramiro Polla
Rémi Denis-Courmont
Renaud Dartus
Richard Shepherd
Faustino Osuna
Arnaud Vallat
Rob Jonson
Robert Jedrzejczyk
Steve Lhomme
Rocky Bernstein
Romain Goyet
Rov Juvano
Sam Hocevar
Martin T. H. Sandsmark
Sebastian Birk
Sébastien Escudier
Vincent Seguin
Fabio Ritrovato
Sigmund Augdal Helberg
Casian Andrei
Srikanth Raju
Hannes Domani
Stéphane Borel
Stephan Krempel
Stephan Assmus
Tony Castley
Pavlov Konstantin
Eric Petit
Tanguy Krotoff
Dennis van Amerongen
Michel Lespinasse
Can Wu
Xavier Marchesini
Sébastien Toque
Christophe Mutricy
Yoann Peronneau
Yohann Martineau
Yuval Tze
Scott Caudle
Clément Stenac
It is possible, that some minor piece of code was badly tracked, for
some reasons (SVN, mainly) or that some small developers did not answer.
However, as an "œuvre collective", defined as in "CPI 113-2 alinéa 3",
and seeing "Cour. Cass. 17 Mai 1978", and seeing that the editor and
the very vast majority of developers have agreed (> 99.99% of the code,
> 99% of developers), we are fine here.
2011-11-27 21:44:15 +01:00
|
|
|
* This program is free software; you can redistribute it and/or modify it
|
|
|
|
* under the terms of the GNU Lesser General Public License as published by
|
|
|
|
* the Free Software Foundation; either version 2.1 of the License, or
|
2006-02-14 23:50:13 +01:00
|
|
|
* (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
|
LGPL
Re-license almost all of libVLC and libVLCcore to LGPLv2.1+
This move was authorized by the developers, either:
- by e-mail,
- by vote at the VideoLAN Dev Days 2011,
- on the license website,
- in a contract, oral or written.
No objection was raised, so far.
The developers agreeing are:
Justus Piater
Alexis Ballier
Alexander Bethke
Mohammed Adnène Trojette
Alex Converse
Alexey Sokolov
Alexis de Lattre
Andre Pang
Anthony Loiseau
Cyril Deguet
André Weber
Boris Dorès
Brieuc Jeunhomme
Benjamin Drung
Hugo Beauzée-Luyssen
Benoit Steiner
Benjamin Pracht
Bernie Purcell
Przemyslaw Fiala
Arnaud de Bossoreille de Ribou
Brad Smith
Nick Briggs
Christopher Rath
Christophe Courtaut
Christopher Mueller
Clement Chesnin
Andres Krapf
Damien Fouilleul
David Flynn
Sebastien Zwickert
Antoine Cellerier
Jérôme Decoodt
Jérome Decoodt
Dylan Yudaken
Eduard Babayan
Eugenio Jarosiewicz
Elliot Murphy
Eric Petit
Erwan Tulou
Etienne Membrives
Ludovic Fauvet
Fabio Ritrovato
Tobias Güntner
Jakub Wieczorek
Frédéric Crozat
Francois Cartegnie
Laurent Aimar
Florian G. Pflug
Felix Paul Kühne
Frank Enderle
Rafaël Carré
Simon Latapie
Gildas Bazin
Geoffroy Couprie
Julien / Gellule
Gildas Bazin
Arnaud Schauly
Toralf Niebuhr
Vicente Jimenez Aguilar
Derk-Jan Hartman
Henri Fallon
Ilkka Ollakka
Olivier Teulière
Rémi Duraffort
Jakob Leben
Jean-Baptiste Kempf
Jean-Paul Saman
Jean-Philippe Grimaldi
Jean-François Massol
Gaël Hendryckx
Jakob Leben
Jean-Marc Dressler
Jai Menon
Johan Bilien
Johann Ransay
Joris van Rooij
JP Dinger
Jean-Philippe André
Adrien Grand
Juha Jeronen
Juho Vähä-Herttua
Kaarlo Raiha
Kaarlo Raiha
Kamil Baldyga
Keary Griffin
Ken Self
KO Myung-Hun
Pierre Ynard
Filippo Carone
Loïc Minier
Luca Barbato
Lucas C. Villa Real
Lukas Durfina
Adrien Maglo
Marc Ariberti
Mark Lee
Mark Moriarty
Martin Storsjö
Christophe Massiot
Michel Kaempf
Marian Ďurkovič
Mirsal Ennaime
Carlo Calabrò
Damien Lucas
Naohiro Koriyama
Basos G
Pierre Baillet
Vincent Penquerc'h
Olivier Aubert
Pankaj Yadav
Paul Corke
Pierre d'Herbemont
Philippe Morin
Antoine Lejeune
Michael Ploujnikov
Jean-Marc Dressler
Michael Hanselmann
Rafaël Carré
Ramiro Polla
Rémi Denis-Courmont
Renaud Dartus
Richard Shepherd
Faustino Osuna
Arnaud Vallat
Rob Jonson
Robert Jedrzejczyk
Steve Lhomme
Rocky Bernstein
Romain Goyet
Rov Juvano
Sam Hocevar
Martin T. H. Sandsmark
Sebastian Birk
Sébastien Escudier
Vincent Seguin
Fabio Ritrovato
Sigmund Augdal Helberg
Casian Andrei
Srikanth Raju
Hannes Domani
Stéphane Borel
Stephan Krempel
Stephan Assmus
Tony Castley
Pavlov Konstantin
Eric Petit
Tanguy Krotoff
Dennis van Amerongen
Michel Lespinasse
Can Wu
Xavier Marchesini
Sébastien Toque
Christophe Mutricy
Yoann Peronneau
Yohann Martineau
Yuval Tze
Scott Caudle
Clément Stenac
It is possible, that some minor piece of code was badly tracked, for
some reasons (SVN, mainly) or that some small developers did not answer.
However, as an "œuvre collective", defined as in "CPI 113-2 alinéa 3",
and seeing "Cour. Cass. 17 Mai 1978", and seeing that the editor and
the very vast majority of developers have agreed (> 99.99% of the code,
> 99% of developers), we are fine here.
2011-11-27 21:44:15 +01:00
|
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
|
|
* GNU Lesser General Public License for more details.
|
2006-02-14 23:50:13 +01:00
|
|
|
*
|
LGPL
Re-license almost all of libVLC and libVLCcore to LGPLv2.1+
This move was authorized by the developers, either:
- by e-mail,
- by vote at the VideoLAN Dev Days 2011,
- on the license website,
- in a contract, oral or written.
No objection was raised, so far.
The developers agreeing are:
Justus Piater
Alexis Ballier
Alexander Bethke
Mohammed Adnène Trojette
Alex Converse
Alexey Sokolov
Alexis de Lattre
Andre Pang
Anthony Loiseau
Cyril Deguet
André Weber
Boris Dorès
Brieuc Jeunhomme
Benjamin Drung
Hugo Beauzée-Luyssen
Benoit Steiner
Benjamin Pracht
Bernie Purcell
Przemyslaw Fiala
Arnaud de Bossoreille de Ribou
Brad Smith
Nick Briggs
Christopher Rath
Christophe Courtaut
Christopher Mueller
Clement Chesnin
Andres Krapf
Damien Fouilleul
David Flynn
Sebastien Zwickert
Antoine Cellerier
Jérôme Decoodt
Jérome Decoodt
Dylan Yudaken
Eduard Babayan
Eugenio Jarosiewicz
Elliot Murphy
Eric Petit
Erwan Tulou
Etienne Membrives
Ludovic Fauvet
Fabio Ritrovato
Tobias Güntner
Jakub Wieczorek
Frédéric Crozat
Francois Cartegnie
Laurent Aimar
Florian G. Pflug
Felix Paul Kühne
Frank Enderle
Rafaël Carré
Simon Latapie
Gildas Bazin
Geoffroy Couprie
Julien / Gellule
Gildas Bazin
Arnaud Schauly
Toralf Niebuhr
Vicente Jimenez Aguilar
Derk-Jan Hartman
Henri Fallon
Ilkka Ollakka
Olivier Teulière
Rémi Duraffort
Jakob Leben
Jean-Baptiste Kempf
Jean-Paul Saman
Jean-Philippe Grimaldi
Jean-François Massol
Gaël Hendryckx
Jakob Leben
Jean-Marc Dressler
Jai Menon
Johan Bilien
Johann Ransay
Joris van Rooij
JP Dinger
Jean-Philippe André
Adrien Grand
Juha Jeronen
Juho Vähä-Herttua
Kaarlo Raiha
Kaarlo Raiha
Kamil Baldyga
Keary Griffin
Ken Self
KO Myung-Hun
Pierre Ynard
Filippo Carone
Loïc Minier
Luca Barbato
Lucas C. Villa Real
Lukas Durfina
Adrien Maglo
Marc Ariberti
Mark Lee
Mark Moriarty
Martin Storsjö
Christophe Massiot
Michel Kaempf
Marian Ďurkovič
Mirsal Ennaime
Carlo Calabrò
Damien Lucas
Naohiro Koriyama
Basos G
Pierre Baillet
Vincent Penquerc'h
Olivier Aubert
Pankaj Yadav
Paul Corke
Pierre d'Herbemont
Philippe Morin
Antoine Lejeune
Michael Ploujnikov
Jean-Marc Dressler
Michael Hanselmann
Rafaël Carré
Ramiro Polla
Rémi Denis-Courmont
Renaud Dartus
Richard Shepherd
Faustino Osuna
Arnaud Vallat
Rob Jonson
Robert Jedrzejczyk
Steve Lhomme
Rocky Bernstein
Romain Goyet
Rov Juvano
Sam Hocevar
Martin T. H. Sandsmark
Sebastian Birk
Sébastien Escudier
Vincent Seguin
Fabio Ritrovato
Sigmund Augdal Helberg
Casian Andrei
Srikanth Raju
Hannes Domani
Stéphane Borel
Stephan Krempel
Stephan Assmus
Tony Castley
Pavlov Konstantin
Eric Petit
Tanguy Krotoff
Dennis van Amerongen
Michel Lespinasse
Can Wu
Xavier Marchesini
Sébastien Toque
Christophe Mutricy
Yoann Peronneau
Yohann Martineau
Yuval Tze
Scott Caudle
Clément Stenac
It is possible, that some minor piece of code was badly tracked, for
some reasons (SVN, mainly) or that some small developers did not answer.
However, as an "œuvre collective", defined as in "CPI 113-2 alinéa 3",
and seeing "Cour. Cass. 17 Mai 1978", and seeing that the editor and
the very vast majority of developers have agreed (> 99.99% of the code,
> 99% of developers), we are fine here.
2011-11-27 21:44:15 +01:00
|
|
|
* You should have received a copy of the GNU Lesser 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.
|
2006-02-14 23:50:13 +01:00
|
|
|
*****************************************************************************/
|
|
|
|
|
2009-08-15 14:57:23 +02:00
|
|
|
#ifdef HAVE_CONFIG_H
|
|
|
|
# include <config.h>
|
|
|
|
#endif
|
|
|
|
|
2006-02-14 23:50:13 +01:00
|
|
|
#include <vlc/libvlc.h>
|
2009-05-25 10:47:38 +02:00
|
|
|
#include <vlc/libvlc_vlm.h>
|
2006-03-12 10:27:48 +01:00
|
|
|
#include <vlc_es.h>
|
2006-02-14 23:50:13 +01:00
|
|
|
#include <vlc_input.h>
|
2007-05-21 21:15:54 +02:00
|
|
|
#include <vlc_vlm.h>
|
2009-09-07 21:13:49 +02:00
|
|
|
#include <assert.h>
|
2006-02-14 23:50:13 +01:00
|
|
|
|
2009-05-25 10:47:38 +02:00
|
|
|
#include "libvlc_internal.h"
|
|
|
|
|
2009-05-18 14:17:53 +02:00
|
|
|
/* VLM events callback. Transmit to libvlc */
|
|
|
|
static int VlmEvent( vlc_object_t *p_this, const char * name,
|
|
|
|
vlc_value_t old_val, vlc_value_t newval, void *param )
|
|
|
|
{
|
2009-08-20 12:01:12 +02:00
|
|
|
VLC_UNUSED(p_this);
|
|
|
|
VLC_UNUSED(name);
|
|
|
|
VLC_UNUSED(old_val);
|
2009-05-18 14:17:53 +02:00
|
|
|
vlm_event_t *event = (vlm_event_t*)newval.p_address;
|
|
|
|
libvlc_event_manager_t *p_event_manager = (libvlc_event_manager_t *) param;
|
|
|
|
libvlc_event_t libvlc_event;
|
|
|
|
|
2009-07-07 14:12:40 +02:00
|
|
|
libvlc_event.u.vlm_media_event.psz_instance_name = NULL;
|
2009-05-18 14:17:53 +02:00
|
|
|
libvlc_event.u.vlm_media_event.psz_media_name = event->psz_name;
|
|
|
|
|
|
|
|
switch( event->i_type )
|
|
|
|
{
|
|
|
|
case VLM_EVENT_MEDIA_ADDED:
|
|
|
|
libvlc_event.type = libvlc_VlmMediaAdded;
|
|
|
|
break;
|
|
|
|
case VLM_EVENT_MEDIA_REMOVED:
|
|
|
|
libvlc_event.type = libvlc_VlmMediaRemoved;
|
|
|
|
break;
|
|
|
|
case VLM_EVENT_MEDIA_CHANGED:
|
|
|
|
libvlc_event.type = libvlc_VlmMediaChanged;
|
|
|
|
break;
|
|
|
|
case VLM_EVENT_MEDIA_INSTANCE_STARTED:
|
|
|
|
libvlc_event.type = libvlc_VlmMediaInstanceStarted;
|
|
|
|
break;
|
|
|
|
case VLM_EVENT_MEDIA_INSTANCE_STOPPED:
|
|
|
|
libvlc_event.type = libvlc_VlmMediaInstanceStopped;
|
|
|
|
break;
|
2009-07-07 14:12:40 +02:00
|
|
|
case VLM_EVENT_MEDIA_INSTANCE_STATE:
|
|
|
|
libvlc_event.u.vlm_media_event.psz_instance_name =
|
|
|
|
event->psz_instance_name;
|
|
|
|
switch( event->input_state )
|
|
|
|
{
|
|
|
|
case INIT_S:
|
|
|
|
libvlc_event.type = libvlc_VlmMediaInstanceStatusInit;
|
|
|
|
break;
|
|
|
|
case OPENING_S:
|
|
|
|
libvlc_event.type =
|
|
|
|
libvlc_VlmMediaInstanceStatusOpening;
|
|
|
|
break;
|
|
|
|
case PLAYING_S:
|
|
|
|
libvlc_event.type =
|
|
|
|
libvlc_VlmMediaInstanceStatusPlaying;
|
|
|
|
break;
|
|
|
|
case PAUSE_S:
|
|
|
|
libvlc_event.type = libvlc_VlmMediaInstanceStatusPause;
|
|
|
|
break;
|
|
|
|
case END_S:
|
|
|
|
libvlc_event.type = libvlc_VlmMediaInstanceStatusEnd;
|
|
|
|
break;
|
|
|
|
case ERROR_S:
|
|
|
|
libvlc_event.type = libvlc_VlmMediaInstanceStatusError;
|
|
|
|
break;
|
|
|
|
default:
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
break;
|
|
|
|
default:
|
|
|
|
return 0;
|
2009-05-18 14:17:53 +02:00
|
|
|
}
|
|
|
|
libvlc_event_send( p_event_manager, &libvlc_event );
|
|
|
|
return 0;
|
|
|
|
}
|
2007-05-21 21:15:54 +02:00
|
|
|
|
2009-06-15 15:30:32 +02:00
|
|
|
static void libvlc_vlm_release_internal( libvlc_instance_t *p_instance )
|
|
|
|
{
|
|
|
|
vlm_t *p_vlm = p_instance->libvlc_vlm.p_vlm;
|
|
|
|
if( !p_instance->libvlc_vlm.p_vlm )
|
|
|
|
return;
|
|
|
|
/* We need to remove medias in order to receive events */
|
|
|
|
vlm_Control( p_vlm, VLM_CLEAR_MEDIAS );
|
|
|
|
vlm_Control( p_vlm, VLM_CLEAR_SCHEDULES );
|
|
|
|
|
|
|
|
var_DelCallback( (vlc_object_t *)p_vlm, "intf-event", VlmEvent,
|
|
|
|
p_instance->libvlc_vlm.p_event_manager );
|
|
|
|
p_instance->libvlc_vlm.pf_release = NULL;
|
|
|
|
libvlc_event_manager_release( p_instance->libvlc_vlm.p_event_manager );
|
|
|
|
p_instance->libvlc_vlm.p_event_manager = NULL;
|
|
|
|
vlm_Delete( p_vlm );
|
|
|
|
p_instance->libvlc_vlm.p_vlm = NULL;
|
|
|
|
}
|
|
|
|
|
2010-02-03 20:37:14 +01:00
|
|
|
static int libvlc_vlm_init( libvlc_instance_t *p_instance )
|
2007-05-21 21:15:54 +02:00
|
|
|
{
|
2009-06-15 15:30:32 +02:00
|
|
|
if( !p_instance->libvlc_vlm.p_event_manager )
|
2009-05-18 14:17:53 +02:00
|
|
|
{
|
2009-07-07 14:12:40 +02:00
|
|
|
p_instance->libvlc_vlm.p_event_manager =
|
2010-01-25 18:19:19 +01:00
|
|
|
libvlc_event_manager_new( p_instance->libvlc_vlm.p_vlm, p_instance );
|
|
|
|
if( unlikely(p_instance->libvlc_vlm.p_event_manager == NULL) )
|
|
|
|
return VLC_ENOMEM;
|
2009-07-07 14:12:40 +02:00
|
|
|
libvlc_event_manager_register_event_type(
|
|
|
|
p_instance->libvlc_vlm.p_event_manager,
|
2010-01-25 18:19:19 +01:00
|
|
|
libvlc_VlmMediaAdded );
|
2009-07-07 14:12:40 +02:00
|
|
|
libvlc_event_manager_register_event_type(
|
|
|
|
p_instance->libvlc_vlm.p_event_manager,
|
2010-01-25 18:19:19 +01:00
|
|
|
libvlc_VlmMediaRemoved );
|
2009-07-07 14:12:40 +02:00
|
|
|
libvlc_event_manager_register_event_type(
|
|
|
|
p_instance->libvlc_vlm.p_event_manager,
|
2010-01-25 18:19:19 +01:00
|
|
|
libvlc_VlmMediaChanged );
|
2009-07-07 14:12:40 +02:00
|
|
|
libvlc_event_manager_register_event_type(
|
|
|
|
p_instance->libvlc_vlm.p_event_manager,
|
2010-01-25 18:19:19 +01:00
|
|
|
libvlc_VlmMediaInstanceStarted );
|
2009-07-07 14:12:40 +02:00
|
|
|
libvlc_event_manager_register_event_type(
|
|
|
|
p_instance->libvlc_vlm.p_event_manager,
|
2010-01-25 18:19:19 +01:00
|
|
|
libvlc_VlmMediaInstanceStopped );
|
2009-07-07 14:12:40 +02:00
|
|
|
libvlc_event_manager_register_event_type(
|
|
|
|
p_instance->libvlc_vlm.p_event_manager,
|
2010-01-25 18:19:19 +01:00
|
|
|
libvlc_VlmMediaInstanceStatusInit );
|
2009-07-07 14:12:40 +02:00
|
|
|
libvlc_event_manager_register_event_type(
|
|
|
|
p_instance->libvlc_vlm.p_event_manager,
|
2010-01-25 18:19:19 +01:00
|
|
|
libvlc_VlmMediaInstanceStatusOpening );
|
2009-07-07 14:12:40 +02:00
|
|
|
libvlc_event_manager_register_event_type(
|
|
|
|
p_instance->libvlc_vlm.p_event_manager,
|
2010-01-25 18:19:19 +01:00
|
|
|
libvlc_VlmMediaInstanceStatusPlaying );
|
2009-07-07 14:12:40 +02:00
|
|
|
libvlc_event_manager_register_event_type(
|
|
|
|
p_instance->libvlc_vlm.p_event_manager,
|
2010-01-25 18:19:19 +01:00
|
|
|
libvlc_VlmMediaInstanceStatusPause );
|
2009-07-07 14:12:40 +02:00
|
|
|
libvlc_event_manager_register_event_type(
|
|
|
|
p_instance->libvlc_vlm.p_event_manager,
|
2010-01-25 18:19:19 +01:00
|
|
|
libvlc_VlmMediaInstanceStatusEnd );
|
2009-07-07 14:12:40 +02:00
|
|
|
libvlc_event_manager_register_event_type(
|
|
|
|
p_instance->libvlc_vlm.p_event_manager,
|
2010-01-25 18:19:19 +01:00
|
|
|
libvlc_VlmMediaInstanceStatusError );
|
2009-05-18 14:17:53 +02:00
|
|
|
}
|
|
|
|
|
2009-06-15 15:30:32 +02:00
|
|
|
if( !p_instance->libvlc_vlm.p_vlm )
|
2009-05-18 14:17:53 +02:00
|
|
|
{
|
2009-06-15 15:30:32 +02:00
|
|
|
p_instance->libvlc_vlm.p_vlm = vlm_New( p_instance->p_libvlc_int );
|
|
|
|
if( !p_instance->libvlc_vlm.p_vlm )
|
2009-06-12 16:54:48 +02:00
|
|
|
{
|
2009-09-07 21:13:49 +02:00
|
|
|
libvlc_printerr( "VLM not supported or out of memory" );
|
2009-06-12 16:54:48 +02:00
|
|
|
return VLC_EGENERIC;
|
|
|
|
}
|
2009-07-07 14:12:40 +02:00
|
|
|
var_AddCallback( (vlc_object_t *)p_instance->libvlc_vlm.p_vlm,
|
|
|
|
"intf-event", VlmEvent,
|
2009-06-15 15:30:32 +02:00
|
|
|
p_instance->libvlc_vlm.p_event_manager );
|
|
|
|
p_instance->libvlc_vlm.pf_release = libvlc_vlm_release_internal;
|
2009-05-18 14:17:53 +02:00
|
|
|
}
|
2009-06-12 16:54:48 +02:00
|
|
|
|
2007-05-21 21:15:54 +02:00
|
|
|
return VLC_SUCCESS;
|
|
|
|
}
|
2009-06-15 15:30:32 +02:00
|
|
|
|
2010-02-03 20:37:14 +01:00
|
|
|
void libvlc_vlm_release( libvlc_instance_t *p_instance )
|
2009-06-15 15:30:32 +02:00
|
|
|
{
|
|
|
|
libvlc_vlm_release_internal( p_instance );
|
|
|
|
}
|
|
|
|
|
2010-02-03 20:37:14 +01:00
|
|
|
#define VLM_RET(p,ret) do { \
|
|
|
|
if( libvlc_vlm_init( p_instance ) ) \
|
|
|
|
return (ret); \
|
|
|
|
(p) = p_instance->libvlc_vlm.p_vlm; \
|
|
|
|
} while(0)
|
|
|
|
|
2009-04-04 11:47:12 +02:00
|
|
|
static vlm_media_instance_t *
|
|
|
|
libvlc_vlm_get_media_instance( libvlc_instance_t *p_instance,
|
2010-02-03 20:37:14 +01:00
|
|
|
const char *psz_name, int i_minstance_idx )
|
2008-04-09 00:31:19 +02:00
|
|
|
{
|
|
|
|
vlm_t *p_vlm;
|
|
|
|
vlm_media_instance_t **pp_minstance;
|
|
|
|
vlm_media_instance_t *p_minstance;
|
|
|
|
int i_minstance;
|
|
|
|
int64_t id;
|
|
|
|
|
|
|
|
VLM_RET(p_vlm, NULL);
|
|
|
|
|
|
|
|
if( vlm_Control( p_vlm, VLM_GET_MEDIA_ID, psz_name, &id ) ||
|
2009-04-04 11:47:12 +02:00
|
|
|
vlm_Control( p_vlm, VLM_GET_MEDIA_INSTANCES, id, &pp_minstance,
|
|
|
|
&i_minstance ) )
|
2008-04-09 00:31:19 +02:00
|
|
|
{
|
2009-09-07 21:13:49 +02:00
|
|
|
libvlc_printerr( "%s: media instances not found", psz_name );
|
2008-04-09 00:31:19 +02:00
|
|
|
return NULL;
|
|
|
|
}
|
|
|
|
p_minstance = NULL;
|
|
|
|
if( i_minstance_idx >= 0 && i_minstance_idx < i_minstance )
|
|
|
|
{
|
|
|
|
p_minstance = pp_minstance[i_minstance_idx];
|
|
|
|
TAB_REMOVE( i_minstance, pp_minstance, p_minstance );
|
|
|
|
}
|
|
|
|
while( i_minstance > 0 )
|
|
|
|
vlm_media_instance_Delete( pp_minstance[--i_minstance] );
|
|
|
|
TAB_CLEAN( i_minstance, pp_minstance );
|
|
|
|
return p_minstance;
|
|
|
|
}
|
|
|
|
|
2009-08-10 10:10:23 +02:00
|
|
|
/* local function to be used in libvlc_vlm_show_media only */
|
|
|
|
static char* recurse_answer( vlm_message_t *p_answer, const char* psz_delim,
|
|
|
|
const int i_list ) {
|
|
|
|
char* psz_childdelim = NULL;
|
|
|
|
char* psz_nametag = NULL;
|
|
|
|
char* psz_response = strdup( "" );
|
2011-03-21 21:44:11 +01:00
|
|
|
char *psz_tmp;
|
2009-08-10 10:10:23 +02:00
|
|
|
int i_success = 0;
|
|
|
|
int i;
|
|
|
|
vlm_message_t *aw_child, **paw_child;
|
|
|
|
|
|
|
|
i_success = asprintf( &psz_childdelim, "%s\t", psz_delim);
|
2011-03-21 20:10:13 +01:00
|
|
|
if( i_success == -1 )
|
|
|
|
return psz_response;
|
2009-08-10 10:10:23 +02:00
|
|
|
|
2011-03-21 20:10:13 +01:00
|
|
|
paw_child = p_answer->child;
|
|
|
|
aw_child = *( paw_child );
|
|
|
|
/* Iterate over children */
|
|
|
|
for( i = 0; i < p_answer->i_child; i++ )
|
2009-08-10 10:10:23 +02:00
|
|
|
{
|
2011-03-21 20:10:13 +01:00
|
|
|
/* Spare comma if it is the last element */
|
|
|
|
char c_comma = ',';
|
|
|
|
if( i == (p_answer->i_child - 1) )
|
|
|
|
c_comma = ' ';
|
|
|
|
|
|
|
|
/* Append name of child node, if not in a list */
|
|
|
|
if( !i_list )
|
2009-08-10 10:10:23 +02:00
|
|
|
{
|
2011-03-21 21:44:11 +01:00
|
|
|
i_success = asprintf( &psz_tmp, "%s\"%s\": ",
|
2011-03-21 20:10:13 +01:00
|
|
|
psz_response, aw_child->psz_name );
|
|
|
|
if( i_success == -1 ) break;
|
2011-03-21 21:44:11 +01:00
|
|
|
free( psz_response );
|
|
|
|
psz_response = psz_tmp;
|
2011-03-21 20:10:13 +01:00
|
|
|
}
|
2009-08-10 10:10:23 +02:00
|
|
|
|
2011-03-21 20:10:13 +01:00
|
|
|
/* If child node has children, */
|
|
|
|
if( aw_child->i_child )
|
|
|
|
{
|
|
|
|
/* If the parent node is a list (hence the child node is
|
|
|
|
* inside a list), create a property of its name as if it
|
|
|
|
* had a name value node
|
|
|
|
*/
|
|
|
|
if( i_list )
|
2009-08-10 10:10:23 +02:00
|
|
|
{
|
2011-03-21 20:10:13 +01:00
|
|
|
i_success = asprintf( &psz_nametag, "\"name\": \"%s\",%s",
|
|
|
|
aw_child->psz_name, psz_childdelim );
|
2009-08-10 10:10:23 +02:00
|
|
|
if( i_success == -1 ) break;
|
|
|
|
}
|
2011-03-21 20:10:13 +01:00
|
|
|
else
|
|
|
|
{
|
|
|
|
psz_nametag = strdup( "" );
|
|
|
|
}
|
|
|
|
/* If the child is a list itself, format it accordingly and
|
|
|
|
* recurse through the child's children, telling them that
|
|
|
|
* they are inside a list.
|
|
|
|
*/
|
|
|
|
if( strcmp( aw_child->psz_name, "media" ) == 0 ||
|
|
|
|
strcmp( aw_child->psz_name, "inputs" ) == 0 ||
|
|
|
|
strcmp( aw_child->psz_name, "options" ) == 0 )
|
2009-08-10 10:10:23 +02:00
|
|
|
{
|
2011-03-21 21:44:11 +01:00
|
|
|
char *psz_recurse = recurse_answer( aw_child, psz_childdelim, 1 ),
|
|
|
|
i_success = asprintf( &psz_tmp, "%s[%s%s%s]%c%s",
|
|
|
|
psz_response, psz_childdelim, psz_recurse,
|
2011-03-21 20:10:13 +01:00
|
|
|
psz_delim, c_comma, psz_delim );
|
2011-03-21 21:44:11 +01:00
|
|
|
free( psz_recurse );
|
2011-03-21 20:10:13 +01:00
|
|
|
if( i_success == -1 ) break;
|
2011-03-21 21:44:11 +01:00
|
|
|
free( psz_response );
|
|
|
|
psz_response = psz_tmp;
|
2009-08-10 10:10:23 +02:00
|
|
|
}
|
2011-03-21 20:10:13 +01:00
|
|
|
/* Not a list, so format the child as a JSON object and
|
|
|
|
* recurse through the child's children
|
2009-08-10 10:10:23 +02:00
|
|
|
*/
|
|
|
|
else
|
|
|
|
{
|
2011-03-21 21:44:11 +01:00
|
|
|
char *psz_recurse = recurse_answer( aw_child, psz_childdelim, 0 ),
|
|
|
|
i_success = asprintf( &psz_tmp, "%s{%s%s%s%s}%c%s",
|
2011-03-21 20:10:13 +01:00
|
|
|
psz_response, psz_childdelim, psz_nametag,
|
2011-03-21 21:44:11 +01:00
|
|
|
psz_recurse, psz_delim, c_comma, psz_delim );
|
|
|
|
free( psz_recurse );
|
2011-03-21 20:10:13 +01:00
|
|
|
if( i_success == -1 ) break;
|
2011-03-21 21:44:11 +01:00
|
|
|
free( psz_response );
|
|
|
|
psz_response = psz_tmp;
|
2009-08-10 10:10:23 +02:00
|
|
|
}
|
|
|
|
}
|
2011-03-21 20:10:13 +01:00
|
|
|
/* Otherwise - when no children are present - the node is a
|
|
|
|
* value node. So print the value string
|
|
|
|
*/
|
|
|
|
else
|
|
|
|
{
|
|
|
|
/* If value is equivalent to NULL, print it as null */
|
|
|
|
if( aw_child->psz_value == NULL
|
|
|
|
|| strcmp( aw_child->psz_value, "(null)" ) == 0 )
|
|
|
|
{
|
2011-03-21 21:44:11 +01:00
|
|
|
i_success = asprintf( &psz_tmp, "%snull%c%s",
|
2011-03-21 20:10:13 +01:00
|
|
|
psz_response, c_comma, psz_delim );
|
2011-03-21 21:44:11 +01:00
|
|
|
if( i_success == -1 ) break;
|
|
|
|
free( psz_response );
|
|
|
|
psz_response = psz_tmp;
|
2011-03-21 20:10:13 +01:00
|
|
|
}
|
|
|
|
/* Otherwise print the value in quotation marks */
|
|
|
|
else
|
|
|
|
{
|
2011-03-21 21:44:11 +01:00
|
|
|
i_success = asprintf( &psz_tmp, "%s\"%s\"%c%s",
|
2011-03-21 20:10:13 +01:00
|
|
|
psz_response, aw_child->psz_value,
|
|
|
|
c_comma, psz_delim );
|
|
|
|
if( i_success == -1 ) break;
|
2011-03-21 21:44:11 +01:00
|
|
|
free( psz_response );
|
|
|
|
psz_response = psz_tmp;
|
2011-03-21 20:10:13 +01:00
|
|
|
}
|
|
|
|
}
|
|
|
|
/* getting next child */
|
|
|
|
paw_child++;
|
|
|
|
aw_child = *( paw_child );
|
2009-08-10 10:10:23 +02:00
|
|
|
}
|
|
|
|
free( psz_nametag );
|
|
|
|
free( psz_childdelim );
|
|
|
|
if( i_success == -1 )
|
|
|
|
{
|
|
|
|
free( psz_response );
|
|
|
|
psz_response = strdup( "" );
|
|
|
|
}
|
|
|
|
return psz_response;
|
|
|
|
}
|
|
|
|
|
|
|
|
const char* libvlc_vlm_show_media( libvlc_instance_t *p_instance,
|
2010-02-03 20:55:19 +01:00
|
|
|
const char *psz_name )
|
2009-08-10 10:10:23 +02:00
|
|
|
{
|
|
|
|
char *psz_message = NULL;
|
|
|
|
vlm_message_t *answer = NULL;
|
|
|
|
char *psz_response = NULL;
|
|
|
|
const char *psz_fmt = NULL;
|
|
|
|
const char *psz_delimiter = NULL;
|
|
|
|
int i_list;
|
|
|
|
vlm_t *p_vlm = NULL;
|
|
|
|
|
|
|
|
VLM_RET(p_vlm, NULL);
|
|
|
|
|
2009-09-07 21:13:49 +02:00
|
|
|
assert( psz_name );
|
|
|
|
|
|
|
|
if( asprintf( &psz_message, "show %s", psz_name ) == -1 )
|
|
|
|
return NULL;
|
|
|
|
|
|
|
|
vlm_ExecuteCommand( p_vlm, psz_message, &answer );
|
|
|
|
if( answer->psz_value )
|
2009-08-10 10:10:23 +02:00
|
|
|
{
|
2009-09-07 21:13:49 +02:00
|
|
|
libvlc_printerr( "Unable to call show %s: %s",
|
|
|
|
psz_name, answer->psz_value );
|
2009-08-10 10:10:23 +02:00
|
|
|
}
|
2009-09-07 21:13:49 +02:00
|
|
|
else if ( answer->child )
|
|
|
|
{ /* in case everything was requested */
|
|
|
|
if ( strcmp( psz_name, "" ) == 0 )
|
2009-08-10 10:10:23 +02:00
|
|
|
{
|
2009-09-07 21:13:49 +02:00
|
|
|
psz_fmt = "{\n\t%s\n}\n";
|
|
|
|
psz_delimiter = "\n\t";
|
|
|
|
i_list = 0;
|
2009-08-10 10:10:23 +02:00
|
|
|
}
|
2009-09-07 21:13:49 +02:00
|
|
|
else
|
|
|
|
{
|
|
|
|
psz_fmt = "%s\n";
|
|
|
|
psz_delimiter = "\n";
|
|
|
|
i_list = 1;
|
|
|
|
}
|
2011-03-21 21:44:11 +01:00
|
|
|
char *psz_tmp = recurse_answer( answer, psz_delimiter, i_list );
|
|
|
|
if( asprintf( &psz_response, psz_fmt, psz_tmp ) == -1 )
|
2009-09-07 21:13:49 +02:00
|
|
|
{
|
|
|
|
libvlc_printerr( "Out of memory" );
|
2010-02-03 20:55:19 +01:00
|
|
|
psz_response = NULL;
|
2009-08-10 10:10:23 +02:00
|
|
|
}
|
2011-03-21 21:44:11 +01:00
|
|
|
free( psz_tmp );
|
2009-08-10 10:10:23 +02:00
|
|
|
}
|
|
|
|
free( psz_message );
|
|
|
|
return( psz_response );
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2010-02-03 20:55:19 +01:00
|
|
|
int libvlc_vlm_add_broadcast( libvlc_instance_t *p_instance,
|
|
|
|
const char *psz_name,
|
|
|
|
const char *psz_input,
|
|
|
|
const char *psz_output, int i_options,
|
|
|
|
const char * const *ppsz_options,
|
|
|
|
int b_enabled, int b_loop )
|
2007-03-07 22:47:25 +01:00
|
|
|
{
|
2007-05-21 21:15:54 +02:00
|
|
|
vlm_t *p_vlm;
|
|
|
|
vlm_media_t m;
|
|
|
|
int n;
|
|
|
|
|
2010-02-03 20:55:19 +01:00
|
|
|
VLM_RET(p_vlm, -1);
|
2007-05-21 21:15:54 +02:00
|
|
|
|
|
|
|
vlm_media_Init( &m );
|
|
|
|
m.psz_name = strdup( psz_name );
|
|
|
|
m.b_enabled = b_enabled;
|
2008-04-14 00:08:29 +02:00
|
|
|
m.b_vod = false;
|
2007-05-21 21:15:54 +02:00
|
|
|
m.broadcast.b_loop = b_loop;
|
|
|
|
if( psz_input )
|
|
|
|
TAB_APPEND( m.i_input, m.ppsz_input, strdup(psz_input) );
|
|
|
|
if( psz_output )
|
|
|
|
m.psz_output = strdup( psz_output );
|
|
|
|
for( n = 0; n < i_options; n++ )
|
|
|
|
TAB_APPEND( m.i_option, m.ppsz_option, strdup(ppsz_options[n]) );
|
|
|
|
|
2008-09-05 17:22:34 +02:00
|
|
|
n = vlm_Control( p_vlm, VLM_ADD_MEDIA, &m, NULL );
|
2007-05-21 21:15:54 +02:00
|
|
|
vlm_media_Clean( &m );
|
2008-09-05 17:22:34 +02:00
|
|
|
if( n )
|
2009-09-07 21:13:49 +02:00
|
|
|
{
|
|
|
|
libvlc_printerr( "Media %s creation failed", psz_name );
|
2010-02-03 20:55:19 +01:00
|
|
|
return -1;
|
2009-09-07 21:13:49 +02:00
|
|
|
}
|
2010-02-03 20:55:19 +01:00
|
|
|
return 0;
|
2007-03-07 22:47:25 +01:00
|
|
|
}
|
|
|
|
|
2010-02-03 20:55:19 +01:00
|
|
|
int libvlc_vlm_add_vod( libvlc_instance_t *p_instance, const char *psz_name,
|
|
|
|
const char *psz_input, int i_options,
|
|
|
|
const char * const *ppsz_options, int b_enabled,
|
|
|
|
const char *psz_mux )
|
2008-07-04 15:04:23 +02:00
|
|
|
{
|
|
|
|
vlm_t *p_vlm;
|
|
|
|
vlm_media_t m;
|
|
|
|
int n;
|
|
|
|
|
2010-02-03 20:55:19 +01:00
|
|
|
VLM_RET(p_vlm, -1);
|
2008-07-04 15:04:23 +02:00
|
|
|
|
|
|
|
vlm_media_Init( &m );
|
|
|
|
m.psz_name = strdup( psz_name );
|
|
|
|
m.b_enabled = b_enabled;
|
|
|
|
m.b_vod = true;
|
|
|
|
m.vod.psz_mux = psz_mux ? strdup( psz_mux ) : NULL;
|
|
|
|
if( psz_input )
|
|
|
|
TAB_APPEND( m.i_input, m.ppsz_input, strdup(psz_input) );
|
|
|
|
for( n = 0; n < i_options; n++ )
|
|
|
|
TAB_APPEND( m.i_option, m.ppsz_option, strdup(ppsz_options[n]) );
|
|
|
|
|
2008-09-05 17:22:34 +02:00
|
|
|
n = vlm_Control( p_vlm, VLM_ADD_MEDIA, &m, NULL );
|
2008-07-04 15:04:23 +02:00
|
|
|
vlm_media_Clean( &m );
|
2008-09-05 17:22:34 +02:00
|
|
|
if( n )
|
2009-09-07 21:13:49 +02:00
|
|
|
{
|
|
|
|
libvlc_printerr( "Media %s creation failed", psz_name );
|
2010-02-03 20:55:19 +01:00
|
|
|
return -1;
|
2009-09-07 21:13:49 +02:00
|
|
|
}
|
2010-02-03 20:55:19 +01:00
|
|
|
return 0;
|
2008-07-04 15:04:23 +02:00
|
|
|
}
|
|
|
|
|
2010-02-03 20:55:19 +01:00
|
|
|
int libvlc_vlm_del_media( libvlc_instance_t *p_instance, const char *psz_name )
|
2007-03-07 22:47:25 +01:00
|
|
|
{
|
2007-05-21 21:15:54 +02:00
|
|
|
vlm_t *p_vlm;
|
|
|
|
int64_t id;
|
|
|
|
|
2010-02-03 20:55:19 +01:00
|
|
|
VLM_RET(p_vlm, -1);
|
2007-05-21 21:15:54 +02:00
|
|
|
|
|
|
|
if( vlm_Control( p_vlm, VLM_GET_MEDIA_ID, psz_name, &id ) ||
|
|
|
|
vlm_Control( p_vlm, VLM_DEL_MEDIA, id ) )
|
|
|
|
{
|
2009-09-07 21:13:49 +02:00
|
|
|
libvlc_printerr( "Unable to delete %s", psz_name );
|
2010-02-03 20:55:19 +01:00
|
|
|
return -1;
|
2007-05-21 21:15:54 +02:00
|
|
|
}
|
2010-02-03 20:55:19 +01:00
|
|
|
return 0;
|
2007-03-07 22:47:25 +01:00
|
|
|
}
|
|
|
|
|
2010-02-03 21:07:54 +01:00
|
|
|
static vlm_media_t *get_media( libvlc_instance_t *p_instance,
|
|
|
|
vlm_t **restrict pp_vlm, const char *name )
|
|
|
|
{
|
|
|
|
vlm_media_t *p_media;
|
|
|
|
vlm_t *p_vlm;
|
|
|
|
int64_t id;
|
|
|
|
|
|
|
|
VLM_RET(p_vlm, NULL);
|
|
|
|
if( vlm_Control( p_vlm, VLM_GET_MEDIA_ID, name, &id ) ||
|
|
|
|
vlm_Control( p_vlm, VLM_GET_MEDIA, id, &p_media ) )
|
|
|
|
return NULL;
|
|
|
|
*pp_vlm = p_vlm;
|
|
|
|
return p_media;
|
|
|
|
}
|
|
|
|
|
2007-05-21 21:15:54 +02:00
|
|
|
#define VLM_CHANGE(psz_error, code ) do { \
|
|
|
|
vlm_t *p_vlm; \
|
2010-02-03 21:07:54 +01:00
|
|
|
vlm_media_t *p_media = get_media( p_instance, &p_vlm, psz_name ); \
|
|
|
|
if( p_media != NULL ) { \
|
|
|
|
code; \
|
|
|
|
if( vlm_Control( p_vlm, VLM_CHANGE_MEDIA, p_media ) ) \
|
|
|
|
p_vlm = NULL; \
|
2007-05-21 21:15:54 +02:00
|
|
|
vlm_media_Delete( p_media ); \
|
2010-02-03 21:07:54 +01:00
|
|
|
if( p_vlm != NULL ) \
|
|
|
|
return 0; \
|
2007-05-21 21:15:54 +02:00
|
|
|
} \
|
2009-09-07 21:13:49 +02:00
|
|
|
libvlc_printerr( psz_error, psz_name ); \
|
2010-02-03 20:55:19 +01:00
|
|
|
return -1; \
|
2007-05-21 21:15:54 +02:00
|
|
|
} while(0)
|
|
|
|
|
2010-02-03 20:55:19 +01:00
|
|
|
int libvlc_vlm_set_enabled( libvlc_instance_t *p_instance,
|
|
|
|
const char *psz_name, int b_enabled )
|
2007-03-07 22:47:25 +01:00
|
|
|
{
|
2007-05-21 21:15:54 +02:00
|
|
|
#define VLM_CHANGE_CODE { p_media->b_enabled = b_enabled; }
|
|
|
|
VLM_CHANGE( "Unable to delete %s", VLM_CHANGE_CODE );
|
|
|
|
#undef VLM_CHANGE_CODE
|
2007-03-07 22:47:25 +01:00
|
|
|
}
|
|
|
|
|
2010-02-03 20:55:19 +01:00
|
|
|
int libvlc_vlm_set_loop( libvlc_instance_t *p_instance, const char *psz_name,
|
|
|
|
int b_loop )
|
2007-03-07 22:47:25 +01:00
|
|
|
{
|
2007-05-21 21:15:54 +02:00
|
|
|
#define VLM_CHANGE_CODE { p_media->broadcast.b_loop = b_loop; }
|
|
|
|
VLM_CHANGE( "Unable to change %s loop property", VLM_CHANGE_CODE );
|
2008-07-04 15:04:23 +02:00
|
|
|
#undef VLM_CHANGE_CODE
|
|
|
|
}
|
|
|
|
|
2010-02-03 20:55:19 +01:00
|
|
|
int libvlc_vlm_set_mux( libvlc_instance_t *p_instance, const char *psz_name,
|
|
|
|
const char *psz_mux )
|
2008-07-04 15:04:23 +02:00
|
|
|
{
|
|
|
|
#define VLM_CHANGE_CODE { if( p_media->b_vod ) { \
|
|
|
|
free( p_media->vod.psz_mux ); \
|
2009-04-04 11:47:12 +02:00
|
|
|
p_media->vod.psz_mux = psz_mux \
|
|
|
|
? strdup( psz_mux ) : NULL; \
|
2008-07-04 15:04:23 +02:00
|
|
|
} }
|
|
|
|
VLM_CHANGE( "Unable to change %s mux property", VLM_CHANGE_CODE );
|
2007-05-21 21:15:54 +02:00
|
|
|
#undef VLM_CHANGE_CODE
|
2007-03-07 22:47:25 +01:00
|
|
|
}
|
|
|
|
|
2010-02-03 20:55:19 +01:00
|
|
|
int libvlc_vlm_set_output( libvlc_instance_t *p_instance,
|
|
|
|
const char *psz_name, const char *psz_output )
|
2007-03-07 22:47:25 +01:00
|
|
|
{
|
2008-03-12 00:30:25 +01:00
|
|
|
#define VLM_CHANGE_CODE { free( p_media->psz_output ); \
|
2007-05-21 21:15:54 +02:00
|
|
|
p_media->psz_output = strdup( psz_output ); }
|
|
|
|
VLM_CHANGE( "Unable to change %s output property", VLM_CHANGE_CODE );
|
|
|
|
#undef VLM_CHANGE_CODE
|
2007-03-07 22:47:25 +01:00
|
|
|
}
|
|
|
|
|
2010-02-03 20:55:19 +01:00
|
|
|
int libvlc_vlm_set_input( libvlc_instance_t *p_instance,
|
|
|
|
const char *psz_name, const char *psz_input )
|
2007-03-07 22:47:25 +01:00
|
|
|
{
|
2007-05-21 21:15:54 +02:00
|
|
|
#define VLM_CHANGE_CODE { while( p_media->i_input > 0 ) \
|
|
|
|
free( p_media->ppsz_input[--p_media->i_input] );\
|
2009-04-04 11:47:12 +02:00
|
|
|
TAB_APPEND( p_media->i_input, p_media->ppsz_input, \
|
|
|
|
strdup(psz_input) ); }
|
2007-05-21 21:15:54 +02:00
|
|
|
VLM_CHANGE( "Unable to change %s input property", VLM_CHANGE_CODE );
|
|
|
|
#undef VLM_CHANGE_CODE
|
2007-03-07 22:47:25 +01:00
|
|
|
}
|
|
|
|
|
2010-02-03 20:55:19 +01:00
|
|
|
int libvlc_vlm_add_input( libvlc_instance_t *p_instance,
|
|
|
|
const char *psz_name, const char *psz_input )
|
2007-03-07 22:47:25 +01:00
|
|
|
{
|
2009-04-04 11:47:12 +02:00
|
|
|
#define VLM_CHANGE_CODE { TAB_APPEND( p_media->i_input, p_media->ppsz_input, \
|
|
|
|
strdup(psz_input) ); }
|
2007-05-21 21:15:54 +02:00
|
|
|
VLM_CHANGE( "Unable to change %s input property", VLM_CHANGE_CODE );
|
|
|
|
#undef VLM_CHANGE_CODE
|
2007-03-07 22:47:25 +01:00
|
|
|
}
|
|
|
|
|
2010-02-03 20:55:19 +01:00
|
|
|
int libvlc_vlm_change_media( libvlc_instance_t *p_instance,
|
|
|
|
const char *psz_name, const char *psz_input,
|
|
|
|
const char *psz_output, int i_options,
|
|
|
|
const char * const *ppsz_options, int b_enabled,
|
|
|
|
int b_loop )
|
2007-03-07 22:47:25 +01:00
|
|
|
{
|
2007-05-21 21:15:54 +02:00
|
|
|
#define VLM_CHANGE_CODE { int n; \
|
|
|
|
p_media->b_enabled = b_enabled; \
|
|
|
|
p_media->broadcast.b_loop = b_loop; \
|
|
|
|
while( p_media->i_input > 0 ) \
|
|
|
|
free( p_media->ppsz_input[--p_media->i_input] ); \
|
|
|
|
if( psz_input ) \
|
|
|
|
TAB_APPEND( p_media->i_input, p_media->ppsz_input, strdup(psz_input) ); \
|
2008-03-12 00:30:25 +01:00
|
|
|
free( p_media->psz_output ); \
|
2007-05-21 21:15:54 +02:00
|
|
|
p_media->psz_output = psz_output ? strdup( psz_output ) : NULL; \
|
|
|
|
while( p_media->i_option > 0 ) \
|
|
|
|
free( p_media->ppsz_option[--p_media->i_option] ); \
|
|
|
|
for( n = 0; n < i_options; n++ ) \
|
2009-04-04 11:47:12 +02:00
|
|
|
TAB_APPEND( p_media->i_option, p_media->ppsz_option, \
|
|
|
|
strdup(ppsz_options[n]) ); \
|
2007-05-21 21:15:54 +02:00
|
|
|
}
|
|
|
|
VLM_CHANGE( "Unable to change %s properties", VLM_CHANGE_CODE );
|
|
|
|
#undef VLM_CHANGE_CODE
|
2007-03-07 22:47:25 +01:00
|
|
|
}
|
|
|
|
|
2010-02-03 20:55:19 +01:00
|
|
|
int libvlc_vlm_play_media( libvlc_instance_t *p_instance,
|
|
|
|
const char *psz_name )
|
2007-03-07 22:47:25 +01:00
|
|
|
{
|
2007-05-21 21:15:54 +02:00
|
|
|
vlm_t *p_vlm;
|
|
|
|
int64_t id;
|
|
|
|
|
2010-02-03 20:55:19 +01:00
|
|
|
VLM_RET(p_vlm, -1);
|
2007-05-21 21:15:54 +02:00
|
|
|
|
|
|
|
if( vlm_Control( p_vlm, VLM_GET_MEDIA_ID, psz_name, &id ) ||
|
|
|
|
vlm_Control( p_vlm, VLM_START_MEDIA_BROADCAST_INSTANCE, id, NULL, 0 ) )
|
|
|
|
{
|
2009-09-07 21:13:49 +02:00
|
|
|
libvlc_printerr( "Unable to play %s", psz_name );
|
2010-02-03 20:55:19 +01:00
|
|
|
return -1;
|
2007-05-21 21:15:54 +02:00
|
|
|
}
|
2010-02-03 20:55:19 +01:00
|
|
|
return 0;
|
2007-03-07 22:47:25 +01:00
|
|
|
}
|
|
|
|
|
2010-02-03 20:55:19 +01:00
|
|
|
int libvlc_vlm_stop_media( libvlc_instance_t *p_instance,
|
|
|
|
const char *psz_name )
|
2007-03-07 22:47:25 +01:00
|
|
|
{
|
2007-05-21 21:15:54 +02:00
|
|
|
vlm_t *p_vlm;
|
|
|
|
int64_t id;
|
|
|
|
|
2010-02-03 20:55:19 +01:00
|
|
|
VLM_RET(p_vlm, -1);
|
2007-05-21 21:15:54 +02:00
|
|
|
|
|
|
|
if( vlm_Control( p_vlm, VLM_GET_MEDIA_ID, psz_name, &id ) ||
|
|
|
|
vlm_Control( p_vlm, VLM_STOP_MEDIA_INSTANCE, id, NULL ) )
|
|
|
|
{
|
2009-09-07 21:13:49 +02:00
|
|
|
libvlc_printerr( "Unable to stop %s", psz_name );
|
2010-02-03 20:55:19 +01:00
|
|
|
return -1;
|
2007-05-21 21:15:54 +02:00
|
|
|
}
|
2010-02-03 20:55:19 +01:00
|
|
|
return 0;
|
2007-03-07 22:47:25 +01:00
|
|
|
}
|
|
|
|
|
2010-02-03 20:55:19 +01:00
|
|
|
int libvlc_vlm_pause_media( libvlc_instance_t *p_instance,
|
|
|
|
const char *psz_name )
|
2007-03-07 22:47:25 +01:00
|
|
|
{
|
2007-05-21 21:15:54 +02:00
|
|
|
vlm_t *p_vlm;
|
|
|
|
int64_t id;
|
|
|
|
|
2010-02-03 20:55:19 +01:00
|
|
|
VLM_RET(p_vlm, -1);
|
2007-05-21 21:15:54 +02:00
|
|
|
|
|
|
|
if( vlm_Control( p_vlm, VLM_GET_MEDIA_ID, psz_name, &id ) ||
|
|
|
|
vlm_Control( p_vlm, VLM_PAUSE_MEDIA_INSTANCE, id, NULL ) )
|
|
|
|
{
|
2009-09-07 21:13:49 +02:00
|
|
|
libvlc_printerr( "Unable to pause %s", psz_name );
|
2010-02-03 20:55:19 +01:00
|
|
|
return -1;
|
2007-05-21 21:15:54 +02:00
|
|
|
}
|
2010-02-03 20:55:19 +01:00
|
|
|
return 0;
|
2007-03-07 22:47:25 +01:00
|
|
|
}
|
|
|
|
|
2010-02-03 20:55:19 +01:00
|
|
|
int libvlc_vlm_seek_media( libvlc_instance_t *p_instance,
|
|
|
|
const char *psz_name, float f_percentage )
|
2007-03-07 22:47:25 +01:00
|
|
|
{
|
2007-05-21 21:15:54 +02:00
|
|
|
vlm_t *p_vlm;
|
|
|
|
int64_t id;
|
|
|
|
|
2010-02-03 20:55:19 +01:00
|
|
|
VLM_RET(p_vlm, -1);
|
2007-05-21 21:15:54 +02:00
|
|
|
|
|
|
|
if( vlm_Control( p_vlm, VLM_GET_MEDIA_ID, psz_name, &id ) ||
|
2009-04-04 11:47:12 +02:00
|
|
|
vlm_Control( p_vlm, VLM_SET_MEDIA_INSTANCE_POSITION, id, NULL,
|
|
|
|
f_percentage ) )
|
2009-09-07 21:13:49 +02:00
|
|
|
{
|
|
|
|
libvlc_printerr( "Unable to seek %s to %f%%", psz_name, f_percentage );
|
2010-02-03 20:55:19 +01:00
|
|
|
return -1;
|
2009-09-07 21:13:49 +02:00
|
|
|
}
|
2010-02-03 20:55:19 +01:00
|
|
|
return 0;
|
2007-05-21 21:15:54 +02:00
|
|
|
}
|
|
|
|
|
2008-08-25 15:48:34 +02:00
|
|
|
float libvlc_vlm_get_media_instance_position( libvlc_instance_t *p_instance,
|
2008-09-12 10:58:50 +02:00
|
|
|
const char *psz_name,
|
2010-02-03 20:37:14 +01:00
|
|
|
int i_instance )
|
2008-08-25 15:48:34 +02:00
|
|
|
{
|
2009-04-04 11:47:12 +02:00
|
|
|
vlm_media_instance_t *p_mi;
|
|
|
|
float result = -1.;
|
|
|
|
|
2010-02-03 20:37:14 +01:00
|
|
|
p_mi = libvlc_vlm_get_media_instance( p_instance, psz_name, i_instance );
|
2008-08-25 15:48:34 +02:00
|
|
|
if( p_mi )
|
|
|
|
{
|
|
|
|
result = p_mi->d_position;
|
|
|
|
vlm_media_instance_Delete( p_mi );
|
|
|
|
}
|
|
|
|
return result;
|
|
|
|
}
|
|
|
|
|
|
|
|
int libvlc_vlm_get_media_instance_time( libvlc_instance_t *p_instance,
|
2010-02-03 20:37:14 +01:00
|
|
|
const char *psz_name, int i_instance )
|
2008-08-25 15:48:34 +02:00
|
|
|
{
|
2009-04-04 11:47:12 +02:00
|
|
|
vlm_media_instance_t *p_mi;
|
2008-08-25 15:48:34 +02:00
|
|
|
int result = -1;
|
2009-04-04 11:47:12 +02:00
|
|
|
|
2010-02-03 20:37:14 +01:00
|
|
|
p_mi = libvlc_vlm_get_media_instance( p_instance, psz_name, i_instance );
|
2008-08-25 15:48:34 +02:00
|
|
|
if( p_mi )
|
|
|
|
{
|
|
|
|
result = p_mi->i_time;
|
|
|
|
vlm_media_instance_Delete( p_mi );
|
|
|
|
}
|
|
|
|
return result;
|
|
|
|
}
|
|
|
|
|
|
|
|
int libvlc_vlm_get_media_instance_length( libvlc_instance_t *p_instance,
|
2008-09-12 10:58:50 +02:00
|
|
|
const char *psz_name,
|
2010-02-03 20:37:14 +01:00
|
|
|
int i_instance )
|
2008-08-25 15:48:34 +02:00
|
|
|
{
|
2009-04-04 11:47:12 +02:00
|
|
|
vlm_media_instance_t *p_mi;
|
2008-08-25 15:48:34 +02:00
|
|
|
int result = -1;
|
2009-04-04 11:47:12 +02:00
|
|
|
|
2010-02-03 20:37:14 +01:00
|
|
|
p_mi = libvlc_vlm_get_media_instance( p_instance, psz_name, i_instance );
|
2008-08-25 15:48:34 +02:00
|
|
|
if( p_mi )
|
|
|
|
{
|
|
|
|
result = p_mi->i_length;
|
|
|
|
vlm_media_instance_Delete( p_mi );
|
|
|
|
}
|
|
|
|
return result;
|
|
|
|
}
|
|
|
|
|
|
|
|
int libvlc_vlm_get_media_instance_rate( libvlc_instance_t *p_instance,
|
2010-02-03 20:37:14 +01:00
|
|
|
const char *psz_name, int i_instance )
|
2008-08-25 15:48:34 +02:00
|
|
|
{
|
2009-04-04 11:47:12 +02:00
|
|
|
vlm_media_instance_t *p_mi;
|
2008-08-25 15:48:34 +02:00
|
|
|
int result = -1;
|
2009-04-04 11:47:12 +02:00
|
|
|
|
2010-02-03 20:37:14 +01:00
|
|
|
p_mi = libvlc_vlm_get_media_instance( p_instance, psz_name, i_instance );
|
2008-08-25 15:48:34 +02:00
|
|
|
if( p_mi )
|
|
|
|
{
|
|
|
|
result = p_mi->i_rate;
|
|
|
|
vlm_media_instance_Delete( p_mi );
|
|
|
|
}
|
|
|
|
return result;
|
2007-03-07 22:47:25 +01:00
|
|
|
}
|
|
|
|
|
2010-02-03 20:38:37 +01:00
|
|
|
#if 0
|
2008-08-25 15:48:34 +02:00
|
|
|
int libvlc_vlm_get_media_instance_title( libvlc_instance_t *p_instance,
|
2010-02-03 20:37:14 +01:00
|
|
|
const char *psz_name, int i_instance )
|
2008-08-25 15:48:34 +02:00
|
|
|
{
|
2009-04-04 11:47:12 +02:00
|
|
|
vlm_media_instance_t *p_mi;
|
|
|
|
|
2010-02-03 20:37:14 +01:00
|
|
|
p_mi = libvlc_vlm_get_media_instance( p_instance, psz_name, i_instance );
|
2008-08-25 15:48:34 +02:00
|
|
|
if( p_mi )
|
|
|
|
vlm_media_instance_Delete( p_mi );
|
2009-04-04 11:55:17 +02:00
|
|
|
return p_mi ? 0 : -1;
|
2008-08-25 15:48:34 +02:00
|
|
|
}
|
2007-03-07 22:47:25 +01:00
|
|
|
|
2008-08-25 15:48:34 +02:00
|
|
|
int libvlc_vlm_get_media_instance_chapter( libvlc_instance_t *p_instance,
|
2008-09-12 10:58:50 +02:00
|
|
|
const char *psz_name,
|
2010-02-03 20:37:14 +01:00
|
|
|
int i_instance )
|
2008-08-25 15:48:34 +02:00
|
|
|
{
|
2009-04-04 11:47:12 +02:00
|
|
|
vlm_media_instance_t *p_mi;
|
|
|
|
|
|
|
|
p_mi = libvlc_vlm_get_media_instance( p_instance, psz_name,
|
2010-02-03 20:37:14 +01:00
|
|
|
i_instance );
|
2008-08-25 15:48:34 +02:00
|
|
|
if( p_mi )
|
|
|
|
vlm_media_instance_Delete( p_mi );
|
2009-04-04 11:55:17 +02:00
|
|
|
return p_mi ? 0 : -1;
|
2008-08-25 15:48:34 +02:00
|
|
|
}
|
2007-03-07 22:47:25 +01:00
|
|
|
|
2008-08-25 15:48:34 +02:00
|
|
|
int libvlc_vlm_get_media_instance_seekable( libvlc_instance_t *p_instance,
|
2008-09-12 10:58:50 +02:00
|
|
|
const char *psz_name,
|
2010-02-03 20:37:14 +01:00
|
|
|
int i_instance )
|
2007-03-07 22:47:25 +01:00
|
|
|
{
|
2009-04-04 11:47:12 +02:00
|
|
|
vlm_media_instance_t *p_mi;
|
|
|
|
|
2010-02-03 20:37:14 +01:00
|
|
|
p_mi = libvlc_vlm_get_media_instance( p_instance, psz_name, i_instance );
|
2008-08-25 15:48:34 +02:00
|
|
|
if( p_mi )
|
|
|
|
vlm_media_instance_Delete( p_mi );
|
2009-04-04 11:55:17 +02:00
|
|
|
return p_mi ? 0 : -1;
|
2007-03-07 22:47:25 +01:00
|
|
|
}
|
2010-02-03 20:38:37 +01:00
|
|
|
#endif
|
2009-05-18 14:17:53 +02:00
|
|
|
|
2010-02-03 20:37:14 +01:00
|
|
|
libvlc_event_manager_t *
|
|
|
|
libvlc_vlm_get_event_manager( libvlc_instance_t *p_instance )
|
2009-05-18 14:17:53 +02:00
|
|
|
{
|
|
|
|
vlm_t *p_vlm;
|
|
|
|
VLM_RET( p_vlm, NULL);
|
2009-06-15 15:30:32 +02:00
|
|
|
return p_instance->libvlc_vlm.p_event_manager;
|
2009-05-18 14:17:53 +02:00
|
|
|
}
|