diff --git a/.todo b/.todo
new file mode 100644
index 0000000..7195972
--- /dev/null
+++ b/.todo
@@ -0,0 +1,26 @@
+
+
+ readme:iframe
+
+ done in r23
+
+
+
+ readme:div
+
+
+ readme:pre
+
+
+ header:inline
+
+
+ header:cache
+
+
+ footer:inline
+
+
+ footer:cache
+
+
diff --git a/README.rst b/README.rst
index b0d14de..7cebeb2 100644
--- a/README.rst
+++ b/README.rst
@@ -32,7 +32,7 @@ Building
4. Build and install the software::
$ make
-
+
And then, as ``root``::
# make install
@@ -130,6 +130,23 @@ fancyindex_readme_options
will instruct the client to perform an additional request in order to
fetch the contents of the frame.
+fancyindex_mode
+:Syntax: *fancyindex_mode* *static* | *cached*
+:Default: *fancyindex_mode static*
+:Context: http, server, location
+:Description:
+ Controls how to include the header and footer specified by
+ `fancyindex_header`_ and `fancyindex_footer`_, Available options are:
+
+ static
+ Read file contents on each request. This is the less efficient method,
+ but generated content will always follow on-disk changes of head and
+ footer templates.
+ cached
+ Header and footer contents will be read the first time they are
+ needed, and kept in memory for thei use in subsequent requests. If the
+ modification time of files changes, they will be re-read as needed.
+
.. _nginx: http://nginx.net
diff --git a/ngx_http_fancyindex_module.c b/ngx_http_fancyindex_module.c
index eb9b1c0..d4dbf0f 100644
--- a/ngx_http_fancyindex_module.c
+++ b/ngx_http_fancyindex_module.c
@@ -36,13 +36,6 @@ typedef struct {
#endif
-#define NGX_HTTP_FANCYINDEX_README_TOP 0x00
-#define NGX_HTTP_FANCYINDEX_README_PRE 0x00
-#define NGX_HTTP_FANCYINDEX_README_ASIS 0x01
-#define NGX_HTTP_FANCYINDEX_README_BOTTOM 0x02
-#define NGX_HTTP_FANCYINDEX_README_DIV 0x04
-#define NGX_HTTP_FANCYINDEX_README_IFRAME 0x08
-
typedef struct {
ngx_str_t name;
@@ -54,23 +47,46 @@ typedef struct {
} ngx_http_fancyindex_entry_t;
+#define NGX_HTTP_FANCYINDEX_README_TOP 0x00
+#define NGX_HTTP_FANCYINDEX_README_PRE 0x00
+#define NGX_HTTP_FANCYINDEX_README_ASIS 0x01
+#define NGX_HTTP_FANCYINDEX_README_BOTTOM 0x02
+#define NGX_HTTP_FANCYINDEX_README_DIV 0x04
+#define NGX_HTTP_FANCYINDEX_README_IFRAME 0x08
+
+
+typedef enum {
+ NGX_HTTP_FANCYINDEX_INCLUDE_STATIC, /* Cache file contents on first request */
+ NGX_HTTP_FANCYINDEX_INCLUDE_CACHED, /* Cache file contents on first request,
+ and re-read if needed afterwards */
+} ngx_http_fancyindex_include_mode_t;
+
+
typedef struct {
- ngx_flag_t enable;
- ngx_flag_t localtime;
- ngx_flag_t exact_size;
+ ngx_flag_t enable;
+ ngx_flag_t localtime;
+ ngx_flag_t exact_size;
- ngx_str_t header;
- ngx_str_t footer;
- ngx_str_t readme;
+ ngx_str_t header;
+ ngx_str_t footer;
+ ngx_str_t readme;
- ngx_uint_t readme_flags;
+ ngx_uint_t readme_flags;
+
+ ngx_http_fancyindex_include_mode_t include_mode;
} ngx_http_fancyindex_loc_conf_t;
+#define nfi_conf_path_set(_c, _n) ((_c)->((_n).len) > 0)
+
+
#define NGX_HTTP_FANCYINDEX_PREALLOCATE 50
#define NGX_HTTP_FANCYINDEX_NAME_LEN 50
+static ngx_inline ngx_str_t
+ nfi_get_readme_path(ngx_http_request_t *r, const ngx_str_t *last);
+
static int ngx_libc_cdecl ngx_http_fancyindex_cmp_entries(const void *one,
const void *two);
static ngx_int_t ngx_http_fancyindex_error(ngx_http_request_t *r,
@@ -82,7 +98,7 @@ static char *ngx_http_fancyindex_merge_loc_conf(ngx_conf_t *cf,
-static ngx_conf_bitmask_t ngx_http_fancyindex_readme_flags[] = {
+static const ngx_conf_bitmask_t ngx_http_fancyindex_readme_flags[] = {
{ ngx_string("pre"), NGX_HTTP_FANCYINDEX_README_PRE },
{ ngx_string("asis"), NGX_HTTP_FANCYINDEX_README_ASIS },
{ ngx_string("top"), NGX_HTTP_FANCYINDEX_README_TOP },
@@ -93,6 +109,14 @@ static ngx_conf_bitmask_t ngx_http_fancyindex_readme_flags[] = {
};
+
+static const ngx_conf_enum_t ngx_http_fancyindex_include_modes[] = {
+ { ngx_string("static"), NGX_HTTP_FANCYINDEX_INCLUDE_STATIC },
+ { ngx_string("cached"), NGX_HTTP_FANCYINDEX_INCLUDE_CACHED },
+ { ngx_null_string, 0 },
+};
+
+
static ngx_command_t ngx_http_fancyindex_commands[] = {
{ ngx_string("fancyindex"),
@@ -144,6 +168,13 @@ static ngx_command_t ngx_http_fancyindex_commands[] = {
offsetof(ngx_http_fancyindex_loc_conf_t, readme_flags),
&ngx_http_fancyindex_readme_flags },
+ { ngx_string("fancyindex_mode"),
+ NGX_HTTP_MAIN_CONF|NGX_HTTP_SRV_CONF|NGX_HTTP_LOC_CONF|NGX_CONF_TAKE1,
+ ngx_conf_set_enum_slot,
+ NGX_HTTP_LOC_CONF_OFFSET,
+ offsetof(ngx_http_fancyindex_loc_conf_t, include_mode),
+ &ngx_http_fancyindex_include_modes },
+
ngx_null_command
};
@@ -192,6 +223,7 @@ ngx_http_fancyindex_handler(ngx_http_request_t *r)
ngx_buf_t *b;
ngx_int_t rc, size;
ngx_str_t path;
+ ngx_str_t readme_path;
ngx_dir_t dir;
ngx_uint_t i, level;
ngx_pool_t *pool;
@@ -264,11 +296,9 @@ ngx_http_fancyindex_handler(ngx_http_request_t *r)
}
#if (NGX_SUPPRESS_WARN)
-
/* MSVC thinks 'entries' may be used without having been initialized */
ngx_memzero(&entries, sizeof(ngx_array_t));
-
-#endif
+#endif /* NGX_SUPPRESS_WARN */
/* TODO: pool should be temporary pool */
pool = r->pool;
@@ -391,6 +421,29 @@ ngx_http_fancyindex_handler(ngx_http_request_t *r)
+ r->uri.len /* HTML head and as an
in the HTML body */
;
+ /*
+ * If including an