Added link support
authorSimon Doppler <dopsi.dev@gmail.com>
Mon, 24 Nov 2014 19:59:03 +0000 (20:59 +0100)
committerMichael Göhler <somebody.here@gmx.de>
Sun, 30 Nov 2014 20:34:29 +0000 (21:34 +0100)
include/url.h [new file with mode: 0644]
sample.md
src/url.c [new file with mode: 0644]
src/viewer.c

diff --git a/include/url.h b/include/url.h
new file mode 100644 (file)
index 0000000..33a270b
--- /dev/null
@@ -0,0 +1,14 @@
+#ifndef URL_H
+#define URL_H
+
+// init the url module
+void url_init(void);
+
+int url_add(const char * link_name, int link_name_length, const char * target, int target_length, int x, int y);
+char * url_get_target(int index);
+char * url_get_name(int index);
+int url_get_amount(void);
+void url_purge(void);
+void url_dump(void);
+
+#endif // URL_H
index a679ba2..762537d 100644 (file)
--- a/sample.md
+++ b/sample.md
@@ -173,6 +173,15 @@ becomes
 
 -------------------------------------------------
 
+-> # Supported markdown formatting's <-
+
+URL in John MacFarlane's Pandoc style are supported :
+
+[GitHub repository for mdp](https://github.com/visit1985/mdp)
+[Google](google.com)
+
+-------------------------------------------------
+
 -> ## More information about markdown <-
 
 can be found on
diff --git a/src/url.c b/src/url.c
new file mode 100644 (file)
index 0000000..7ccfa10
--- /dev/null
+++ b/src/url.c
@@ -0,0 +1,141 @@
+#include <stdlib.h>
+#include <assert.h>
+#include <string.h>
+#include <stdio.h>
+
+#include "url.h"
+
+typedef struct Url {
+       char * link_name;
+       char * target;
+       int x;
+       int y;
+       struct Url * next;
+} Url_t;
+
+static void url_del_elem(Url_t * elem);
+static void url_print(Url_t * u);
+
+static Url_t *list;
+static int index_max;
+static int init_ok;
+
+void url_init(void) {
+       list = NULL;
+       index_max = 0;
+       init_ok = 1;
+}
+
+int url_add(const char * link_name, int link_name_length, const char * target, int target_length, int x, int y) {
+       if (!init_ok) return -1;
+       
+       Url_t *tmp = NULL;
+       int i = 0;
+       
+       if (list) {
+               tmp = list;
+               while (tmp->next) {
+                       tmp = tmp->next;
+                       i++;
+               }
+               tmp->next = malloc(sizeof(Url_t));
+               assert(tmp->next);
+               tmp = tmp->next;
+       } else {
+               list = malloc(sizeof(Url_t));
+               tmp = list;
+               assert(tmp);
+       }
+       
+       tmp -> link_name = calloc(link_name_length, sizeof(char));
+       assert(tmp->link_name);
+       strncpy(tmp->link_name, link_name, link_name_length);
+       
+       tmp->target = calloc(target_length, sizeof(char));
+       assert(tmp->target);
+       strncpy(tmp->target, target, target_length);
+       
+       tmp->x = x;
+       tmp->y = y;
+       tmp->next = NULL;
+       
+       index_max++;
+       
+       return index_max-1;
+}
+
+
+char * url_get_target(int index) {
+       Url_t * tmp = list;
+       
+       while (index > 0 && tmp && tmp->next) {
+               tmp = tmp->next;
+               index --;
+       }
+       
+       if (!index) {
+               return tmp->target;
+       } else return NULL; 
+}
+
+char * url_get_name(int index) {
+       Url_t * tmp = list;
+       
+       while (index > 0 && tmp && tmp->next) {
+               tmp = tmp->next;
+               index --;
+       }
+       
+       if (!index) {
+               return tmp->link_name;
+       } else return NULL; 
+}
+
+void url_purge() {
+       url_del_elem(list);
+       list = NULL;
+       index_max = 0;
+       init_ok = 0;
+}
+
+static void url_del_elem(Url_t *elem) {
+       if (!elem) return;
+       
+       if (elem->next) {
+               url_del_elem(elem->next);
+               elem->next = NULL;
+       }
+       
+       if (elem->target) {
+               free(elem->target);
+               elem->target = NULL;
+       }
+       
+       if (elem->link_name) {
+               free(elem->link_name);
+               elem->link_name = NULL;
+       }
+       
+       free(elem);
+}
+
+void url_dump(void) {
+       if (!list) return;
+       
+       Url_t *tmp = list;
+       
+       while (tmp) {
+               url_print(tmp);
+               if (tmp->next)
+                       tmp = tmp->next;
+               else break;
+       }
+}
+
+static void url_print(Url_t * u) {
+       printf("Url_t @ %p\n", u);
+}
+
+int url_get_amount(void) {
+       return index_max;
+}
index b9dcbf7..593d9d3 100644 (file)
@@ -27,6 +27,7 @@
 #include <unistd.h> // usleep
 
 #include "viewer.h"
+#include "url.h"
 
 // color ramp for fading from black to color
 static short white_ramp[24] = { 16, 232, 233, 234, 235, 236,
@@ -234,6 +235,9 @@ int ncurses_display(deck_t *deck, int notrans, int nofade, int invert) {
 
     slide = deck->slide;
     while(slide) {
+               
+               url_init();
+               
         // clear windows
         werase(content);
         werase(stdscr);
@@ -278,6 +282,13 @@ int ncurses_display(deck_t *deck, int notrans, int nofade, int invert) {
             l += (line->length / COLS) + 1;
             line = line->next;
         }
+        
+        int i, ymax;
+        getmaxyx( content, ymax, i );
+        for (i = 0; i < url_get_amount(); i++) {
+                       mvwprintw(content, ymax - url_get_amount() - 1 + i, 3, 
+                               "[%d] %s", i, url_get_target(i));
+               }
 
         // make content visible
         wrefresh(content);
@@ -394,6 +405,8 @@ int ncurses_display(deck_t *deck, int notrans, int nofade, int invert) {
         // fade out
         if(fade)
             fade_out(content, trans, colors, invert);
+           
+        url_purge();
     }
 
     endwin();
@@ -560,8 +573,10 @@ void add_line(WINDOW *window, int y, int x, line_t *line, int max_cols, int colo
 }
 
 void inline_display(WINDOW *window, const char *c, const int colors) {
-    const static char *special = "\\*_`"; // list of interpreted chars
+    const static char *special = "\\*_`["; // list of interpreted chars
     const char *i = c; // iterator
+    const char *start_link_name, *start_url;
+    int length_link_name, url_num;
     cstack_t *stack = cstack_init();
 
 
@@ -618,7 +633,41 @@ void inline_display(WINDOW *window, const char *c, const int colors) {
                    ((*(i - 1) == '_' || *(i - 1) == '*') && ((i - 1) == c || *(i - 2) == ' ')) ||
                    *i == '\\') {
 
-                    switch(*i) {
+                    if (*i == '[' && strchr(i, ']')) {
+                                               
+                                               if (strchr(i, ']')[1] == '(') {// url in pandoc style
+                                                       i++;
+                                                       // turn higlighting and underlining on
+                                                       if (colors)
+                                                               wattron(window, COLOR_PAIR(CP_BLUE));
+                                                       wattron(window, A_UNDERLINE);
+                                                       
+                                                       start_link_name = i;
+                                                       
+                                                       // print the content of the label
+                                                       // the label is printed as is
+                                                       do {
+                                                               wprintw(window, "%c", *i);
+                                                               i++;
+                                                       } while (*i != ']');
+                                                       
+                                                       length_link_name = i - 1 - start_link_name;
+                                                       
+                                                       i++;
+                                                       i++;
+                                                       
+                                                       start_url = i;
+                                                       
+                                                       while (*i != ')') i++;
+                                                       
+                                                       url_num = url_add(start_link_name, length_link_name, start_url, i - start_url, 0,0);
+                                                       
+                                                       wprintw(window, "[%d]", url_num);
+                                                       // turn highlighting and undelining off
+                                                       wattroff(window, A_UNDERLINE);
+                                                       wattron(window, COLOR_PAIR(CP_WHITE));
+                                               } else wprintw(window, "[");
+                                       } else switch(*i) {
                         // enable highlight
                         case '*':
                             if(colors)