C.でgetopt_longを使用した無効なファイルパス
-
26-12-2019 - |
質問
optarg
は次の場合に無効なパスを返すのですか?
そしてそれは両方の場合で動作するように回避策となるでしょう。
#include <stdio.h>
#include <stdlib.h>
#include <getopt.h>
int main(int argc, char *argv[]) {
int opt = 0;
int long_index = 0;
char *f;
static struct option longopt[] = {
{"foo", required_argument, 0, 'd' },
{0,0,0,0}
};
while ((opt = getopt_long(argc, argv,"d:", longopt, &long_index )) != -1) {
switch (opt) {
case 'd' :
printf("\n%s\n", optarg);
f = realpath (optarg, NULL);
if (f) printf("%s\n", f);
break;
default:
exit(1);
}
}
return 0;
}
.
出力:
$ ./a.out --foo=~/.bashrc
~/.bashrc
$ ./a.out --foo ~/.bashrc
/home/user/.bashrc
. 解決
シェルによって "Tilde Expansion"が実行されているために発生します。それはそれ自体で有効なパスではありません。tilde~は、文字列引数の先頭にある場合にのみホームディレクトリとして展開されます。これはパスのように見えます。例えば:
$ echo ~
/home/sigi
$ echo ~/a
/home/sigi/a
$ echo ~root/a
/root/a
$ echo ~a
~a
$ echo a/~
a/~
.
最初のケースでこの機能を提供したい場合は、シェルがあなたを助けることができない、またはシェルによって使用されている単語の展開では、必要な情報を見つけることができます。このリファレンス
所属していません StackOverflow