diff options
-rw-r--r-- | Makefile.am | 3 | ||||
-rw-r--r-- | src/content-parser.c | 246 | ||||
-rw-r--r-- | src/directives.c | 21 | ||||
-rw-r--r-- | src/directives.h | 17 | ||||
-rw-r--r-- | tests/check_content_parser.c | 620 |
5 files changed, 23 insertions, 884 deletions
diff --git a/Makefile.am b/Makefile.am index 4e79863..4a28b8b 100644 --- a/Makefile.am +++ b/Makefile.am @@ -26,7 +26,6 @@ MAINTAINERCLEANFILES = \ noinst_HEADERS = \ src/content-parser.h \ src/datetime-parser.h \ - src/directives.h \ src/file.h \ src/error.h \ src/loader.h \ @@ -54,7 +53,6 @@ check_PROGRAMS = \ libblogc_la_SOURCES = \ src/content-parser.c \ src/datetime-parser.c \ - src/directives.c \ src/file.c \ src/error.c \ src/loader.c \ @@ -200,7 +198,6 @@ tests_check_content_parser_CFLAGS = \ tests_check_content_parser_LDFLAGS = \ -no-install \ - -Wl,--wrap=blogc_directive_loader \ $(NULL) tests_check_content_parser_LDADD = \ diff --git a/src/content-parser.c b/src/content-parser.c index 1529ace..59e337e 100644 --- a/src/content-parser.c +++ b/src/content-parser.c @@ -15,7 +15,6 @@ #include "utils/utils.h" #include "content-parser.h" -#include "directives.h" // this is a half ass implementation of a markdown-like syntax. bugs are // expected. feel free to improve the parser and add new features. @@ -44,7 +43,7 @@ blogc_slugify(const char *str) typedef enum { CONTENT_START_LINE = 1, - CONTENT_EXCERPT_OR_DIRECTIVE, + CONTENT_EXCERPT, CONTENT_EXCERPT_END, CONTENT_HEADER, CONTENT_HEADER_TITLE_START, @@ -65,17 +64,6 @@ typedef enum { CONTENT_ORDERED_LIST_SPACE, CONTENT_ORDERED_LIST_START, CONTENT_ORDERED_LIST_END, - CONTENT_DIRECTIVE_NAME_START, - CONTENT_DIRECTIVE_NAME, - CONTENT_DIRECTIVE_COLON, - CONTENT_DIRECTIVE_ARGUMENT_START, - CONTENT_DIRECTIVE_ARGUMENT, - CONTENT_DIRECTIVE_PARAM_PREFIX, - CONTENT_DIRECTIVE_PARAM_KEY_START, - CONTENT_DIRECTIVE_PARAM_KEY, - CONTENT_DIRECTIVE_PARAM_VALUE_START, - CONTENT_DIRECTIVE_PARAM_VALUE, - CONTENT_DIRECTIVE_PARAM_END, CONTENT_PARAGRAPH, CONTENT_PARAGRAPH_END, } blogc_content_parser_state_t; @@ -416,9 +404,6 @@ blogc_content_parse(const char *src, size_t *end_excerpt) size_t end = 0; size_t eend = 0; size_t real_end = 0; - size_t spaces = 0; - - bool no_jump = false; unsigned int header_level = 0; char *prefix = NULL; @@ -428,11 +413,6 @@ blogc_content_parse(const char *src, size_t *end_excerpt) char *parsed = NULL; char *slug = NULL; - char *directive_name = NULL; - char *directive_argument = NULL; - char *directive_key = NULL; - b_trie_t *directive_params = NULL; - // this isn't empty because we need some reasonable default value in the // unlikely case that we need to print some line ending before evaluating // the "real" value. @@ -483,9 +463,11 @@ blogc_content_parse(const char *src, size_t *end_excerpt) break; start = current; if (c == '.') { - eend = rv->len; // fuck it - state = CONTENT_EXCERPT_OR_DIRECTIVE; - break; + if (end_excerpt != NULL) { + eend = rv->len; // fuck it + state = CONTENT_EXCERPT; + break; + } } if (c == '#') { header_level = 1; @@ -520,29 +502,26 @@ blogc_content_parse(const char *src, size_t *end_excerpt) state = CONTENT_PARAGRAPH; break; - case CONTENT_EXCERPT_OR_DIRECTIVE: - if (c == '.') - break; - if (c == ' ' && current - start == 2) { - state = CONTENT_DIRECTIVE_NAME_START; - if (is_last) - goto para; - break; - } - if (c == '\n' || c == '\r') { - state = CONTENT_EXCERPT_END; - break; + case CONTENT_EXCERPT: + if (end_excerpt != NULL) { + if (c == '.') + break; + if (c == '\n' || c == '\r') { + state = CONTENT_EXCERPT_END; + break; + } } eend = 0; state = CONTENT_PARAGRAPH; break; case CONTENT_EXCERPT_END: - if (c == '\n' || c == '\r') { - if (end_excerpt != NULL) + if (end_excerpt != NULL) { + if (c == '\n' || c == '\r') { *end_excerpt = eend; - state = CONTENT_START_LINE; - break; + state = CONTENT_START_LINE; + break; + } } eend = 0; state = CONTENT_PARAGRAPH_END; @@ -637,11 +616,6 @@ blogc_content_parse(const char *src, size_t *end_excerpt) prefix = NULL; b_slist_free_full(lines, free); lines = NULL; - if (is_last) { - free(tmp); - tmp = NULL; - goto para; - } } free(tmp); tmp = NULL; @@ -703,8 +677,6 @@ blogc_content_parse(const char *src, size_t *end_excerpt) lines = NULL; free(tmp); tmp = NULL; - if (is_last) - goto para; break; } free(tmp); @@ -864,8 +836,6 @@ hr: break; } state = CONTENT_PARAGRAPH; - if (is_last) - goto para; break; case CONTENT_ORDERED_LIST_SPACE: @@ -967,172 +937,6 @@ hr: } break; - case CONTENT_DIRECTIVE_NAME_START: - if (is_last) - goto para; - if (c >= 'a' && c <= 'z') { - start2 = current; - state = CONTENT_DIRECTIVE_NAME; - break; - } - state = CONTENT_PARAGRAPH; - break; - - case CONTENT_DIRECTIVE_NAME: - if (is_last) - goto para; - if ((c >= 'a' && c <= 'z') || (c >= '0' && c <= '9') || c == '_') - break; - if (c == ':') { - end = current; - state = CONTENT_DIRECTIVE_COLON; - break; - } - state = CONTENT_PARAGRAPH; - break; - - case CONTENT_DIRECTIVE_COLON: - if (c == ':') { - free(directive_name); - directive_name = b_strndup(src + start2, end - start2); - state = CONTENT_DIRECTIVE_ARGUMENT_START; - if (is_last) - goto param_end; - break; - } - if (is_last) - goto para; - state = CONTENT_PARAGRAPH; - break; - - case CONTENT_DIRECTIVE_ARGUMENT_START: - if (c == ' ') { - if (is_last) - goto param_end; - break; - } - if (c == '\n' || c == '\r' || is_last) { - state = CONTENT_DIRECTIVE_PARAM_PREFIX; - directive_argument = NULL; - if (is_last) - goto param_end; - break; - } - start2 = current; - state = CONTENT_DIRECTIVE_ARGUMENT; - break; - - case CONTENT_DIRECTIVE_ARGUMENT: - if (c == '\n' || c == '\r' || is_last) { - spaces = 0; - state = CONTENT_DIRECTIVE_PARAM_PREFIX; - end = is_last && c != '\n' && c != '\r' ? src_len : - (real_end != 0 ? real_end : current); - free(directive_argument); - directive_argument = b_strndup(src + start2, end - start2); - if (is_last) - goto param_end; - } - break; - - case CONTENT_DIRECTIVE_PARAM_PREFIX: - if (c == ' ') { - spaces++; - break; - } - if ((c == '\n' || c == '\r') && spaces == 0) { - state = CONTENT_DIRECTIVE_PARAM_END; - if (is_last) - goto param_end; - break; - } - if (c == ':' && spaces == 3) { - state = CONTENT_DIRECTIVE_PARAM_KEY_START; - break; - } - state = CONTENT_PARAGRAPH; - if (is_last) - goto para; - break; - - case CONTENT_DIRECTIVE_PARAM_KEY_START: - if (is_last) - goto para; - if (c >= 'a' && c <= 'z') { - start2 = current; - state = CONTENT_DIRECTIVE_PARAM_KEY; - break; - } - state = CONTENT_PARAGRAPH; - break; - - case CONTENT_DIRECTIVE_PARAM_KEY: - if (is_last) - goto para; - if ((c >= 'a' && c <= 'z') || (c >= '0' && c <= '9') || c == '_') - break; - if (c == ':') { - free(directive_key); - directive_key = b_strndup(src + start2, current - start2); - state = CONTENT_DIRECTIVE_PARAM_VALUE_START; - break; - } - state = CONTENT_PARAGRAPH; - break; - - case CONTENT_DIRECTIVE_PARAM_VALUE_START: - if (is_last) - goto para; - if (c == ' ') - break; - start2 = current; - state = CONTENT_DIRECTIVE_PARAM_VALUE; - break; - - case CONTENT_DIRECTIVE_PARAM_VALUE: - if (c == '\n' || c == '\r' || is_last) { - state = CONTENT_DIRECTIVE_PARAM_END; - end = is_last && c != '\n' && c != '\r' ? src_len : - (real_end != 0 ? real_end : current); - if (directive_params == NULL) - directive_params = b_trie_new(free); - b_trie_insert(directive_params, directive_key, - b_strndup(src + start2, end - start2)); - free(directive_key); - directive_key = NULL; - } - if (!is_last) - break; - - case CONTENT_DIRECTIVE_PARAM_END: -param_end: - if (c == '\n' || c == '\r' || is_last) { - char *rv_d = blogc_directive_loader(directive_name, - directive_argument, directive_params); - if (rv_d) - b_string_append(rv, rv_d); - free(rv_d); - state = CONTENT_START_LINE; - start = current; - free(directive_name); - directive_name = NULL; - free(directive_argument); - directive_argument = NULL; - b_trie_free(directive_params); - directive_params = NULL; - break; - } - if (c == ' ') { - start2 = current; - spaces = 1; - state = CONTENT_DIRECTIVE_PARAM_PREFIX; - break; - } - state = CONTENT_PARAGRAPH; - if (is_last) - goto para; - break; - case CONTENT_PARAGRAPH: if (c == '\n' || c == '\r' || is_last) { state = CONTENT_PARAGRAPH_END; @@ -1143,15 +947,8 @@ param_end: break; case CONTENT_PARAGRAPH_END: - no_jump = true; para: if (c == '\n' || c == '\r' || is_last) { - if (!no_jump && is_last) { - if (c == '\n' || c == '\r') - end = src_len - 1; - else - end = src_len; - } tmp = b_strndup(src + start, end - start); parsed = blogc_content_parse_inline(tmp); b_string_append_printf(rv, "<p>%s</p>%s", parsed, @@ -1172,10 +969,5 @@ para: current++; } - free(directive_name); - free(directive_argument); - free(directive_key); - b_trie_free(directive_params); - return b_string_free(rv, false); } diff --git a/src/directives.c b/src/directives.c deleted file mode 100644 index 7a6b47f..0000000 --- a/src/directives.c +++ /dev/null @@ -1,21 +0,0 @@ -/* - * blogc: A blog compiler. - * Copyright (C) 2015 Rafael G. Martins <rafael@rafaelmartins.eng.br> - * - * This program can be distributed under the terms of the BSD License. - * See the file LICENSE. - */ - -#ifdef HAVE_CONFIG_H -#include <config.h> -#endif /* HAVE_CONFIG_H */ - -#include "utils/utils.h" - - -char* -blogc_directive_loader(const char *name, const char *argument, b_trie_t *params) -{ - // TODO: implement me! - return b_strdup("TODO\n"); -} diff --git a/src/directives.h b/src/directives.h deleted file mode 100644 index fa758e2..0000000 --- a/src/directives.h +++ /dev/null @@ -1,17 +0,0 @@ -/* - * blogc: A blog compiler. - * Copyright (C) 2015 Rafael G. Martins <rafael@rafaelmartins.eng.br> - * - * This program can be distributed under the terms of the BSD License. - * See the file LICENSE. - */ - -#ifndef _DIRECTIVES_H -#define _DIRECTIVES_H - -#include "utils/utils.h" - -char* blogc_directive_loader(const char *name, const char *argument, - b_trie_t *params); - -#endif /* _DIRECTIVES_H */ diff --git a/tests/check_content_parser.c b/tests/check_content_parser.c index 5d13564..994e900 100644 --- a/tests/check_content_parser.c +++ b/tests/check_content_parser.c @@ -1014,405 +1014,6 @@ test_content_parse_ordered_list_crlf(void **state) } -char* -__wrap_blogc_directive_loader(const char *name, const char *argument, - b_trie_t *params) -{ - assert_string_equal(name, mock_type(const char*)); - const char *arg = mock_type(const char*); - if (arg == NULL) - assert_null(argument); - else - assert_string_equal(argument, arg); - assert_int_equal(b_trie_size(params), mock_type(unsigned int)); - - for (unsigned int i = 0; i < b_trie_size(params); i++) - assert_string_equal(b_trie_lookup(params, mock_type(const char*)), - mock_type(const char*)); - - return b_strdup("CHUNDA\n"); -} - - -static void -test_content_parse_directive(void **state) -{ - will_return(__wrap_blogc_directive_loader, "bola"); - will_return(__wrap_blogc_directive_loader, NULL); - will_return(__wrap_blogc_directive_loader, 0); - char *html = blogc_content_parse( - ".. bola::", - NULL); - assert_non_null(html); - assert_string_equal(html, - "CHUNDA\n"); - free(html); - - will_return(__wrap_blogc_directive_loader, "bola"); - will_return(__wrap_blogc_directive_loader, NULL); - will_return(__wrap_blogc_directive_loader, 0); - html = blogc_content_parse( - ".. bola::\n", - NULL); - assert_non_null(html); - assert_string_equal(html, - "CHUNDA\n"); - free(html); - - will_return(__wrap_blogc_directive_loader, "bola"); - will_return(__wrap_blogc_directive_loader, NULL); - will_return(__wrap_blogc_directive_loader, 0); - html = blogc_content_parse( - ".. bola:: ", - NULL); - assert_non_null(html); - assert_string_equal(html, - "CHUNDA\n"); - free(html); - - will_return(__wrap_blogc_directive_loader, "bola"); - will_return(__wrap_blogc_directive_loader, NULL); - will_return(__wrap_blogc_directive_loader, 0); - html = blogc_content_parse( - ".. bola:: \n", - NULL); - assert_non_null(html); - assert_string_equal(html, - "CHUNDA\n"); - free(html); - - will_return(__wrap_blogc_directive_loader, "bola"); - will_return(__wrap_blogc_directive_loader, NULL); - will_return(__wrap_blogc_directive_loader, 0); - html = blogc_content_parse( - ".. bola::\r\n", - NULL); - assert_non_null(html); - assert_string_equal(html, - "CHUNDA\n"); - free(html); - - will_return(__wrap_blogc_directive_loader, "bola"); - will_return(__wrap_blogc_directive_loader, NULL); - will_return(__wrap_blogc_directive_loader, 1); - will_return(__wrap_blogc_directive_loader, "asd"); - will_return(__wrap_blogc_directive_loader, "qwe"); - html = blogc_content_parse( - ".. bola::\n" - " :asd: qwe", - NULL); - assert_non_null(html); - assert_string_equal(html, - "CHUNDA\n"); - free(html); - - will_return(__wrap_blogc_directive_loader, "bola"); - will_return(__wrap_blogc_directive_loader, NULL); - will_return(__wrap_blogc_directive_loader, 1); - will_return(__wrap_blogc_directive_loader, "asd"); - will_return(__wrap_blogc_directive_loader, "qwe"); - html = blogc_content_parse( - ".. bola::\n" - " :asd: qwe\n", - NULL); - assert_non_null(html); - assert_string_equal(html, - "CHUNDA\n"); - free(html); - - will_return(__wrap_blogc_directive_loader, "bola"); - will_return(__wrap_blogc_directive_loader, NULL); - will_return(__wrap_blogc_directive_loader, 1); - will_return(__wrap_blogc_directive_loader, "asd"); - will_return(__wrap_blogc_directive_loader, "qwe"); - html = blogc_content_parse( - ".. bola::\r\n" - " :asd: qwe\r\n", - NULL); - assert_non_null(html); - assert_string_equal(html, - "CHUNDA\n"); - free(html); - - will_return(__wrap_blogc_directive_loader, "bola"); - will_return(__wrap_blogc_directive_loader, NULL); - will_return(__wrap_blogc_directive_loader, 2); - will_return(__wrap_blogc_directive_loader, "asd"); - will_return(__wrap_blogc_directive_loader, "qwe"); - will_return(__wrap_blogc_directive_loader, "zxc"); - will_return(__wrap_blogc_directive_loader, "vbn"); - html = blogc_content_parse( - ".. bola::\n" - " :asd: qwe\n" - " :zxc: vbn", - NULL); - assert_non_null(html); - assert_string_equal(html, - "CHUNDA\n"); - free(html); - - will_return(__wrap_blogc_directive_loader, "bola"); - will_return(__wrap_blogc_directive_loader, NULL); - will_return(__wrap_blogc_directive_loader, 2); - will_return(__wrap_blogc_directive_loader, "asd"); - will_return(__wrap_blogc_directive_loader, "qwe"); - will_return(__wrap_blogc_directive_loader, "zxc"); - will_return(__wrap_blogc_directive_loader, "vbn"); - html = blogc_content_parse( - ".. bola::\n" - " :asd: qwe\n" - " :zxc: vbn\n", - NULL); - assert_non_null(html); - assert_string_equal(html, - "CHUNDA\n"); - free(html); - - will_return(__wrap_blogc_directive_loader, "bola"); - will_return(__wrap_blogc_directive_loader, NULL); - will_return(__wrap_blogc_directive_loader, 2); - will_return(__wrap_blogc_directive_loader, "asd"); - will_return(__wrap_blogc_directive_loader, "qwe"); - will_return(__wrap_blogc_directive_loader, "zxc"); - will_return(__wrap_blogc_directive_loader, "vbn"); - html = blogc_content_parse( - ".. bola::\r\n" - " :asd: qwe\r\n" - " :zxc: vbn\r\n", - NULL); - assert_non_null(html); - assert_string_equal(html, - "CHUNDA\n"); - free(html); - - will_return(__wrap_blogc_directive_loader, "bola"); - will_return(__wrap_blogc_directive_loader, NULL); - will_return(__wrap_blogc_directive_loader, 3); - will_return(__wrap_blogc_directive_loader, "asd"); - will_return(__wrap_blogc_directive_loader, "qwe"); - will_return(__wrap_blogc_directive_loader, "ert"); - will_return(__wrap_blogc_directive_loader, "zxvc"); - will_return(__wrap_blogc_directive_loader, "qwe"); - will_return(__wrap_blogc_directive_loader, "bola"); - html = blogc_content_parse( - "# foo\n" - "\n" - ".. bola::\n" - " :asd: qwe\n" - " :ert: zxvc\n" - " :qwe: bola\n" - "\n" - "bola", NULL); - assert_non_null(html); - assert_string_equal(html, - "<h1 id=\"foo\">foo</h1>\n" - "CHUNDA\n" - "<p>bola</p>\n"); - free(html); - - will_return(__wrap_blogc_directive_loader, "bola"); - will_return(__wrap_blogc_directive_loader, NULL); - will_return(__wrap_blogc_directive_loader, 3); - will_return(__wrap_blogc_directive_loader, "asd"); - will_return(__wrap_blogc_directive_loader, "qwe"); - will_return(__wrap_blogc_directive_loader, "ert"); - will_return(__wrap_blogc_directive_loader, "zxvc"); - will_return(__wrap_blogc_directive_loader, "qwe"); - will_return(__wrap_blogc_directive_loader, "bola"); - html = blogc_content_parse( - "# foo\r\n" - "\r\n" - ".. bola::\r\n" - " :asd: qwe\r\n" - " :ert: zxvc\r\n" - " :qwe: bola\r\n" - "\r\n" - "bola", NULL); - assert_non_null(html); - assert_string_equal(html, - "<h1 id=\"foo\">foo</h1>\r\n" - "CHUNDA\n" - "<p>bola</p>\r\n"); - free(html); - - will_return(__wrap_blogc_directive_loader, "bola"); - will_return(__wrap_blogc_directive_loader, "chunda"); - will_return(__wrap_blogc_directive_loader, 0); - html = blogc_content_parse( - ".. bola:: chunda", - NULL); - assert_non_null(html); - assert_string_equal(html, - "CHUNDA\n"); - free(html); - - will_return(__wrap_blogc_directive_loader, "bola"); - will_return(__wrap_blogc_directive_loader, "chunda"); - will_return(__wrap_blogc_directive_loader, 0); - html = blogc_content_parse( - ".. bola:: chunda\n", - NULL); - assert_non_null(html); - assert_string_equal(html, - "CHUNDA\n"); - free(html); - - will_return(__wrap_blogc_directive_loader, "bola"); - will_return(__wrap_blogc_directive_loader, "chunda"); - will_return(__wrap_blogc_directive_loader, 0); - html = blogc_content_parse( - ".. bola:: chunda\r\n", - NULL); - assert_non_null(html); - assert_string_equal(html, - "CHUNDA\n"); - free(html); - - will_return(__wrap_blogc_directive_loader, "bola"); - will_return(__wrap_blogc_directive_loader, "chunda"); - will_return(__wrap_blogc_directive_loader, 1); - will_return(__wrap_blogc_directive_loader, "asd"); - will_return(__wrap_blogc_directive_loader, "qwe"); - html = blogc_content_parse( - ".. bola:: chunda\n" - " :asd: qwe", - NULL); - assert_non_null(html); - assert_string_equal(html, - "CHUNDA\n"); - free(html); - - will_return(__wrap_blogc_directive_loader, "bola"); - will_return(__wrap_blogc_directive_loader, "chunda"); - will_return(__wrap_blogc_directive_loader, 1); - will_return(__wrap_blogc_directive_loader, "asd"); - will_return(__wrap_blogc_directive_loader, "qwe"); - html = blogc_content_parse( - ".. bola:: chunda\n" - " :asd: qwe\n", - NULL); - assert_non_null(html); - assert_string_equal(html, - "CHUNDA\n"); - free(html); - - will_return(__wrap_blogc_directive_loader, "bola"); - will_return(__wrap_blogc_directive_loader, "chunda"); - will_return(__wrap_blogc_directive_loader, 1); - will_return(__wrap_blogc_directive_loader, "asd"); - will_return(__wrap_blogc_directive_loader, "qwe"); - html = blogc_content_parse( - ".. bola:: chunda\r\n" - " :asd: qwe\r\n", - NULL); - assert_non_null(html); - assert_string_equal(html, - "CHUNDA\n"); - free(html); - - will_return(__wrap_blogc_directive_loader, "bola"); - will_return(__wrap_blogc_directive_loader, "chunda"); - will_return(__wrap_blogc_directive_loader, 2); - will_return(__wrap_blogc_directive_loader, "asd"); - will_return(__wrap_blogc_directive_loader, "qwe"); - will_return(__wrap_blogc_directive_loader, "zxc"); - will_return(__wrap_blogc_directive_loader, "vbn"); - html = blogc_content_parse( - ".. bola:: chunda\n" - " :asd: qwe\n" - " :zxc: vbn", - NULL); - assert_non_null(html); - assert_string_equal(html, - "CHUNDA\n"); - free(html); - - will_return(__wrap_blogc_directive_loader, "bola"); - will_return(__wrap_blogc_directive_loader, "chunda"); - will_return(__wrap_blogc_directive_loader, 2); - will_return(__wrap_blogc_directive_loader, "asd"); - will_return(__wrap_blogc_directive_loader, "qwe"); - will_return(__wrap_blogc_directive_loader, "zxc"); - will_return(__wrap_blogc_directive_loader, "vbn"); - html = blogc_content_parse( - ".. bola:: chunda\n" - " :asd: qwe\n" - " :zxc: vbn\n", - NULL); - assert_non_null(html); - assert_string_equal(html, - "CHUNDA\n"); - free(html); - - will_return(__wrap_blogc_directive_loader, "bola"); - will_return(__wrap_blogc_directive_loader, "chunda"); - will_return(__wrap_blogc_directive_loader, 2); - will_return(__wrap_blogc_directive_loader, "asd"); - will_return(__wrap_blogc_directive_loader, "qwe"); - will_return(__wrap_blogc_directive_loader, "zxc"); - will_return(__wrap_blogc_directive_loader, "vbn"); - html = blogc_content_parse( - ".. bola:: chunda\r\n" - " :asd: qwe\r\n" - " :zxc: vbn\r\n", - NULL); - assert_non_null(html); - assert_string_equal(html, - "CHUNDA\n"); - free(html); - - will_return(__wrap_blogc_directive_loader, "bola"); - will_return(__wrap_blogc_directive_loader, "chunda"); - will_return(__wrap_blogc_directive_loader, 3); - will_return(__wrap_blogc_directive_loader, "asd"); - will_return(__wrap_blogc_directive_loader, "qwe"); - will_return(__wrap_blogc_directive_loader, "ert"); - will_return(__wrap_blogc_directive_loader, "zxvc"); - will_return(__wrap_blogc_directive_loader, "qwe"); - will_return(__wrap_blogc_directive_loader, "bola"); - html = blogc_content_parse( - "# foo\n" - "\n" - ".. bola:: chunda\n" - " :asd: qwe\n" - " :ert: zxvc\n" - " :qwe: bola\n" - "\n" - "bola", NULL); - assert_non_null(html); - assert_string_equal(html, - "<h1 id=\"foo\">foo</h1>\n" - "CHUNDA\n" - "<p>bola</p>\n"); - free(html); - - will_return(__wrap_blogc_directive_loader, "bola"); - will_return(__wrap_blogc_directive_loader, "chunda"); - will_return(__wrap_blogc_directive_loader, 3); - will_return(__wrap_blogc_directive_loader, "asd"); - will_return(__wrap_blogc_directive_loader, "qwe"); - will_return(__wrap_blogc_directive_loader, "ert"); - will_return(__wrap_blogc_directive_loader, "zxvc"); - will_return(__wrap_blogc_directive_loader, "qwe"); - will_return(__wrap_blogc_directive_loader, "bola"); - html = blogc_content_parse( - "# foo\r\n" - "\r\n" - ".. bola:: chunda\r\n" - " :asd: qwe\r\n" - " :ert: zxvc\r\n" - " :qwe: bola\r\n" - "\r\n" - "bola", NULL); - assert_non_null(html); - assert_string_equal(html, - "<h1 id=\"foo\">foo</h1>\r\n" - "CHUNDA\n" - "<p>bola</p>\r\n"); - free(html); -} - - static void test_content_parse_invalid_excerpt(void **state) { @@ -1534,14 +1135,6 @@ test_content_parse_invalid_blockquote(void **state) "> bola\n" "> foo</p>\n"); free(html); - html = blogc_content_parse( - "> asd\n" - "> bola", NULL); - assert_non_null(html); - assert_string_equal(html, - "<p>> asd\n" - "> bola</p>\n"); - free(html); } @@ -1558,16 +1151,6 @@ test_content_parse_invalid_code(void **state) " bola\n" " foo</p>\n"); free(html); - html = blogc_content_parse( - " asd\n" - " bola\n" - " foo", NULL); - assert_non_null(html); - assert_string_equal(html, - "<p> asd\n" - " bola\n" - " foo</p>\n"); - free(html); } @@ -1613,8 +1196,7 @@ test_content_parse_invalid_unordered_list(void **state) assert_non_null(html); assert_string_equal(html, "<p><em> asd\n" - "1. qwe" - "</p>\n"); + "1. qwe</p>\n"); free(html); html = blogc_content_parse( "* asd\n" @@ -1622,8 +1204,7 @@ test_content_parse_invalid_unordered_list(void **state) assert_non_null(html); assert_string_equal(html, "<p><em> asd\n" - "1. qwe" - "</p>\n"); + "1. qwe</p>\n"); free(html); html = blogc_content_parse( "chunda\n" @@ -1669,8 +1250,7 @@ test_content_parse_invalid_ordered_list(void **state) assert_non_null(html); assert_string_equal(html, "<p>1. asd\n" - "<em> qwe" - "</p>\n"); + "<em> qwe</p>\n"); free(html); html = blogc_content_parse( "1. asd\n" @@ -1678,8 +1258,7 @@ test_content_parse_invalid_ordered_list(void **state) assert_non_null(html); assert_string_equal(html, "<p>1. asd\n" - "<em> qwe" - "</p>\n"); + "<em> qwe</p>\n"); free(html); html = blogc_content_parse( "chunda\n" @@ -1724,195 +1303,6 @@ test_content_parse_invalid_ordered_list(void **state) assert_non_null(html); assert_string_equal(html, "<p>1.</p>\n"); free(html); - html = blogc_content_parse("1 ", NULL); - assert_non_null(html); - assert_string_equal(html, "<p>1 </p>\n"); - free(html); -} - - -static void -test_content_parse_invalid_directive(void **state) -{ - char *html = blogc_content_parse( - ".. ", - NULL); - assert_non_null(html); - assert_string_equal(html, - "<p>.. </p>\n"); - free(html); - - html = blogc_content_parse( - ".. \n", - NULL); - assert_non_null(html); - assert_string_equal(html, - "<p>.. </p>\n"); - free(html); - - html = blogc_content_parse( - ".. ", - NULL); - assert_non_null(html); - assert_string_equal(html, - "<p>.. <br /></p>\n"); - free(html); - - html = blogc_content_parse( - ".. \n", - NULL); - assert_non_null(html); - assert_string_equal(html, - "<p>.. <br /></p>\n"); - free(html); - - html = blogc_content_parse( - ".. a", - NULL); - assert_non_null(html); - assert_string_equal(html, - "<p>.. a</p>\n"); - free(html); - - html = blogc_content_parse( - ".. a\n", - NULL); - assert_non_null(html); - assert_string_equal(html, - "<p>.. a</p>\n"); - free(html); - - html = blogc_content_parse( - ".. asd", - NULL); - assert_non_null(html); - assert_string_equal(html, - "<p>.. asd</p>\n"); - free(html); - - html = blogc_content_parse( - ".. asd\n", - NULL); - assert_non_null(html); - assert_string_equal(html, - "<p>.. asd</p>\n"); - free(html); - - html = blogc_content_parse( - ".. asd:", - NULL); - assert_non_null(html); - assert_string_equal(html, - "<p>.. asd:</p>\n"); - free(html); - - html = blogc_content_parse( - ".. asd:\n", - NULL); - assert_non_null(html); - assert_string_equal(html, - "<p>.. asd:</p>\n"); - free(html); - - html = blogc_content_parse( - ".. asd::\n" - " :", - NULL); - assert_non_null(html); - assert_string_equal(html, - "<p>.. asd::\n" - " :</p>\n"); - free(html); - - html = blogc_content_parse( - ".. asd::\n" - " :\n", - NULL); - assert_non_null(html); - assert_string_equal(html, - "<p>.. asd::\n" - " :</p>\n"); - free(html); - - html = blogc_content_parse( - ".. asd::\n" - " :a", - NULL); - assert_non_null(html); - assert_string_equal(html, - "<p>.. asd::\n" - " :a</p>\n"); - free(html); - - html = blogc_content_parse( - ".. asd::\n" - " :a\n", - NULL); - assert_non_null(html); - assert_string_equal(html, - "<p>.. asd::\n" - " :a</p>\n"); - free(html); - - html = blogc_content_parse( - ".. asd::\n" - " :as", - NULL); - assert_non_null(html); - assert_string_equal(html, - "<p>.. asd::\n" - " :as</p>\n"); - free(html); - - html = blogc_content_parse( - ".. asd::\n" - " :as\n", - NULL); - assert_non_null(html); - assert_string_equal(html, - "<p>.. asd::\n" - " :as</p>\n"); - free(html); - - html = blogc_content_parse( - ".. asd::\n" - " :as:", - NULL); - assert_non_null(html); - assert_string_equal(html, - "<p>.. asd::\n" - " :as:</p>\n"); - free(html); - - html = blogc_content_parse( - ".. asd::\n" - " :as:\n", - NULL); - assert_non_null(html); - assert_string_equal(html, - "<p>.. asd::\n" - " :as:</p>\n"); - free(html); - - html = blogc_content_parse( - ".. asd::\n" - " :as: ", - NULL); - assert_non_null(html); - assert_string_equal(html, - "<p>.. asd::\n" - " :as: </p>\n"); - free(html); - - html = blogc_content_parse( - ".. asd::\n" - " :as: \n", - NULL); - assert_non_null(html); - assert_string_equal(html, - "<p>.. asd::\n" - " :as: </p>\n"); - free(html); } @@ -2266,7 +1656,6 @@ main(void) unit_test(test_content_parse_unordered_list_crlf), unit_test(test_content_parse_ordered_list), unit_test(test_content_parse_ordered_list_crlf), - unit_test(test_content_parse_directive), unit_test(test_content_parse_invalid_excerpt), unit_test(test_content_parse_invalid_header), unit_test(test_content_parse_invalid_header_empty), @@ -2275,7 +1664,6 @@ main(void) unit_test(test_content_parse_invalid_horizontal_rule), unit_test(test_content_parse_invalid_unordered_list), unit_test(test_content_parse_invalid_ordered_list), - unit_test(test_content_parse_invalid_directive), unit_test(test_content_parse_inline), unit_test(test_content_parse_inline_em), unit_test(test_content_parse_inline_strong), |