Add an easy way to edit a configuration file.

This commit is contained in:
Guus Sliepen 2012-07-15 20:37:38 +02:00
parent cedfeccb24
commit eb01fd9625
3 changed files with 61 additions and 0 deletions

View file

@ -2056,6 +2056,10 @@ As above, but without removing any previously existing configuration variables.
Remove configuration variables with the same name and @var{value}. Remove configuration variables with the same name and @var{value}.
If no @var{value} is given, all configuration variables with the same name will be removed. If no @var{value} is given, all configuration variables with the same name will be removed.
@item edit @var{filename}
Start an editor for the given configuration file.
You do not need to specify the full path to the file.
@item start @item start
Start @samp{tincd}. Start @samp{tincd}.

View file

@ -68,6 +68,9 @@ Remove configuration variables with the same name and
If no If no
.Ar value .Ar value
is given, all configuration variables with the same name will be removed. is given, all configuration variables with the same name will be removed.
.It edit Ar filename
Start an editor for the given configuration file.
You do not need to specify the full path to the file.
.It start .It start
Start Start
.Xr tincd 8 . .Xr tincd 8 .

View file

@ -1269,6 +1269,59 @@ static int cmd_version(int argc, char *argv[]) {
return 0; return 0;
} }
static const char *conffiles[] = {
"tinc.conf",
"tinc-up",
"tinc-down",
"subnet-up",
"subnet-down",
"host-up",
"host-down",
NULL,
};
static int cmd_edit(int argc, char *argv[]) {
if(argc != 2) {
fprintf(stderr, "Invalid number of arguments.\n");
return 1;
}
char *filename = NULL;
if(strncmp(argv[1], "hosts/", 6)) {
for(int i = 0; conffiles[i]; i++) {
if(!strcmp(argv[1], conffiles[i])) {
xasprintf(&filename, "%s/%s", confbase, argv[1]);
break;
}
}
} else {
argv[1] += 6;
}
if(!filename) {
xasprintf(&filename, "%s/%s", hosts_dir, argv[1]);
char *dash = strchr(argv[1], '-');
if(dash) {
*dash++ = 0;
if((strcmp(dash, "up") && strcmp(dash, "down")) || !check_id(argv[1])) {
fprintf(stderr, "Invalid configuration filename.\n");
return 1;
}
}
}
#ifndef HAVE_MINGW
char *editor = getenv("VISUAL") ?: getenv("EDITOR") ?: "vi";
#else
char *editor = "edit"
#endif
char *command;
xasprintf(&command, "\"%s\" \"%s\"", editor, filename);
return system(command);
}
static const struct { static const struct {
const char *command; const char *command;
int (*function)(int argc, char *argv[]); int (*function)(int argc, char *argv[]);
@ -1294,6 +1347,7 @@ static const struct {
{"generate-ecdsa-keys", cmd_generate_ecdsa_keys}, {"generate-ecdsa-keys", cmd_generate_ecdsa_keys},
{"help", cmd_help}, {"help", cmd_help},
{"version", cmd_version}, {"version", cmd_version},
{"edit", cmd_edit},
{NULL, NULL}, {NULL, NULL},
}; };