質問

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/~
.

最初のケースでこの機能を提供したい場合は、シェルがあなたを助けることができない、またはシェルによって使用されている単語の展開では、必要な情報を見つけることができます。このリファレンス

ライセンス: CC-BY-SA帰属
所属していません StackOverflow
scroll top