Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in
Toggle navigation
V
vlc-1.1
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Redmine
Redmine
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Operations
Operations
Metrics
Environments
Analytics
Analytics
CI / CD
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
videolan
vlc-1.1
Commits
4e5473ac
Commit
4e5473ac
authored
Mar 07, 2004
by
Olivier Teulière
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
* skins/vars/stream.cpp: support $N (stream name) and $F (full stream name)
parent
445d17b2
Changes
6
Hide whitespace changes
Inline
Side-by-side
Showing
6 changed files
with
181 additions
and
10 deletions
+181
-10
modules/gui/skins2/Modules.am
modules/gui/skins2/Modules.am
+2
-0
modules/gui/skins2/src/vlcproc.cpp
modules/gui/skins2/src/vlcproc.cpp
+23
-9
modules/gui/skins2/src/vlcproc.hpp
modules/gui/skins2/src/vlcproc.hpp
+7
-1
modules/gui/skins2/utils/var_text.cpp
modules/gui/skins2/utils/var_text.cpp
+20
-0
modules/gui/skins2/vars/stream.cpp
modules/gui/skins2/vars/stream.cpp
+80
-0
modules/gui/skins2/vars/stream.hpp
modules/gui/skins2/vars/stream.hpp
+49
-0
No files found.
modules/gui/skins2/Modules.am
View file @
4e5473ac
...
@@ -139,6 +139,8 @@ SOURCES_skins2 = \
...
@@ -139,6 +139,8 @@ SOURCES_skins2 = \
\
\
vars/playlist.cpp \
vars/playlist.cpp \
vars/playlist.hpp \
vars/playlist.hpp \
vars/stream.cpp \
vars/stream.hpp \
vars/time.cpp \
vars/time.cpp \
vars/time.hpp \
vars/time.hpp \
vars/volume.cpp \
vars/volume.cpp \
...
...
modules/gui/skins2/src/vlcproc.cpp
View file @
4e5473ac
...
@@ -2,7 +2,7 @@
...
@@ -2,7 +2,7 @@
* vlcproc.cpp
* vlcproc.cpp
*****************************************************************************
*****************************************************************************
* Copyright (C) 2003 VideoLAN
* Copyright (C) 2003 VideoLAN
* $Id
: vlcproc.cpp,v 1.4 2004/01/18 19:54:46 asmax Exp
$
* $Id$
*
*
* Authors: Cyril Deguet <asmax@via.ecp.fr>
* Authors: Cyril Deguet <asmax@via.ecp.fr>
* Olivier Teulire <ipkiss@via.ecp.fr>
* Olivier Teulire <ipkiss@via.ecp.fr>
...
@@ -64,29 +64,31 @@ VlcProc::VlcProc( intf_thread_t *pIntf ): SkinObject( pIntf )
...
@@ -64,29 +64,31 @@ VlcProc::VlcProc( intf_thread_t *pIntf ): SkinObject( pIntf )
// Create and register VLC variables
// Create and register VLC variables
VarManager
*
pVarManager
=
VarManager
::
instance
(
getIntf
()
);
VarManager
*
pVarManager
=
VarManager
::
instance
(
getIntf
()
);
#define REGISTER_VAR( var, type, name ) \
#define REGISTER_VAR( var, type, name ) \
var = VariablePtr( new type( getIntf() ) ); \
var = VariablePtr( new type( getIntf() ) ); \
pVarManager->registerVar( var, name );
pVarManager->registerVar( var, name );
REGISTER_VAR
(
m_cPlaylist
,
Playlist
,
"playlist"
)
REGISTER_VAR
(
m_cPlaylist
,
Playlist
,
"playlist"
)
pVarManager
->
registerVar
(
getPlaylistVar
().
getPositionVarPtr
(),
pVarManager
->
registerVar
(
getPlaylistVar
().
getPositionVarPtr
(),
"playlist.slider"
);
"playlist.slider"
);
REGISTER_VAR
(
m_cVarTime
,
Time
,
"time"
)
REGISTER_VAR
(
m_cVarTime
,
Time
,
"time"
)
REGISTER_VAR
(
m_cVarVolume
,
Volume
,
"volume"
)
REGISTER_VAR
(
m_cVarVolume
,
Volume
,
"volume"
)
REGISTER_VAR
(
m_cVarStream
,
Stream
,
"stream"
)
REGISTER_VAR
(
m_cVarMute
,
VarBoolImpl
,
"vlc.isMute"
)
// XXX broken
REGISTER_VAR
(
m_cVarMute
,
VarBoolImpl
,
"vlc.isMute"
)
// XXX broken
REGISTER_VAR
(
m_cVarPlaying
,
VarBoolImpl
,
"vlc.isPlaying"
)
REGISTER_VAR
(
m_cVarPlaying
,
VarBoolImpl
,
"vlc.isPlaying"
)
REGISTER_VAR
(
m_cVarStopped
,
VarBoolImpl
,
"vlc.isStopped"
)
REGISTER_VAR
(
m_cVarStopped
,
VarBoolImpl
,
"vlc.isStopped"
)
REGISTER_VAR
(
m_cVarPaused
,
VarBoolImpl
,
"vlc.isPaused"
)
REGISTER_VAR
(
m_cVarPaused
,
VarBoolImpl
,
"vlc.isPaused"
)
REGISTER_VAR
(
m_cVarSeekable
,
VarBoolImpl
,
"vlc.isSeekable"
)
REGISTER_VAR
(
m_cVarSeekable
,
VarBoolImpl
,
"vlc.isSeekable"
)
#undef REGISTER_VAR
// Called when the playlist changes
// Called when the playlist changes
var_AddCallback
(
pIntf
->
p_sys
->
p_playlist
,
"intf-change"
,
var_AddCallback
(
pIntf
->
p_sys
->
p_playlist
,
"intf-change"
,
onIntfChange
,
this
);
onIntfChange
,
this
);
// Called when the current played item changes
// Called when the current played item changes
var_AddCallback
(
pIntf
->
p_sys
->
p_playlist
,
"playlist-current"
,
var_AddCallback
(
pIntf
->
p_sys
->
p_playlist
,
"playlist-current"
,
onPlaylistChange
,
this
);
onPlaylistChange
,
this
);
// Called when a playlist item
s
changed
// Called when a playlist item changed
var_AddCallback
(
pIntf
->
p_sys
->
p_playlist
,
"item-change"
,
var_AddCallback
(
pIntf
->
p_sys
->
p_playlist
,
"item-change"
,
onItemChange
,
this
);
onItemChange
,
this
);
getIntf
()
->
p_sys
->
p_input
=
NULL
;
getIntf
()
->
p_sys
->
p_input
=
NULL
;
...
@@ -229,6 +231,18 @@ int VlcProc::onPlaylistChange( vlc_object_t *pObj, const char *pVariable,
...
@@ -229,6 +231,18 @@ int VlcProc::onPlaylistChange( vlc_object_t *pObj, const char *pVariable,
{
{
VlcProc
*
pThis
=
(
VlcProc
*
)
pParam
;
VlcProc
*
pThis
=
(
VlcProc
*
)
pParam
;
// Update the stream variable
// XXX: we should not need to access p_inpu->psz_source directly, a
// getter should be provided by VLC core
playlist_t
*
p_playlist
=
(
playlist_t
*
)
pObj
;
if
(
p_playlist
->
p_input
)
{
Stream
*
pStream
=
(
Stream
*
)
pThis
->
m_cVarStream
.
get
();
UString
srcName
(
pThis
->
getIntf
(),
p_playlist
->
p_input
->
psz_source
);
pStream
->
set
(
srcName
,
false
);
}
// Create a playlist notify command
// Create a playlist notify command
// TODO: selective update
// TODO: selective update
CmdNotifyPlaylist
*
pCmd
=
new
CmdNotifyPlaylist
(
pThis
->
getIntf
()
);
CmdNotifyPlaylist
*
pCmd
=
new
CmdNotifyPlaylist
(
pThis
->
getIntf
()
);
...
@@ -237,9 +251,9 @@ int VlcProc::onPlaylistChange( vlc_object_t *pObj, const char *pVariable,
...
@@ -237,9 +251,9 @@ int VlcProc::onPlaylistChange( vlc_object_t *pObj, const char *pVariable,
AsyncQueue
*
pQueue
=
AsyncQueue
::
instance
(
pThis
->
getIntf
()
);
AsyncQueue
*
pQueue
=
AsyncQueue
::
instance
(
pThis
->
getIntf
()
);
pQueue
->
remove
(
"notify playlist"
);
pQueue
->
remove
(
"notify playlist"
);
pQueue
->
push
(
CmdGenericPtr
(
pCmd
)
);
pQueue
->
push
(
CmdGenericPtr
(
pCmd
)
);
/*
p_playlist_dialog->UpdateItem( old_val.i_int );
//
p_playlist_dialog->UpdateItem( old_val.i_int );
p_playlist_dialog->UpdateItem( new_val.i_int );*/
// p_playlist_dialog->UpdateItem( new_val.i_int );
return
VLC_SUCCESS
;
return
VLC_SUCCESS
;
}
}
modules/gui/skins2/src/vlcproc.hpp
View file @
4e5473ac
...
@@ -2,7 +2,7 @@
...
@@ -2,7 +2,7 @@
* vlcproc.hpp
* vlcproc.hpp
*****************************************************************************
*****************************************************************************
* Copyright (C) 2003 VideoLAN
* Copyright (C) 2003 VideoLAN
* $Id
: vlcproc.hpp,v 1.4 2004/01/18 19:54:46 asmax Exp
$
* $Id$
*
*
* Authors: Cyril Deguet <asmax@via.ecp.fr>
* Authors: Cyril Deguet <asmax@via.ecp.fr>
* Olivier Teulire <ipkiss@via.ecp.fr>
* Olivier Teulire <ipkiss@via.ecp.fr>
...
@@ -28,6 +28,7 @@
...
@@ -28,6 +28,7 @@
#include "../vars/playlist.hpp"
#include "../vars/playlist.hpp"
#include "../vars/time.hpp"
#include "../vars/time.hpp"
#include "../vars/volume.hpp"
#include "../vars/volume.hpp"
#include "../vars/stream.hpp"
class
OSTimer
;
class
OSTimer
;
class
VarBool
;
class
VarBool
;
...
@@ -53,6 +54,9 @@ class VlcProc: public SkinObject
...
@@ -53,6 +54,9 @@ class VlcProc: public SkinObject
/// Getter for the volume variable
/// Getter for the volume variable
Volume
&
getVolumeVar
()
{
return
*
((
Volume
*
)(
m_cVarVolume
.
get
()));
}
Volume
&
getVolumeVar
()
{
return
*
((
Volume
*
)(
m_cVarVolume
.
get
()));
}
/// Getter for the stream variable
Stream
&
getStreamVar
()
{
return
*
((
Stream
*
)(
m_cVarStream
.
get
()));
}
/// Getter for the mute variable
/// Getter for the mute variable
VarBool
&
getIsMuteVar
()
{
return
*
((
VarBool
*
)(
m_cVarMute
.
get
()));
}
VarBool
&
getIsMuteVar
()
{
return
*
((
VarBool
*
)(
m_cVarMute
.
get
()));
}
...
@@ -82,6 +86,8 @@ class VlcProc: public SkinObject
...
@@ -82,6 +86,8 @@ class VlcProc: public SkinObject
VariablePtr
m_cVarTime
;
VariablePtr
m_cVarTime
;
/// Variable for audio volume
/// Variable for audio volume
VariablePtr
m_cVarVolume
;
VariablePtr
m_cVarVolume
;
/// Variable for current stream properties (only name, currently)
VariablePtr
m_cVarStream
;
/// Variable for the "mute" state
/// Variable for the "mute" state
VariablePtr
m_cVarMute
;
VariablePtr
m_cVarMute
;
/// Variables related to the input
/// Variables related to the input
...
...
modules/gui/skins2/utils/var_text.cpp
View file @
4e5473ac
...
@@ -27,6 +27,7 @@
...
@@ -27,6 +27,7 @@
#include "../src/var_manager.hpp"
#include "../src/var_manager.hpp"
#include "../vars/time.hpp"
#include "../vars/time.hpp"
#include "../vars/volume.hpp"
#include "../vars/volume.hpp"
#include "../vars/stream.hpp"
const
string
VarText
::
m_type
=
"text"
;
const
string
VarText
::
m_type
=
"text"
;
...
@@ -85,6 +86,16 @@ const UString VarText::get() const
...
@@ -85,6 +86,16 @@ const UString VarText::get() const
temp
.
replace
(
pos
,
2
,
temp
.
replace
(
pos
,
2
,
pVlcProc
->
getVolumeVar
().
getAsStringPercent
().
c_str
()
);
pVlcProc
->
getVolumeVar
().
getAsStringPercent
().
c_str
()
);
}
}
while
(
(
pos
=
temp
.
find
(
"$N"
))
!=
UString
::
npos
)
{
temp
.
replace
(
pos
,
2
,
pVlcProc
->
getStreamVar
().
getAsStringName
().
c_str
()
);
}
while
(
(
pos
=
temp
.
find
(
"$F"
))
!=
UString
::
npos
)
{
temp
.
replace
(
pos
,
2
,
pVlcProc
->
getStreamVar
().
getAsStringFullName
().
c_str
()
);
}
return
temp
;
return
temp
;
}
}
...
@@ -102,6 +113,7 @@ void VarText::set( const UString &rText )
...
@@ -102,6 +113,7 @@ void VarText::set( const UString &rText )
VlcProc
*
pVlcProc
=
VlcProc
::
instance
(
getIntf
()
);
VlcProc
*
pVlcProc
=
VlcProc
::
instance
(
getIntf
()
);
pVlcProc
->
getTimeVar
().
delObserver
(
this
);
pVlcProc
->
getTimeVar
().
delObserver
(
this
);
pVlcProc
->
getVolumeVar
().
delObserver
(
this
);
pVlcProc
->
getVolumeVar
().
delObserver
(
this
);
pVlcProc
->
getStreamVar
().
delObserver
(
this
);
VarManager
*
pVarManager
=
VarManager
::
instance
(
getIntf
()
);
VarManager
*
pVarManager
=
VarManager
::
instance
(
getIntf
()
);
pVarManager
->
getHelpText
().
delObserver
(
this
);
pVarManager
->
getHelpText
().
delObserver
(
this
);
...
@@ -128,6 +140,14 @@ void VarText::set( const UString &rText )
...
@@ -128,6 +140,14 @@ void VarText::set( const UString &rText )
{
{
pVlcProc
->
getVolumeVar
().
addObserver
(
this
);
pVlcProc
->
getVolumeVar
().
addObserver
(
this
);
}
}
if
(
m_text
.
find
(
"$N"
)
!=
UString
::
npos
)
{
pVlcProc
->
getStreamVar
().
addObserver
(
this
);
}
if
(
m_text
.
find
(
"$F"
)
!=
UString
::
npos
)
{
pVlcProc
->
getStreamVar
().
addObserver
(
this
);
}
notify
();
notify
();
}
}
...
...
modules/gui/skins2/vars/stream.cpp
0 → 100644
View file @
4e5473ac
/*****************************************************************************
* time.cpp
*****************************************************************************
* Copyright (C) 2003 VideoLAN
* $Id: time.cpp 6996 2004-03-07 12:55:32Z ipkiss $
*
* Authors: Olivier Teulière <ipkiss@via.ecp.fr>
*
* 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., 59 Temple Place - Suite 330, Boston, MA 02111, USA.
*****************************************************************************/
#include <stdio.h> // snprintf
#include "stream.hpp"
#include "../utils/ustring.hpp"
#include "../src/os_factory.hpp"
#include <vlc/input.h>
void
Stream
::
set
(
const
UString
&
name
,
bool
updateVLC
)
{
VarText
::
set
(
name
);
// Avoid looping forever...
if
(
updateVLC
)
{
// We have nothing to do here, until we decide that the user
// can change a stream name on the fly...
}
}
const
string
Stream
::
getAsStringName
()
const
{
string
fullName
=
getAsStringFullName
();
// XXX: This should be done in VLC core, not here...
// Remove path information if any
OSFactory
*
pFactory
=
OSFactory
::
instance
(
getIntf
()
);
string
::
size_type
pos
=
fullName
.
rfind
(
pFactory
->
getDirSeparator
()
);
if
(
pos
!=
string
::
npos
)
{
fullName
=
fullName
.
substr
(
pos
+
1
,
fullName
.
size
()
-
pos
+
1
);
}
return
fullName
;
}
const
string
Stream
::
getAsStringFullName
()
const
{
string
ret
;
// XXX: we are not using geIntf()->p_sys->p_input direclty here, because it
// is not updated by VlcProc yet. Anyway, we shouldn't need to do that,
// because VLC core should provide getter functions for the stream name...
if
(
getIntf
()
->
p_sys
->
p_playlist
->
p_input
==
NULL
)
{
ret
=
""
;
}
else
{
ret
=
getIntf
()
->
p_sys
->
p_playlist
->
p_input
->
psz_source
;
}
return
ret
;
}
modules/gui/skins2/vars/stream.hpp
0 → 100644
View file @
4e5473ac
/*****************************************************************************
* stream.hpp
*****************************************************************************
* Copyright (C) 2003 VideoLAN
* $Id: time.hpp 6996 2004-03-07 12:55:32Z ipkiss $
*
* Authors: Olivier Teulière <ipkiss@via.ecp.fr>
*
* 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., 59 Temple Place - Suite 330, Boston, MA 02111, USA.
*****************************************************************************/
#ifndef STREAM_HPP
#define STREAM_HPP
#include "../utils/var_text.hpp"
#include <string>
class
UString
;
/// Variable for VLC volume
class
Stream
:
public
VarText
{
public:
Stream
(
intf_thread_t
*
pIntf
)
:
VarText
(
pIntf
)
{}
virtual
~
Stream
()
{}
virtual
void
set
(
const
UString
&
name
,
bool
updateVLC
);
virtual
void
set
(
const
UString
&
name
)
{
set
(
name
,
true
);
}
/// Return current stream name
virtual
const
string
getAsStringName
()
const
;
/// Return current stream full name (i.e. including path)
virtual
const
string
getAsStringFullName
()
const
;
};
#endif
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment