diary

Text-based journaling program
git clone https://git.in0rdr.ch/diary.git
Log | Files | Refs | Pull requests |Archive | README | LICENSE

commit ede0dbf9aba91d2a16000d684ddf358b7ac14afe
parent 61b1fff5b0e40b7eafca24ff47eaca0899f9c9ab
Author: mbjd <vir.ingens@gmail.com>
Date:   Sat, 19 Nov 2016 14:52:07 +0100

Option to read directory from environment variable

Also, the program now checks if that directory exists instead of
pretending everything's fine and then letting the editor fail

Diffstat:
Mdiary.c | 40+++++++++++++++++++++++++++++++++++++---
1 file changed, 37 insertions(+), 3 deletions(-)

diff --git a/diary.c b/diary.c @@ -1,6 +1,11 @@ #include <stdlib.h> #include <string.h> #include <time.h> +#include <errno.h> + +#include <sys/types.h> +#include <dirent.h> + #include <ncurses.h> #define YEAR_RANGE 1 @@ -158,9 +163,39 @@ void setup_cal_timeframe() { int main(int argc, char** argv) { + // Get the diary directory via environment variable or argument + // If both are given, the argument takes precedence + char* diary_dir = NULL; if (argc < 2) { - printf("Expect diary directory as command line argument\n"); - return 0; + diary_dir = getenv("DIARY_DIR"); + if (diary_dir == NULL) + { + fprintf(stderr, "The diary directory must ge given as command line " + "argument or in the DIARY_DIR environment variable\n"); + return 1; + } + } + else + { + diary_dir = argv[1]; + } + + // Check if that directory exists + DIR* diary_dir_ptr = opendir(diary_dir); + if (diary_dir_ptr) + { + // Directory exists, continue + closedir(diary_dir_ptr); + } + else if (errno = ENOENT) + { + fprintf(stderr, "The directory '%s' does not exist\n", diary_dir); + return 2; + } + else + { + fprintf(stderr, "The directory '%s' could not be opened\n", diary_dir); + return 1; } setup_cal_timeframe(); @@ -182,7 +217,6 @@ int main(int argc, char** argv) int ch; struct tm new_date; - char* diary_dir = argv[1]; // init the current pad possition at the very end, // such that the cursor is displayed top of screen int pad_pos = 9999999;