Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in
Toggle navigation
V
vlc-2-2
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-2-2
Commits
a72aa02a
Commit
a72aa02a
authored
May 26, 2010
by
Laurent Aimar
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Removed all vlc_object_find in lua osd code.
I highly doubt that the osd register/clear functions are usable...
parent
4d5258cf
Changes
1
Hide whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
41 additions
and
24 deletions
+41
-24
modules/misc/lua/libs/osd.c
modules/misc/lua/libs/osd.c
+41
-24
No files found.
modules/misc/lua/libs/osd.c
View file @
a72aa02a
...
...
@@ -40,6 +40,7 @@
#include "../vlc.h"
#include "../libs.h"
#include "input.h"
/*****************************************************************************
* OSD
...
...
@@ -72,31 +73,36 @@ static int vlclua_osd_icon( lua_State *L )
int
i_chan
=
luaL_optint
(
L
,
2
,
SPU_DEFAULT_CHANNEL
);
if
(
!
i_icon
)
return
luaL_error
(
L
,
"
\"
%s
\"
is not a valid osd icon."
,
psz_icon
);
else
input_thread_t
*
p_input
=
vlclua_get_input_internal
(
L
);
if
(
p_input
)
{
vlc_object_t
*
p_this
=
vlclua_get_this
(
L
);
vout_thread_t
*
p_vout
=
vlc_object_find
(
p_this
,
VLC_OBJECT_VOUT
,
FIND_ANYWHERE
);
vout_thread_t
*
p_vout
=
input_GetVout
(
p_input
);
if
(
p_vout
)
{
vout_OSDIcon
(
p_vout
,
i_chan
,
i_icon
);
vlc_object_release
(
p_vout
);
}
return
0
;
vlc_object_release
(
p_input
)
;
}
return
0
;
}
static
int
vlclua_osd_message
(
lua_State
*
L
)
{
const
char
*
psz_message
=
luaL_checkstring
(
L
,
1
);
int
i_chan
=
luaL_optint
(
L
,
2
,
SPU_DEFAULT_CHANNEL
);
vlc_object_t
*
p_this
=
vlclua_get_this
(
L
);
vout_thread_t
*
p_vout
=
vlc_object_find
(
p_this
,
VLC_OBJECT_VOUT
,
FIND_ANYWHERE
);
if
(
p_vout
)
input_thread_t
*
p_input
=
vlclua_get_input_internal
(
L
);
if
(
p_input
)
{
vout_OSDMessage
(
p_vout
,
i_chan
,
"%s"
,
psz_message
);
vlc_object_release
(
p_vout
);
vout_thread_t
*
p_vout
=
input_GetVout
(
p_input
);
if
(
p_vout
)
{
vout_OSDMessage
(
p_vout
,
i_chan
,
"%s"
,
psz_message
);
vlc_object_release
(
p_vout
);
}
vlc_object_release
(
p_input
);
}
return
0
;
}
...
...
@@ -129,31 +135,37 @@ static int vlclua_osd_slider( lua_State *L )
if
(
!
i_type
)
return
luaL_error
(
L
,
"
\"
%s
\"
is not a valid slider type."
,
psz_type
);
else
input_thread_t
*
p_input
=
vlclua_get_input_internal
(
L
);
if
(
p_input
)
{
vlc_object_t
*
p_this
=
vlclua_get_this
(
L
);
vout_thread_t
*
p_vout
=
vlc_object_find
(
p_this
,
VLC_OBJECT_VOUT
,
FIND_ANYWHERE
);
vout_thread_t
*
p_vout
=
input_GetVout
(
p_input
);
if
(
p_vout
)
{
vout_OSDSlider
(
p_vout
,
i_chan
,
i_position
,
i_type
);
vlc_object_release
(
p_vout
);
}
return
0
;
vlc_object_release
(
p_input
)
;
}
return
0
;
}
static
int
vlclua_spu_channel_register
(
lua_State
*
L
)
{
int
i_chan
;
vlc_object_t
*
p_this
=
vlclua_get_this
(
L
);
vout_thread_t
*
p_vout
=
vlc_object_find
(
p_this
,
VLC_OBJECT_VOUT
,
FIND_ANYWHERE
);
input_thread_t
*
p_input
=
vlclua_get_input_internal
(
L
);
if
(
!
p_input
)
return
luaL_error
(
L
,
"Unable to find input."
);
vout_thread_t
*
p_vout
=
input_GetVout
(
p_input
);
if
(
!
p_vout
)
{
vlc_object_release
(
p_input
);
return
luaL_error
(
L
,
"Unable to find vout."
);
}
i_chan
=
vout_RegisterSubpictureChannel
(
p_vout
);
i
nt
i
_chan
=
vout_RegisterSubpictureChannel
(
p_vout
);
vlc_object_release
(
p_vout
);
vlc_object_release
(
p_input
);
lua_pushinteger
(
L
,
i_chan
);
return
1
;
}
...
...
@@ -161,14 +173,19 @@ static int vlclua_spu_channel_register( lua_State *L )
static
int
vlclua_spu_channel_clear
(
lua_State
*
L
)
{
int
i_chan
=
luaL_checkint
(
L
,
1
);
vlc_object_t
*
p_this
=
vlclua_get_this
(
L
);
vout_thread_t
*
p_vout
=
vlc_object_find
(
p_this
,
VLC_OBJECT_VOUT
,
FIND_ANYWHERE
);
input_thread_t
*
p_input
=
vlclua_get_input_internal
(
L
);
if
(
!
p_input
)
return
luaL_error
(
L
,
"Unable to find input."
);
vout_thread_t
*
p_vout
=
input_GetVout
(
p_input
);
if
(
!
p_vout
)
{
vlc_object_release
(
p_input
);
return
luaL_error
(
L
,
"Unable to find vout."
);
}
vout_FlushSubpictureChannel
(
p_vout
,
i_chan
);
vlc_object_release
(
p_vout
);
vlc_object_release
(
p_input
);
return
0
;
}
...
...
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