Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in
Toggle navigation
V
vlc-gpu
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-gpu
Commits
ed0b82ee
Commit
ed0b82ee
authored
Feb 08, 2005
by
Laurent Aimar
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
* http: add a redirect from */index.html to */
parent
10f2eccc
Changes
1
Show whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
24 additions
and
5 deletions
+24
-5
modules/control/http.c
modules/control/http.c
+24
-5
No files found.
modules/control/http.c
View file @
ed0b82ee
...
@@ -173,6 +173,7 @@ struct httpd_file_sys_t
...
@@ -173,6 +173,7 @@ struct httpd_file_sys_t
intf_thread_t
*
p_intf
;
intf_thread_t
*
p_intf
;
httpd_file_t
*
p_file
;
httpd_file_t
*
p_file
;
httpd_redirect_t
*
p_redir
;
httpd_redirect_t
*
p_redir
;
httpd_redirect_t
*
p_redir2
;
char
*
file
;
char
*
file
;
char
*
name
;
char
*
name
;
...
@@ -388,9 +389,9 @@ void Close ( vlc_object_t *p_this )
...
@@ -388,9 +389,9 @@ void Close ( vlc_object_t *p_this )
{
{
httpd_FileDelete
(
p_sys
->
pp_files
[
i
]
->
p_file
);
httpd_FileDelete
(
p_sys
->
pp_files
[
i
]
->
p_file
);
if
(
p_sys
->
pp_files
[
i
]
->
p_redir
)
if
(
p_sys
->
pp_files
[
i
]
->
p_redir
)
{
httpd_RedirectDelete
(
p_sys
->
pp_files
[
i
]
->
p_redir
);
httpd_RedirectDelete
(
p_sys
->
pp_files
[
i
]
->
p_redir
);
}
if
(
p_sys
->
pp_files
[
i
]
->
p_redir2
)
httpd_RedirectDelete
(
p_sys
->
pp_files
[
i
]
->
p_redir2
);
free
(
p_sys
->
pp_files
[
i
]
->
file
);
free
(
p_sys
->
pp_files
[
i
]
->
file
);
free
(
p_sys
->
pp_files
[
i
]
->
name
);
free
(
p_sys
->
pp_files
[
i
]
->
name
);
...
@@ -464,7 +465,7 @@ static void Run( intf_thread_t *p_intf )
...
@@ -464,7 +465,7 @@ static void Run( intf_thread_t *p_intf )
/****************************************************************************
/****************************************************************************
* FileToUrl: create a good name for an url from filename
* FileToUrl: create a good name for an url from filename
****************************************************************************/
****************************************************************************/
static
char
*
FileToUrl
(
char
*
name
)
static
char
*
FileToUrl
(
char
*
name
,
vlc_bool_t
*
pb_index
)
{
{
char
*
url
,
*
p
;
char
*
url
,
*
p
;
...
@@ -500,12 +501,14 @@ static char *FileToUrl( char *name )
...
@@ -500,12 +501,14 @@ static char *FileToUrl( char *name )
}
}
#endif
#endif
*
pb_index
=
VLC_FALSE
;
/* index.* -> / */
/* index.* -> / */
if
(
(
p
=
strrchr
(
url
,
'/'
)
)
!=
NULL
)
if
(
(
p
=
strrchr
(
url
,
'/'
)
)
!=
NULL
)
{
{
if
(
!
strncmp
(
p
,
"/index."
,
7
)
)
if
(
!
strncmp
(
p
,
"/index."
,
7
)
)
{
{
p
[
1
]
=
'\0'
;
p
[
1
]
=
'\0'
;
*
pb_index
=
VLC_TRUE
;
}
}
}
}
return
url
;
return
url
;
...
@@ -594,12 +597,14 @@ static int ParseDirectory( intf_thread_t *p_intf, char *psz_root,
...
@@ -594,12 +597,14 @@ static int ParseDirectory( intf_thread_t *p_intf, char *psz_root,
if
(
ParseDirectory
(
p_intf
,
psz_root
,
dir
)
)
if
(
ParseDirectory
(
p_intf
,
psz_root
,
dir
)
)
{
{
httpd_file_sys_t
*
f
=
malloc
(
sizeof
(
httpd_file_sys_t
)
);
httpd_file_sys_t
*
f
=
malloc
(
sizeof
(
httpd_file_sys_t
)
);
vlc_bool_t
b_index
;
f
->
p_intf
=
p_intf
;
f
->
p_intf
=
p_intf
;
f
->
p_file
=
NULL
;
f
->
p_file
=
NULL
;
f
->
p_redir
=
NULL
;
f
->
p_redir
=
NULL
;
f
->
p_redir2
=
NULL
;
f
->
file
=
strdup
(
dir
);
f
->
file
=
strdup
(
dir
);
f
->
name
=
FileToUrl
(
&
dir
[
strlen
(
psz_root
)]
);
f
->
name
=
FileToUrl
(
&
dir
[
strlen
(
psz_root
)]
,
&
b_index
);
f
->
b_html
=
strstr
(
&
dir
[
strlen
(
psz_root
)],
".htm"
)
?
VLC_TRUE
:
VLC_FALSE
;
f
->
b_html
=
strstr
(
&
dir
[
strlen
(
psz_root
)],
".htm"
)
?
VLC_TRUE
:
VLC_FALSE
;
if
(
!
f
->
name
)
if
(
!
f
->
name
)
...
@@ -621,15 +626,29 @@ static int ParseDirectory( intf_thread_t *p_intf, char *psz_root,
...
@@ -621,15 +626,29 @@ static int ParseDirectory( intf_thread_t *p_intf, char *psz_root,
{
{
TAB_APPEND
(
p_sys
->
i_files
,
p_sys
->
pp_files
,
f
);
TAB_APPEND
(
p_sys
->
i_files
,
p_sys
->
pp_files
,
f
);
}
}
/* For rep/ add a redir from rep to rep/ */
/* for url that ends by / add
* - a redirect from rep to rep/
* - in case of index.* rep/index.html to rep/ */
if
(
f
&&
f
->
name
[
strlen
(
f
->
name
)
-
1
]
==
'/'
)
if
(
f
&&
f
->
name
[
strlen
(
f
->
name
)
-
1
]
==
'/'
)
{
{
char
*
psz_redir
=
strdup
(
f
->
name
);
char
*
psz_redir
=
strdup
(
f
->
name
);
char
*
p
;
psz_redir
[
strlen
(
psz_redir
)
-
1
]
=
'\0'
;
psz_redir
[
strlen
(
psz_redir
)
-
1
]
=
'\0'
;
msg_Dbg
(
p_intf
,
"redir=%s -> %s"
,
psz_redir
,
f
->
name
);
msg_Dbg
(
p_intf
,
"redir=%s -> %s"
,
psz_redir
,
f
->
name
);
f
->
p_redir
=
httpd_RedirectNew
(
p_sys
->
p_httpd_host
,
f
->
name
,
psz_redir
);
f
->
p_redir
=
httpd_RedirectNew
(
p_sys
->
p_httpd_host
,
f
->
name
,
psz_redir
);
free
(
psz_redir
);
free
(
psz_redir
);
if
(
b_index
&&
(
p
=
strstr
(
f
->
file
,
"index."
)
)
)
{
asprintf
(
&
psz_redir
,
"%s%s"
,
f
->
name
,
p
);
msg_Dbg
(
p_intf
,
"redir=%s -> %s"
,
psz_redir
,
f
->
name
);
f
->
p_redir2
=
httpd_RedirectNew
(
p_sys
->
p_httpd_host
,
f
->
name
,
psz_redir
);
free
(
psz_redir
);
}
}
}
}
}
}
}
...
...
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