用main(int argc,char ** argv){}重写程序作为函数

时间:2014-07-17 10:35:13

标签: c function main

我想重写一个以main(){}开头的程序,以便我可以将它用作函数。 通常,程序期望输入文件是输出文件,并且可选地最多6个参数。 我在命令行中传递它们:

programname --opt1 --op2 --op3 <input file> output file

然后getopt_long (int argc, char *const *argv, const char *shortopts, const struct option *longopts, int *indexptr)读取程序中的不同参数。

当我想创建一个函数时,我必须将名称main()交给其他人,让我们说programname(),除此之外我必须直接传递参数,所以

main(int argc, char **argv){}

它变成了例如:

main(int opt1, int opt2, int opt3, FILE *infile, FILE *outfile){}

我的问题是:如何管理输入参数数量的可选性?使用getopt_long我可以使用--opt1代替-opt1进行管理,但getopt_long只能在主要功能中使用,或者? 我可以以某种方式创建一个没有指定输入数量的函数吗?

感谢您的帮助!

编辑: 现在我尝试用scanf()

从用户那里读取argv

一个小例子,你可以尝试例如: 第一次输入: - dd = 2 第二个输入:ok

#include <getopt.h>
void main(){

    char **options = (char**) malloc(6*sizeof(char*));
    int i;
    for(i=0;i<6;i++){
        options[i] = (char*) malloc(100*sizeof(char));
    }

    int argc=1;

    printf("%s\n", "insert your options. e.g.: [--ngf=20]");
    printf("%s\n", "if finished press [ok]");

    scanf("%s",options[argc]);
    while (strcmp(options[argc],"ok")!=0){
        argc++;
        scanf("%s",options[argc]);
    }

    char **argv = (char**) malloc(argc*sizeof(char*));

    for(i=0;i<argc;i++){
        argv[i] = (char*) malloc(100*sizeof(char));
    }
    for(i=0;i<argc;i++){
        argv[i] = options[i];
    }

    /* Process Arguments */
      optind = 1;
      double aa,bb,cc;
      int c, dd;
      int option_index = 0;
      static struct option long_options[] = {
             {"aa", 1, 0, 1},
             {"bb", 1, 0, 2},
             {"cc", 1, 0, 3},
             {"dd", 1, 0, 4},
             {0, 0, 0, 0}
      };
      while ((c = getopt_long(argc,argv,"hgt",
                              long_options, &option_index)) != -1) {
        switch (c) {
        case 1: if (sscanf(optarg,"%lg",&aa) != 1)
                           fun_Stop("incorrect format");
        break;
        case 2: if (sscanf(optarg,"%lg",&bb) != 1)
                           fun_Stop("incorrect format ");
        break;
        case 3: if (sscanf(optarg,"%lg",&cc) != 1)
                           fun_Stop("incorrect format");
        break;
        case 4: if (sscanf(optarg,"%i",&dd) != 1)
                           fun_Stop("incorrect format");
        break;
        default  :
          break;
        }
      }
}

3 个答案:

答案 0 :(得分:1)

有几种可能性:

1)你保持接口完好无损。这意味着你必须在调用代码时自己构建argc argv。像这样:

void myfunction(int argc, char **argv);

...

char *arguments[5]={"whatever","--opt1","--opt2","blabla","blablabla"};
myfunction(5,arguments);

你可以像以前一样使用getopt_long。请注意,第一个参数argv [0]是程序的名称(在这种情况下不重要),而不是您的第一个参数,它位于argv [1]中。

2)如果您的选项只是二进制开/关事务,您可以将选项定义为可以在位域中组合的常量。像这样:

typedef enum {opt1=1, opt2=2, opt3=4, opt4=8} Opts;

void myfunction(unsigned long opts, char *input, char *output)
{
   if(opts&opt1)
    printf("Option 1!\n");

    ...
}

...

myfunction(opt1|opt2,"blabla","blablabla");

这应该取决于32或64种不同选项的架构。

答案 1 :(得分:0)

自己解析argc / argv&gt; o&lt;

if (argc >= 2)
{
    for (int i = 1; i < argc; i++)
    {
        char * const arg = argv[i];
        // parse..
    }
}

或者,您可以使用Boost.ProgramOptions。 (如果你使用的是C ++)

答案 2 :(得分:0)

已经在argc和argv中完成了。传递给程序的参数数量由操作系统存储在argc(参数计数器)中,然后您可以在argv(参数向量)中获取数据。你不需要做你想做的事情,只需简单一点。