Commit bb137a27 authored by Christophe Massiot's avatar Christophe Massiot

* modules/control/http.c: Added an id="include" macro to include

   another file. Also reduced MAX_DIR_PATH_LENGTH to 2560 since
   allocating anything larger than 4kB on the stack is likely to break
   on many OSes.
parent 28e27d84
...@@ -486,7 +486,7 @@ static void Run( intf_thread_t *p_intf ) ...@@ -486,7 +486,7 @@ static void Run( intf_thread_t *p_intf )
/***************************************************************************** /*****************************************************************************
* Local functions * Local functions
*****************************************************************************/ *****************************************************************************/
#define MAX_DIR_SIZE 10240 #define MAX_DIR_SIZE 2560
/**************************************************************************** /****************************************************************************
* FileToUrl: create a good name for an url from filename * FileToUrl: create a good name for an url from filename
...@@ -1923,6 +1923,7 @@ enum macroType ...@@ -1923,6 +1923,7 @@ enum macroType
MVLC_VLM_LOAD, MVLC_VLM_LOAD,
MVLC_VLM_SAVE, MVLC_VLM_SAVE,
MVLC_INCLUDE,
MVLC_FOREACH, MVLC_FOREACH,
MVLC_IF, MVLC_IF,
MVLC_RPN, MVLC_RPN,
...@@ -1982,6 +1983,7 @@ StrToMacroTypeTab [] = ...@@ -1982,6 +1983,7 @@ StrToMacroTypeTab [] =
{ "rpn", MVLC_RPN }, { "rpn", MVLC_RPN },
{ "stack", MVLC_STACK }, { "stack", MVLC_STACK },
{ "include", MVLC_INCLUDE },
{ "foreach", MVLC_FOREACH }, { "foreach", MVLC_FOREACH },
{ "value", MVLC_VALUE }, { "value", MVLC_VALUE },
...@@ -2624,7 +2626,7 @@ static void MacroDo( httpd_file_sys_t *p_args, ...@@ -2624,7 +2626,7 @@ static void MacroDo( httpd_file_sys_t *p_args,
EvaluateRPN( p_intf, p_args->vars, &p_args->stack, m->param1 ); EvaluateRPN( p_intf, p_args->vars, &p_args->stack, m->param1 );
break; break;
/* Usefull for learning stack management */ /* Useful to learn stack management */
case MVLC_STACK: case MVLC_STACK:
{ {
int i; int i;
...@@ -2731,6 +2733,46 @@ static void Execute( httpd_file_sys_t *p_args, ...@@ -2731,6 +2733,46 @@ static void Execute( httpd_file_sys_t *p_args,
switch( StrToMacroType( m.id ) ) switch( StrToMacroType( m.id ) )
{ {
case MVLC_INCLUDE:
{
FILE *f;
int i_buffer;
char *p_buffer;
char psz_file[MAX_DIR_SIZE];
char *p;
if( m.param1[0] != '/' )
{
strcpy( psz_file, p_args->file );
p = strrchr( psz_file, '/' );
if( p != NULL )
strcpy( p + 1, m.param1 );
else
strcpy( psz_file, m.param1 );
}
else
{
strcpy( psz_file, m.param1 );
}
if( ( f = fopen( psz_file, "r" ) ) == NULL )
{
msg_Warn( p_args->p_intf,
"unable to include file %s (%s)",
psz_file, strerror(errno) );
break;
}
/* first we load in a temporary buffer */
FileLoad( f, &p_buffer, &i_buffer );
/* we parse executing all <vlc /> macros */
Execute( p_args, p_request, i_request, pp_data, pi_data,
&dst, &p_buffer[0], &p_buffer[i_buffer] );
free( p_buffer );
fclose(f);
break;
}
case MVLC_IF: case MVLC_IF:
{ {
vlc_bool_t i_test; vlc_bool_t i_test;
......
...@@ -538,7 +538,7 @@ void httpd_FileDelete( httpd_file_t *file ) ...@@ -538,7 +538,7 @@ void httpd_FileDelete( httpd_file_t *file )
} }
/***************************************************************************** /*****************************************************************************
* High Level Funtions: httpd_redirect_t * High Level Functions: httpd_redirect_t
*****************************************************************************/ *****************************************************************************/
struct httpd_redirect_t struct httpd_redirect_t
{ {
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment