Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in
Toggle navigation
V
vlc
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
Commits
fa37652a
Commit
fa37652a
authored
Mar 27, 2006
by
Rémi Denis-Courmont
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Use utf8_scandir instead of scandir
parent
168549fa
Changes
1
Show whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
43 additions
and
46 deletions
+43
-46
modules/control/http/mvar.c
modules/control/http/mvar.c
+43
-46
No files found.
modules/control/http/mvar.c
View file @
fa37652a
/*****************************************************************************
* mvar.c : Variables handling for the HTTP Interface
*****************************************************************************
* Copyright (C) 2001-200
5
the VideoLAN team
* Copyright (C) 2001-200
6
the VideoLAN team
* $Id$
*
* Authors: Gildas Bazin <gbazin@netcourrier.com>
...
...
@@ -26,15 +26,15 @@
#include "http.h"
/* Utility function for scandir */
static
int
Filter
(
const
struct
dirent
*
foo
)
static
int
Filter
(
const
char
*
foo
)
{
return
VLC_TRUE
;
return
strcmp
(
foo
,
"."
)
;
};
static
int
InsensitiveAlphasort
(
const
struct
dirent
**
foo1
,
const
struct
dirent
**
foo2
)
static
int
InsensitiveAlphasort
(
const
char
**
foo1
,
const
char
**
foo2
)
{
return
strcasecmp
(
(
*
foo1
)
->
d_name
,
(
*
foo2
)
->
d_name
);
return
strcasecmp
(
*
foo1
,
*
foo2
);
};
...
...
@@ -526,25 +526,23 @@ mvar_t *E_(mvar_FileSetNew)( intf_thread_t *p_intf, char *name,
char
*
psz_dir
)
{
mvar_t
*
s
=
E_
(
mvar_New
)(
name
,
"set"
);
char
tmp
[
MAX_DIR_SIZE
];
#ifdef HAVE_SYS_STAT_H
struct
stat
stat_info
;
#endif
struct
dirent
**
pp
_dir_content
;
char
**
ppsz
_dir_content
;
int
i_dir_content
,
i
;
char
sep
;
/* convert all / to native separator */
#if defined( WIN32 )
sep
=
'\\'
;
const
char
sep
=
'\\'
;
#else
sep
=
'/'
;
const
char
sep
=
'/'
;
#endif
psz_dir
=
E_
(
RealPath
)(
p_intf
,
psz_dir
);
#ifdef HAVE_SYS_STAT_H
if
(
(
stat
(
psz_dir
,
&
stat_info
)
==
-
1
||
!
S_ISDIR
(
stat_info
.
st_mode
))
if
(
(
utf8_stat
(
psz_dir
,
&
stat_info
)
==
-
1
)
||
!
S_ISDIR
(
stat_info
.
st_mode
)
# if defined( WIN32 )
&&
psz_dir
[
0
]
!=
'\0'
&&
(
psz_dir
[
0
]
!=
'\\'
||
psz_dir
[
1
]
!=
'\0'
)
# endif
...
...
@@ -556,7 +554,7 @@ mvar_t *E_(mvar_FileSetNew)( intf_thread_t *p_intf, char *name,
#endif
/* parse psz_src dir */
if
(
(
i_dir_content
=
scandir
(
psz_dir
,
&
pp
_dir_content
,
Filter
,
if
(
(
i_dir_content
=
utf8_scandir
(
psz_dir
,
&
ppsz
_dir_content
,
Filter
,
InsensitiveAlphasort
)
)
==
-
1
)
{
msg_Warn
(
p_intf
,
"scandir error on %s (%s)"
,
psz_dir
,
...
...
@@ -567,56 +565,52 @@ mvar_t *E_(mvar_FileSetNew)( intf_thread_t *p_intf, char *name,
for
(
i
=
0
;
i
<
i_dir_content
;
i
++
)
{
struct
dirent
*
p_dir_content
=
pp_dir_content
[
i
];
char
*
psz_dir_content
=
ppsz_dir_content
[
i
];
char
psz_tmp
[
strlen
(
psz_dir
)
+
1
+
strlen
(
psz_dir_content
)
+
1
];
mvar_t
*
f
;
char
*
psz_name
,
*
psz_tmp
,
*
psz_ext
;
if
(
!
strcmp
(
p_dir_content
->
d_name
,
"."
)
)
{
continue
;
}
char
*
psz_name
,
*
psz_ext
,
*
psz_dummy
;
#if defined( WIN32 )
if
(
psz_dir
[
0
]
==
'\0'
||
(
psz_dir
[
0
]
==
'\\'
&&
psz_dir
[
1
]
==
'\0'
)
)
{
s
nprintf
(
tmp
,
sizeof
(
tmp
),
"%s"
,
p_dir_content
->
d_name
);
s
trcpy
(
psz_tmp
,
psz_dir_content
);
}
else
#endif
{
snprintf
(
tmp
,
sizeof
(
tmp
),
"%s%c%s"
,
psz_dir
,
sep
,
p_dir_content
->
d_name
);
sprintf
(
psz_tmp
,
"%s%c%s"
,
psz_dir
,
sep
,
psz_dir_content
);
#ifdef HAVE_SYS_STAT_H
if
(
stat
(
tmp
,
&
stat_info
)
==
-
1
)
if
(
utf8_stat
(
psz_
tmp
,
&
stat_info
)
==
-
1
)
{
free
(
psz_dir_content
);
continue
;
}
#endif
}
f
=
E_
(
mvar_New
)(
name
,
"set"
);
psz_tmp
=
vlc_fix_readdir_charset
(
p_intf
,
p_dir_content
->
d_name
);
psz_name
=
E_
(
FromUTF8
)(
p_intf
,
psz_tmp
);
free
(
psz_tmp
);
/* FIXME: merge vlc_fix_readdir_charset with utf8_readir */
psz_dummy
=
vlc_fix_readdir_charset
(
p_intf
,
psz_dir_content
);
psz_name
=
E_
(
FromUTF8
)(
p_intf
,
psz_dummy
);
free
(
psz_dummy
);
/* put lower-case file extension in 'ext' */
psz_ext
=
strrchr
(
psz_name
,
'.'
);
psz_tmp
=
psz_ext
=
strdup
(
psz_ext
!=
NULL
?
psz_ext
+
1
:
""
);
while
(
*
psz_tmp
!=
'\0'
)
{
*
psz_tmp
=
tolower
(
*
psz_tmp
);
psz_tmp
++
;
}
psz_ext
=
strdup
(
psz_ext
!=
NULL
?
psz_ext
+
1
:
""
);
for
(
psz_dummy
=
psz_ext
;
*
psz_dummy
!=
'\0'
;
psz_dummy
++
)
*
psz_dummy
=
tolower
(
*
psz_dummy
);
E_
(
mvar_AppendNewVar
)(
f
,
"ext"
,
psz_ext
);
free
(
psz_ext
);
#if defined( WIN32 )
if
(
psz_dir
[
0
]
==
'\0'
||
(
psz_dir
[
0
]
==
'\\'
&&
psz_dir
[
1
]
==
'\0'
)
)
{
snprintf
(
tmp
,
sizeof
(
tmp
),
"%c:"
,
psz_name
[
0
]
);
char
psz_tmp
[
3
];
sprintf
(
psz_tmp
,
"%c:"
,
psz_name
[
0
]
);
E_
(
mvar_AppendNewVar
)(
f
,
"name"
,
psz_name
);
E_
(
mvar_AppendNewVar
)(
f
,
"basename"
,
tmp
);
E_
(
mvar_AppendNewVar
)(
f
,
"basename"
,
psz_
tmp
);
E_
(
mvar_AppendNewVar
)(
f
,
"type"
,
"directory"
);
E_
(
mvar_AppendNewVar
)(
f
,
"size"
,
"unknown"
);
E_
(
mvar_AppendNewVar
)(
f
,
"date"
,
"unknown"
);
...
...
@@ -624,8 +618,11 @@ mvar_t *E_(mvar_FileSetNew)( intf_thread_t *p_intf, char *name,
else
#endif
{
snprintf
(
tmp
,
sizeof
(
tmp
),
"%s%c%s"
,
psz_dir
,
sep
,
psz_name
);
E_
(
mvar_AppendNewVar
)(
f
,
"name"
,
tmp
);
char
psz_ctime
[
26
];
char
psz_tmp
[
strlen
(
psz_dir
)
+
1
+
strlen
(
psz_name
)
+
1
];
sprintf
(
psz_tmp
,
"%s%c%s"
,
psz_dir
,
sep
,
psz_name
);
E_
(
mvar_AppendNewVar
)(
f
,
"name"
,
psz_tmp
);
E_
(
mvar_AppendNewVar
)(
f
,
"basename"
,
psz_name
);
#ifdef HAVE_SYS_STAT_H
...
...
@@ -642,13 +639,13 @@ mvar_t *E_(mvar_FileSetNew)( intf_thread_t *p_intf, char *name,
E_
(
mvar_AppendNewVar
)(
f
,
"type"
,
"unknown"
);
}
sprintf
(
tmp
,
I64Fd
,
(
int64_t
)
stat_info
.
st_size
);
E_
(
mvar_AppendNewVar
)(
f
,
"size"
,
tmp
);
sprintf
(
psz_ctime
,
I64Fd
,
(
int64_t
)
stat_info
.
st_size
);
E_
(
mvar_AppendNewVar
)(
f
,
"size"
,
psz_ctime
);
/* FIXME memory leak FIXME */
# ifdef HAVE_CTIME_R
ctime_r
(
&
stat_info
.
st_mtime
,
tmp
);
E_
(
mvar_AppendNewVar
)(
f
,
"date"
,
tmp
);
ctime_r
(
&
stat_info
.
st_mtime
,
psz_ctime
);
E_
(
mvar_AppendNewVar
)(
f
,
"date"
,
psz_ctime
);
# else
E_
(
mvar_AppendNewVar
)(
f
,
"date"
,
ctime
(
&
stat_info
.
st_mtime
)
);
# endif
...
...
@@ -663,12 +660,12 @@ mvar_t *E_(mvar_FileSetNew)( intf_thread_t *p_intf, char *name,
E_
(
mvar_AppendVar
)(
s
,
f
);
free
(
psz_name
);
free
(
psz_dir_content
);
}
free
(
psz_dir
);
for
(
i
=
0
;
i
<
i_dir_content
;
i
++
)
if
(
pp_dir_content
[
i
]
)
free
(
pp_dir_content
[
i
]
);
if
(
pp_dir_content
)
free
(
pp_dir_content
);
if
(
ppsz_dir_content
!=
NULL
)
free
(
ppsz_dir_content
);
return
s
;
}
...
...
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