From e4c08cd44e37f28cd11d62a95f4791ace663c62d Mon Sep 17 00:00:00 2001 From: "Rafael G. Martins" Date: Tue, 24 Jul 2018 21:54:27 +0200 Subject: make: fixed filename generation for rules and atom feed --- src/blogc-make/atom.c | 39 ++++++++++++++++++++++++++++----------- 1 file changed, 28 insertions(+), 11 deletions(-) (limited to 'src') diff --git a/src/blogc-make/atom.c b/src/blogc-make/atom.c index 0e4e631..ae5e0c1 100644 --- a/src/blogc-make/atom.c +++ b/src/blogc-make/atom.c @@ -13,6 +13,7 @@ #include "../common/error.h" #include "../common/utils.h" #include "settings.h" +#include "utils.h" #include "atom.h" static const char atom_template[] = @@ -20,12 +21,10 @@ static const char atom_template[] = "\n" " {{ SITE_TITLE }}{%% ifdef FILTER_TAG %%} - " "{{ FILTER_TAG }}{%% endif %%}\n" - " {{ BASE_URL }}%s%s{%% ifdef FILTER_TAG %%}/{{ FILTER_TAG }}" - "{%% endif %%}%s\n" + " {{ BASE_URL }}%s\n" " {{ DATE_FIRST_FORMATTED }}\n" " \n" - " \n" + " \n" " \n" " {{ AUTHOR_NAME }}\n" " {{ AUTHOR_EMAIL }}\n" @@ -34,10 +33,10 @@ static const char atom_template[] = " {%% block listing %%}\n" " \n" " {{ TITLE }}\n" - " {{ BASE_URL }}%s%s/{{ FILENAME }}/\n" + " {{ BASE_URL }}%s\n" " {{ DATE_FORMATTED }}\n" " {{ DATE_FORMATTED }}\n" - " \n" + " \n" " \n" " {{ AUTHOR_NAME }}\n" " {{ AUTHOR_EMAIL }}\n" @@ -66,12 +65,30 @@ bm_atom_deploy(bm_settings_t *settings, bc_error_t **err) const char *atom_prefix = bc_trie_lookup(settings->settings, "atom_prefix"); const char *atom_ext = bc_trie_lookup(settings->settings, "atom_ext"); const char *post_prefix = bc_trie_lookup(settings->settings, "post_prefix"); - const char *atom_slash = atom_prefix[0] == '\0' ? "" : "/"; - const char *post_slash = post_prefix[0] == '\0' ? "" : "/"; + const char *post_ext = bc_trie_lookup(settings->settings, "html_ext"); - char *content = bc_strdup_printf(atom_template, atom_slash, atom_prefix, - atom_ext, atom_slash, atom_prefix, atom_ext, post_slash, post_prefix, - post_slash, post_prefix); + bc_string_t *atom_url = bc_string_new(); + + if (atom_prefix[0] != '\0') + bc_string_append_c(atom_url, '/'); + + bc_string_append(atom_url, atom_prefix); + bc_string_append(atom_url, "{% ifdef FILTER_TAG %}/{{ FILTER_TAG }}"); + + if (atom_prefix[0] == '\0' && atom_ext[0] != '/') + bc_string_append(atom_url, "{% else %}/index"); + + bc_string_append(atom_url, "{% endif %}"); + bc_string_append(atom_url, atom_ext); + + char *post_url = bm_generate_filename(NULL, post_prefix, "{{ FILENAME }}", + post_ext); + + char *content = bc_strdup_printf(atom_template, atom_url->str, atom_url->str, + post_url, post_url); + + bc_string_free(atom_url, true); + free(post_url); if (-1 == write(fd, content, strlen(content))) { *err = bc_error_new_printf(BLOGC_MAKE_ERROR_ATOM, -- cgit v1.2.3-18-g5258