diff options
author | dx <aryadevchavali1@gmail.com> | 2020-05-06 06:03:32 +0100 |
---|---|---|
committer | dx <aryadevchavali1@gmail.com> | 2020-05-06 06:04:44 +0100 |
commit | 3ce7811758c351df069ae36c55886af8b577cb66 (patch) | |
tree | 52f0528e5f4fe9e5e6fcd7d9852ca88318dd1411 /Converter/src/compiler.c | |
parent | 0b5450d05c98701e02412b9cc712595d01518263 (diff) | |
download | mdhtml-3ce7811758c351df069ae36c55886af8b577cb66.tar.gz mdhtml-3ce7811758c351df069ae36c55886af8b577cb66.tar.bz2 mdhtml-3ce7811758c351df069ae36c55886af8b577cb66.zip |
+routine to compile plain text +diagnostics
This routine will handle asterisks and bullet points.
Works by checking characters at each step.
Also has diagnostics by checking for matching characters. If a matching
asterisk, for example, isn't found then present an error and quit.
Diffstat (limited to 'Converter/src/compiler.c')
-rw-r--r-- | Converter/src/compiler.c | 112 |
1 files changed, 107 insertions, 5 deletions
diff --git a/Converter/src/compiler.c b/Converter/src/compiler.c index 1c5b728..c6060be 100644 --- a/Converter/src/compiler.c +++ b/Converter/src/compiler.c @@ -2,15 +2,116 @@ #include <stdio.h> #include <string.h> -string compile_line(string line, size_t size_of_line) +void compile_plain_text(string dest, string src, size_t size_of_line, + string line_or_source) +{ + /* cursor is the current index on the dest pointer + * lower represents the last tag character before content + * upper represents the first tag character after content + * + * size_of_content is self explanatory (size of content in tags) + * tag_size is the compiled size of a tag + * md_tag_size is the precompiled size of a tag + * + * tag is the string for the open HTML tag + * close_tag is the string for the close HTML tag + * + * i and j are iterator variables + */ + int cursor, lower, upper; + size_t size_of_content, tag_size, md_tag_size; + string tag, close_tag; + int i, j; + + lower = 0; + upper = 0; + cursor = 0; + + for (i = 0; i < size_of_line; ++i) + { + // Asterisk routine + if (src[i] == '*') + { + j = i + 1; + + // Twin asterisks + if (src[i + 1] == '*') + { + tag = "<strong>"; + close_tag = "</strong>"; + tag_size = 8; + md_tag_size = 2; + + // Make j the cursor seeking for the matching asterisk pair + while ((j < size_of_line - 1) && (src[j] != '*' || src[j + 1] != '*')) + ++j; + + // if found + if (src[j] == '*') + { + lower = i + 1; + upper = j; + } + else + { + // ERROR + fprintf(stderr, "No matching asterisk for %s:%d\n", line_or_source, + i); + exit(-1); + } + } + + // one asterisk + else + { + tag = "<i>"; + close_tag = "</i>"; + tag_size = 3; + md_tag_size = 1; + while ((j < size_of_line) && (src[j] != '*')) ++j; + + if (src[j] == '*') + { + lower = i; + upper = j; + } + else + { + // error, no matching asterisk + fprintf(stderr, "No matching asterisk for %s:%d\n", line_or_source, + i); + exit(-1); + } + } + + /* + * Copy all + */ + size_of_content = upper - lower - 1; + strncpy(dest + cursor, tag, tag_size); + strncpy(dest + cursor + tag_size, src + lower + 1, size_of_content); + strncpy(dest + cursor + tag_size + size_of_content, close_tag, + tag_size + 1); + cursor += + tag_size + size_of_content + tag_size + 1; // shift after operation + i += size_of_content + (2 * md_tag_size) - 1; + } + else + { + strncpy(dest + cursor, &src[i], 1); + cursor += 1; + } + } +} + +string compile_line(string line, size_t size_of_line, string line_or_source) { string compiled_line; size_t size_of_content; + // Compile a header if (line[0] == '#') { - // Compile a header - // Get the level of header (h1, h2, etc) int depth; for (depth = 1; line[depth] == '#'; ++depth) continue; @@ -38,8 +139,9 @@ string compile_line(string line, size_t size_of_line) else { - compiled_line = malloc(sizeof(*compiled_line) * size_of_line); - strncpy(compiled_line, line, size_of_line); + // Assume standard text + compiled_line = malloc(sizeof(*compiled_line) * size_of_line * 2); + compile_plain_text(compiled_line, line, size_of_line, line_or_source); } return compiled_line; |