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
87151c41
Commit
87151c41
authored
Feb 20, 2010
by
Fabio Ritrovato
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Lua SD: use a function to get the SD description
parent
80db30df
Changes
1
Show whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
55 additions
and
41 deletions
+55
-41
modules/misc/lua/vlc.c
modules/misc/lua/vlc.c
+55
-41
No files found.
modules/misc/lua/vlc.c
View file @
87151c41
...
...
@@ -579,6 +579,7 @@ static int vlc_sd_probe_Open( vlc_object_t *obj )
char
*
psz_name
;
char
*
ppsz_dir_list
[]
=
{
NULL
,
NULL
,
NULL
,
NULL
};
char
**
ppsz_dir
;
lua_State
*
L
=
NULL
;
vlclua_dir_list
(
obj
,
"sd"
,
ppsz_dir_list
);
for
(
ppsz_dir
=
ppsz_dir_list
;
*
ppsz_dir
;
ppsz_dir
++
)
{
...
...
@@ -603,33 +604,47 @@ static int vlc_sd_probe_Open( vlc_object_t *obj )
{
goto
error
;
}
FILE
*
fd
=
vlc_fopen
(
psz_filename
,
"r"
);
if
(
fd
)
L
=
luaL_newstate
(
);
if
(
!
L
)
{
char
description
[
256
];
if
(
fgets
(
description
,
256
,
fd
)
!=
NULL
)
msg_Err
(
probe
,
"Could not create new Lua State"
);
return
VLC_EGENERIC
;
}
luaL_openlibs
(
L
);
if
(
vlclua_add_modules_path
(
probe
,
L
,
psz_filename
)
)
{
char
*
temp
=
strchr
(
description
,
'\n'
);
if
(
temp
)
*
temp
=
'\0'
;
temp
=
strchr
(
*
ppsz_file
,
'.'
);
msg_Err
(
probe
,
"Error while setting the module search path for %s"
,
psz_filename
);
goto
error
;
}
if
(
luaL_dofile
(
L
,
psz_filename
)
)
{
msg_Err
(
probe
,
"Error loading script %s: %s"
,
psz_filename
,
lua_tostring
(
L
,
lua_gettop
(
L
)
)
);
lua_pop
(
L
,
1
);
goto
error
;
}
char
*
psz_longname
;
char
*
temp
=
strchr
(
*
ppsz_file
,
'.'
);
if
(
temp
)
*
temp
=
'\0'
;
char
*
psz_longname
;
if
(
!
strncmp
(
description
,
"--SD_Description="
,
17
)
)
lua_getglobal
(
L
,
"descriptor"
)
;
if
(
!
lua_isfunction
(
L
,
lua_gettop
(
L
)
)
||
lua_pcall
(
L
,
0
,
1
,
0
)
)
{
if
(
!
(
psz_longname
=
strdup
(
description
+
17
)
)
)
lua_pop
(
L
,
1
);
if
(
!
(
psz_longname
=
strdup
(
*
ppsz_file
)
)
)
{
fclose
(
fd
);
free
(
psz_filename
);
goto
error
;
}
}
else
{
if
(
!
(
psz_longname
=
strdup
(
*
ppsz_file
)
)
)
lua_getfield
(
L
,
-
1
,
"title"
);
if
(
!
lua_isstring
(
L
,
-
1
)
||
!
(
psz_longname
=
strdup
(
lua_tostring
(
L
,
-
1
)
)
)
)
{
fclose
(
fd
);
free
(
psz_filename
);
goto
error
;
}
...
...
@@ -637,7 +652,6 @@ static int vlc_sd_probe_Open( vlc_object_t *obj )
if
(
asprintf
(
&
psz_name
,
"lua{sd=%s,longname=%s}"
,
*
ppsz_file
,
psz_longname
)
<
0
)
{
fclose
(
fd
);
free
(
psz_filename
);
free
(
psz_longname
);
goto
error
;
...
...
@@ -645,10 +659,8 @@ static int vlc_sd_probe_Open( vlc_object_t *obj )
vlc_sd_probe_Add
(
probe
,
psz_name
,
psz_longname
,
SD_CAT_INTERNET
);
free
(
psz_name
);
free
(
psz_longname
);
}
fclose
(
fd
);
}
free
(
psz_filename
);
lua_close
(
L
);
}
}
if
(
ppsz_filelist
)
...
...
@@ -668,6 +680,8 @@ error:
free
(
*
ppsz_file
);
free
(
ppsz_filelist
);
}
if
(
L
)
lua_close
(
L
);
vlclua_dir_list_free
(
ppsz_dir_list
);
return
VLC_ENOMEM
;
}
...
...
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