handling header blocks
[taskasaur.git] / parser.c
index 0f476b4..1c3cb13 100644 (file)
--- a/parser.c
+++ b/parser.c
@@ -1,6 +1,7 @@
 #include <stdio.h>
 #include <stdlib.h>
 #include <string.h>
+#include <md4c.h>
 
 typedef struct TodoItem {
     char* name;
@@ -9,70 +10,122 @@ typedef struct TodoItem {
     char** items;
 } TodoItem;
 
-void parse(FILE* file, int* length);
-
-
-static char task_md[] = "###";
+char* read_file(char* file_name, long* size);
+
+/* callbacks to parser */
+int enter_block(MD_BLOCKTYPE type, void* detail, void* userdata);
+int leave_block(MD_BLOCKTYPE type, void* detail, void* userdata);
+int enter_span(MD_SPANTYPE type, void* detail, void* userdata);
+int leave_span(MD_SPANTYPE type, void* detail, void* userdata);
+int text(MD_TEXTTYPE type, const MD_CHAR* text, MD_SIZE size, void* userdata);
+void debug_log(const char* msg, void* userdata);
+void syntax(void);
+
+const MD_PARSER parser = {
+    0,
+    MD_DIALECT_COMMONMARK,
+    &enter_block,
+    &leave_block,
+    &enter_span,
+    &leave_span,
+    &text,
+    &debug_log,
+    &syntax
+};
 
 int
 main(int argc, char** argv)
 {
-    FILE* input_file;
-    int todo_length;
+    const char* input_buffer;
+    long input_size;
 
-    input_file = fopen("test_board.md", "r");     
-    if (!input_file) {
-        printf("Something went wrong opening file");
-        return 1;
-    }
+    input_buffer = read_file("test_board.md", &input_size);
 
-    parse(input_file, &todo_length);
+    int out = md_parse(input_buffer, input_size, &parser, NULL);
 
     return 0;    
 }
 
-/* TodoItem** */ 
-void
-parse(FILE* file, int* length) 
-{
-    TodoItem** out_arr;
-    int out_len;
-    char* lineptr;
-    size_t len;
-    ssize_t nread;
+char*
+read_file(char* file_name, long* size) 
+{ // apparently using seek isnt the greatest, may change to chunk reading later
+    FILE* file;
+    char* output;
+    long fsize;
+
+    file = fopen(file_name, "r");
+    if (file == NULL) {
+        printf("Something went wrong opening file\n");
+        return NULL;
+    }
 
-    out_arr = NULL;
-    out_len = 0;
-    lineptr = NULL;
-    len = 0;
+    fseek(file, 0, SEEK_END);
+    fsize = ftell(file);
+    fseek(file, 0, SEEK_SET);
+
+    output = malloc(fsize+1); // maybe error check malloc
+    fread(output, 1, fsize, file);
+    if (ferror(file)) {
+        printf("Something went wrong reading file\n");
+        fclose(file);
+        free(output);
+        return NULL;
+    }
+    output[fsize] = 0; // add null terminator
+    
+    /* clean up */
+    fclose(file);
 
-    while ((nread = getline(&lineptr, &len, file)) != -1) {
+    /* return */
+    *size = fsize;
+    return output;
+}
 
-        lineptr[strcspn(lineptr, "\n")] = 0; // remove newline
-        
-        if (strcmp(lineptr, "") == 0) {
-            printf("found empty line\n");
-            lineptr = NULL;
-            continue;
-        } 
+int
+enter_block(MD_BLOCKTYPE type, void* detail, void* userdata)
+{
+    switch (type) {
+        case MD_BLOCK_H:
+            printf("Found h%d block\n", ((MD_BLOCK_H_DETAIL*)detail)->level);
+            break;
 
-        // found a task
-        if (strlen(lineptr) > 3 && strncmp(lineptr, task_md, 3) == 0) {
-            printf("found_task\n");
-            lineptr = NULL;
-            continue;
-        }
+        // no need for default case for now :>
+    }
+    return 0;
+}
 
+int
+leave_block(MD_BLOCKTYPE type, void* detail, void* userdata)
+{
+    return 0;
+}
 
-        
+int
+enter_span(MD_SPANTYPE type, void* detail, void* userdata)
+{
+    return 0;
+}
 
-        /* out_arr = realloc(out_arr, (sizeof(char*))*out_len); // bad to keep resizing? */
+int
+leave_span(MD_SPANTYPE type, void* detail, void* userdata)
+{
+    return 0;
+}
 
-        /* out_arr[out_len-1] = lineptr; */
+int
+text(MD_TEXTTYPE type, const MD_CHAR* text, MD_SIZE size, void* userdata){
+    return 0;
+}
 
-        lineptr = NULL;
-    }
-    
-    *length = out_len;
-    /* return out_arr; */
+void
+debug_log(const char* msg, void* userdata)
+{
+    printf(msg);
+    return;
+}
+
+void 
+syntax(void)
+{
+    return;
 }