/* daisy
* alif@radhitya.org
*
* thank you stackoverflow, geeksforgeeks, grok
*/
#define _DEFAULT_SOURCE
#include ");
}
for (i = 0; i < len; i++) {
if (txt[i] == '_' && (i == 0 || txt[i-1] != '\\')) {
doitalic();
} else if (txt[i] == '!' && (i == 0 || txt[i-1] != '\\')) {
doimage();
} else if (txt[i] == '[' && (i == 0 || txt[i-1] != '\\')) {
dohyperlink();
} else if (txt[i] == '`' && (i == 0 || txt[i-1] != '\\')) {
docode();
} else if (i + 1 < len && txt[i] == '*' && txt[i+1] == '*' && (i == 0 || txt[i-1] != '\\')) {
dobold();
} else {
fputc(txt[i], fpto);
}
}
if (mdt.italic) fprintf(fpto, "");
else if (mdt.code) fprintf(fpto, "");
else if (mdt.bold) fprintf(fpto, "");
else if (mdt.quote) fprintf(fpto, "");
mdt.quote = 1;
}
void
doimage(void) {
if (i + 1 < len && txt[i+1] == '[' && (i == 0 || txt[i] != '\\')) {
int alt_start = i + 2;
int alt_end = -1;
int url_start = -1;
int url_end = -1;
int j;
for (j = alt_start; j < len; j++) {
if (txt[j] == ']' && (j == 0 || txt[j-1] != '\\')) {
alt_end = j;
break;
}
}
if (alt_end != -1) {
for (j = alt_end + 1; j < len; j++) {
if (txt[j] == '(' && (j == 0 || txt[j-1] != '\\')) {
url_start = j + 1;
break;
}
}
if (url_start != -1) {
for (j = url_start; j < len; j++) {
if (txt[j] == ')' && (j == 0 || txt[j-1] != '\\')) {
url_end = j;
break;
}
}
}
}
if (alt_end != -1 && url_end != -1) {
char alt_text[100], url[100];
int alt_len = alt_end - alt_start;
int url_len = url_end - url_start;
strncpy(alt_text, txt + alt_start, alt_len);
alt_text[alt_len] = '\0';
strncpy(url, txt + url_start, url_len);
url[url_len] = '\0';
fprintf(fpto, "
\n");
else if (mdt.headingone) fprintf(fpto, "\n");
else if (mdt.headingtwo) fprintf(fpto, "\n");
else if (mdt.headingthree) fprintf(fpto, "\n");
if (!(mdt.headingone || mdt.headingtwo || mdt.headingthree || mdt.quote)) fprintf(fpto, "", url, alt_text);
i = url_end;
} else {
fprintf(fpto, "!");
}
} else {
fprintf(fpto, "!");
}
}
void
docode(void) {
if (!mdt.code) {
fprintf(fpto, "
");
mdt.code = 1;
} else {
fprintf(fpto, "");
mdt.code = 0;
}
}
void
dohyperlink(void) {
int start_linkname = i + 1;
int end_linkname = -1;
int start_linkurl = -1;
int end_linkurl = -1;
int j;
for (j = start_linkname; j < len; j++) {
if (txt[j] == ']' && (j == 0 || txt[j-1] != '\\')) {
end_linkname = j;
break;
}
}
if (end_linkname != -1) {
for (j = end_linkname + 1; j < len; j++) {
if (txt[j] == '(' && (j == 0 || txt[j-1] != '\\')) {
start_linkurl = j + 1;
break;
}
}
if (start_linkurl != -1) {
for (j = start_linkurl; j < len; j++) {
if (txt[j] == ')' && (j == 0 || txt[j-1] != '\\')) {
end_linkurl = j;
break;
}
}
}
}
if (end_linkname != -1 && end_linkurl != -1) {
char linkname[100], linkurl[100];
int linkname_len = end_linkname - start_linkname;
int linkurl_len = end_linkurl - start_linkurl;
strncpy(linkname, txt + start_linkname, linkname_len);
linkname[linkname_len] = '\0';
strncpy(linkurl, txt + start_linkurl, linkurl_len);
linkurl[linkurl_len] = '\0';
fprintf(fpto, "%s", linkurl, linkname);
i = end_linkurl;
} else {
fprintf(fpto, "[");
}
}
void build(void) {
}
void generate(void) {
fprintf(fpto, "\n\n");
fprintf(fpto, "\n");
fprintf(fpto, ""); mdt.headingone = 1; break;
case 3: fprintf(fpto, "
"); mdt.headingtwo = 1; break;
case 4: fprintf(fpto, "
"); mdt.headingthree = 1; break;
default: i = 0; break;
}
while (i < len && txt[i] == ' ') i++;
} else if (len > 1 && txt[0] == '>' && txt[1] != '\\') {
doblockquote();
while (i < len && (txt[i] == '>' || txt[i] == ' ')) i++;
} else {
fprintf(fpto, "