}
char *pathval = g_key_file_get_string(conf, entries[i], "path", NULL);
char *nameval = g_key_file_get_string(conf, entries[i], "name", NULL);
+ int hideval = g_key_file_get_boolean(conf, entries[i], "hide", NULL);
if (pathval) next->path = pathval;
if (nameval) next->name = nameval;
if (!next->path) next->path = g_strdup(entries[i]);
if (!next->name) next->name = g_strdup(entries[i]);
+ if (hideval)
+ next->show = SHOW_HIDDEN;
+ if (!parts[0] && !strcmp(next->base, "index"))
+ next->show = SHOW_ACTIVE;
cur = cur->next = next;
}
g_strfreev(entries);
continue;
if ((next = get_menu_entry(prefix, entries[i])))
cur = cur->next = next;
+ if (!strcmp(cur->base, "index"))
+ cur->show = SHOW_HIDDEN;
}
g_strfreev(entries);
g_key_file_free(conf);
cur->kids = get_menu_rec(cur->path, parts+1);
cur->show = SHOW_ACTIVE;
}
- if (!strcmp(cur->base, "index"))
- cur->show = SHOW_HIDDEN;
}
error:
void print_menu(menu_t *menu, int first, int last)
{
for (menu_t *cur = menu; cur; cur = cur->next) {
- if (cur->show == SHOW_HIDDEN)
- continue;
- if (first <= 0)
+ if (first <= 0 && cur->show != SHOW_HIDDEN)
print_link(cur->path, cur->name,
cur->show == SHOW_ACTIVE);
if (cur->kids && last != 0)
else
page->html = markdown_to_string(page->text, 0, 0);
} else {
- page->html = g_strdup("Page not found");
+ page->error = g_strdup("403 Forbidden");
+ page->html = g_strdup("Page not accessable\n");
}
}
static void do_notfound(page_t *page, const char *path)
{
- page->html = "Page not found";
+ page->error = g_strdup("404 Not Found");
+ page->html = g_strdup("Page not found\n");
}
static char *clean(const char *src)
/* Main */
int main(int argc, char **argv)
{
- char *path = clean(getenv("PATH_INFO") ?: "/aweather/");
-
- print_header();
+ char *path = clean(getenv("PATH_INFO") ?: "/");
page_t *page = get_page(path);
menu_t *menu = get_menu(path);
g_free(index);
g_free(file);
+ print_header(page);
print_page(page, menu);
return 0;