diary

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

commit f8cf772f9a3cd91676038da929167577f31967e0
parent ea39be827a4e1bd01af650ab3b838fbbd83eeaee
Author: Andreas Gruhler <agruhl@gmx.ch>
Date:   Sat,  2 Jan 2021 09:28:25 +0100

Merge pull request #58 from in0rdr/fix/55/diary_dir

Fix sizeof diary_dir
Diffstat:
Mdiary.c | 14+++++++-------
1 file changed, 7 insertions(+), 7 deletions(-)

diff --git a/diary.c b/diary.c @@ -289,14 +289,14 @@ struct tm find_closest_entry(const struct tm current, /* Set the diary storage directory. * Copies the path to the storage directory from character -* string `path` to the destination location `diary_dir` +* string `path` to the destination location `pdiary_dir` */ -bool set_diary_dir(char* path, char* diary_dir) { - if (strlen(path) + 1 > sizeof diary_dir) { +bool set_diary_dir(char* path, char* pdiary_dir, size_t diary_dir_size) { + if (strlen(path) + 1 > diary_dir_size) { fprintf(stderr, "Diary directory path too long\n"); return false; } - strcpy(diary_dir, path); + strcpy(pdiary_dir, path); return true; } @@ -335,7 +335,7 @@ int main(int argc, char** argv) { } // set diary directory from environment variable - if ( !set_diary_dir(env_var, diary_dir) ) { + if ( !set_diary_dir(env_var, diary_dir, sizeof diary_dir) ) { return 1; } } else { @@ -372,7 +372,7 @@ int main(int argc, char** argv) { break; case 'd': // set diary directory from option character - if ( !set_diary_dir(optarg, diary_dir) ) { + if ( !set_diary_dir(optarg, diary_dir, sizeof diary_dir) ) { return 1; } break; @@ -384,7 +384,7 @@ int main(int argc, char** argv) { if (optind < argc) { // set diary directory from first non-option argv-element, // required for backwarad compatibility with diary <= 0.4 - if ( !set_diary_dir(argv[optind], diary_dir) ) { + if ( !set_diary_dir(argv[optind], diary_dir, sizeof diary_dir) ) { return 1; } }