diff options
Diffstat (limited to 'src/actionhelper.c')
-rw-r--r-- | src/actionhelper.c | 68 |
1 files changed, 63 insertions, 5 deletions
diff --git a/src/actionhelper.c b/src/actionhelper.c index 55f0326..7d6aa8a 100644 --- a/src/actionhelper.c +++ b/src/actionhelper.c @@ -1,11 +1,69 @@ +/* actionhelper.c - helper functions for ck actions --------------------*- C -*- + * + * This file is part of ck, the config keeper + * + * ----------------------------------------------------------------------------- + * + * Copyright (C) 2018 Anastasis Grammenos + * GPLv3 (see LICENCE for the full notice) + * + * ----------------------------------------------------------------------------- + * + * + * + * -------------------------------------------------------------------------- */ #include "actionhelper.h" -/* Holds the suggestions */ -char _sug[2][STR_L]; +char add_err[STR_M] = ""; + +int add_err_message(char *err) { + if (!str_is_empty(add_err)) { + if (err) { + strcpy(err, add_err); + } + return 1; + } + return 0; +} + +int copy_config(char *path); + + +void link_config(const AddOpt *opt, const char* newPath) { + printf("Linking %s -> %s\n", newPath, opt->confPath); + if (util_symlink_file(newPath, opt->confPath) != 0) { + strcpy(add_err, "Could not link file."); + } +} + +void move_config(const AddOpt *opt, const Conf *conf, char *ret) { + char newName[STR_M]; + str_make_ck_config_name(newName, opt->confPath, opt->progName); + char newPath[STR_L]; + str_join_dirname_with_basename(newPath, opt->secret ? conf->SCRT_dir : conf->VC_dir, newName); + printf("Moving %s -> %s\n", opt->confPath, newPath); + strcpy(ret, newPath); + if (util_move_file(opt->confPath, newPath) != 0) { + strcpy(add_err, "Could not move file."); + } +} + +void add_make_link(const AddOpt *opt, + const Conf *conf) { + char newPath[STR_L]; + move_config(opt, conf, newPath); + if (add_err_message(NULL)) { + return; + } + link_config(opt, newPath); + if (add_err_message(NULL)) { + return; + } +} edit_rc -edit_get_config_or_suggestions(const int argc, - char **argv, - char *ret) { +edit_get_config_or_suggestions(cklist *args, char *ret) { + UNUSED(args); + UNUSED(ret); return ERC_ERR; } |