Mercurial > prosody-modules
changeset 1064:5db8debb4531
mod_http_dir_listing: Attach the MIME type to list items for use in CSS
author | Kim Alvefur <zash@zash.se> |
---|---|
date | Fri, 14 Jun 2013 12:09:00 +0200 (2013-06-14) |
parents | b2a4679e7d20 |
children | 3d04d9377a67 |
files | mod_http_dir_listing/http_dir_listing/mod_http_dir_listing.lua |
diffstat | 1 files changed, 10 insertions(+), 2 deletions(-) [+] |
line wrap: on
line diff
--- a/mod_http_dir_listing/http_dir_listing/mod_http_dir_listing.lua Thu Jun 13 21:27:41 2013 +0200 +++ b/mod_http_dir_listing/http_dir_listing/mod_http_dir_listing.lua Fri Jun 14 12:09:00 2013 +0200 @@ -14,6 +14,10 @@ local tag = require"util.stanza".stanza; local template = require"util.template"; +module:depends"http_files"; + +local mime = module:shared("/*/http_files/mime"); + local function get_resource(resource) local fh = assert(module:load_resource(resource)); local data = fh:read"*a"; @@ -33,13 +37,17 @@ filelist:tag("li", { class = "parent directory" }) :tag("a", { href = "..", rel = "up" }):text("Parent Directory"):up():up():text"\n" end + local mime_map = mime.types; for file in lfs.dir(full_path) do if file:sub(1,1) ~= "." then local attr = stat(full_path..file) or {}; local path = { file }; + local file_ext = file:match"%.(.-)$"; + local type = attr.mode == "file" and mime_map and mime_map[file_ext] or nil; + local class = table.concat({ attr.mode or "unknown", file_ext, type and type:match"^[^/]+" }, " "); path.is_directory = attr.mode == "directory"; - filelist:tag("li", { class = attr.mode }) - :tag("a", { href = build_path(path) }):text(file):up() + filelist:tag("li", { class = class }) + :tag("a", { href = build_path(path), type = type }):text(file):up() :up():text"\n"; end end