X-Git-Url: https://git.danieliu.xyz/?a=blobdiff_plain;f=parser.c;h=3474cfdc94ec5490c6b018487a6a992066cf7f69;hb=8464e8bb01d5fd455653927245b61f3b31873044;hp=41219641e1c5a5257b5aa8f71b06cd5a552c0e09;hpb=f7c44aadc65ba6401992ec02f7ccb1ea4c2301ff;p=smdp.git
diff --git a/parser.c b/parser.c
index 4121964..3474cfd 100644
--- a/parser.c
+++ b/parser.c
@@ -1,3 +1,27 @@
+/*
+ * Functions necessary to parse a file and transform its content into
+ * a deck of slides containing lines. All based on markdown formating
+ * rules.
+ * Copyright (C) 2014 Michael Goehler
+ *
+ * This file is part of mpd.
+ *
+ * This program is free software: you can redistribute it and/or modify
+ * it under the terms of the GNU General Public License as published by
+ * the Free Software Foundation, either version 3 of the License, or
+ * (at your option) any later version.
+ *
+ * This program is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+ * GNU General Public License for more details.
+ *
+ * You should have received a copy of the GNU General Public License
+ * along with this program. If not, see .
+ *
+ */
+
+#include
#include
#include
@@ -80,11 +104,35 @@ deck_t *markdown_load(FILE *input) {
} else if(c == '\t') {
// expand tab to spaces
- for (i = 0; i <= 4; i++) {
+ for (i = 0; i < EXPAND_TABS; i++) {
(text->expand)(text, ' ');
l++;
}
+ } else if(c == '\\') {
+
+ // add char to line
+ (text->expand)(text, c);
+ l++;
+
+ // if !IS_CODE add next char to line
+ // and do not increase line count
+ if(next_nonblank(text, 0) < CODE_INDENT) {
+
+ c = fgetc(input);
+ (text->expand)(text, c);
+
+ if(is_utf8(c)) {
+
+ // if utf-8 char > 1 byte add remaing to line
+ for(i = 0; i < length_utf8(c) - 1; i++) {
+ c = fgetc(input);
+ (text->expand)(text, c);
+ }
+ }
+
+ }
+
} else if(isprint(c) || isspace(c)) {
// add char to line
@@ -101,6 +149,7 @@ deck_t *markdown_load(FILE *input) {
c = fgetc(input);
(text->expand)(text, c);
}
+
l++;
}
}
@@ -146,7 +195,8 @@ deck_t *markdown_load(FILE *input) {
// remove line from linked list
line->prev->next = line->next;
- line->next->prev = line->prev;
+ if(line->next)
+ line->next->prev = line->prev;
// set bits on revious line
if(CHECK_BIT(line->bits, IS_H1)) {
@@ -187,15 +237,28 @@ int markdown_analyse(cstring_t *text) {
// strip trailing spaces
for(eol = text->size; eol > offset && isspace(text->text[eol - 1]); eol--);
+ // IS_CODE
+ if(offset >= CODE_INDENT) {
+ SET_BIT(bits, IS_CODE);
+ }
+
for(i = offset; i < eol; i++) {
- switch(text->text[i]) {
- case '=': equals++; break;
- case '#': hashes++; break;
- case '*': stars++; break;
- case '-': minus++; break;
- case ' ': spaces++; break;
- default: other++; break;
+ if(text->text[i] == ' ') {
+ spaces++;
+
+ } else if(CHECK_BIT(bits, IS_CODE)) {
+ other++;
+
+ } else {
+ switch(text->text[i]) {
+ case '=': equals++; break;
+ case '#': hashes++; break;
+ case '*': stars++; break;
+ case '-': minus++; break;
+ case '\\': other++; i++; break;
+ default: other++; break;
+ }
}
}
@@ -229,11 +292,6 @@ int markdown_analyse(cstring_t *text) {
SET_BIT(bits, IS_QUOTE);
}
- // IS_CODE
- if(offset >= 4) {
- SET_BIT(bits, IS_CODE);
- }
-
// IS_HR
if((minus >= 3 && equals + hashes + stars + other == 0) ||
(stars >= 3 && equals + hashes + minus + other == 0)) {
@@ -326,12 +384,16 @@ int next_nonblank(cstring_t *text, int i) {
++i;
return i;
-};
+}
int next_blank(cstring_t *text, int i) {
while ((i < text->size) && !isspace((text->text)[i]))
++i;
return i;
-};
+}
+
+int next_word(cstring_t *text, int i) {
+ return next_nonblank(text, next_blank(text, i));
+}