0

我试图弄清楚如何system()在 SunOS 上进行函数调用(在 C 中),并且没有将任何内容打印到 stderr(或 stdout)。目前,以下代码在 Linux、OSX、HP-UX 和 SunOS 上编译/运行。除了 SunOS,我得到了一个不错的输出,例如:

i = 32512 (0x7f00); wexitstatus = 127

但是,在 SunOS 上,我得到:

sh: unknowncommand: not found
i = 256 (0x100); wexitstatus = 1

...那额外的“sh:”行很烦人:)

(我的目标:安静地以编程方式确定我是否可以执行“cc”和/或“gcc”命令。)

#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <unistd.h>
#include <sys/wait.h>

int main (int argc, char **argv)
{
int i;

char buf [1000];

strcpy (buf, "unknowncommand -c foo.c > /dev/null 2>&1");

i = system (buf);

printf ("i = %d (0x%x); wexitstatus = %d\n", i, i, WEXITSTATUS (i));

return 0;
}
4

3 回答 3

0

这是删除输出的一种简单方法:

strcpy (buf, "sh -c 'unknowncommand -c foo.c' > /dev/null 2>&1");
i = system (buf);
于 2013-09-25T08:16:37.953 回答
0

which 命令将找到一个存在于您的 PATH 变量中的可执行文件。

which gcc
which cc

您可以在系统调用中使用它。

这是一个穷人的版本:

// performs task similar to which command
// mywhich.c
char **split(char **result, char *w, const char *src, const char *delim)
{
    char *p;
    w=strdup(src);
    int i=0;
    for(p=strtok(w, delim); p!=NULL; p=strtok(NULL, delim))
    {
       result[i++]=p;
       result[i]=NULL;
    }
    return result;
}

char *detect_cc(char *cc, char **argv)
{
    char search[PATH_MAX]={0x0};
    char resolved[PATH_MAX]={0x0};

    char *w=NULL;
    int i=0,j=0;
    char *result[1024]={NULL};      // set 1024 to appropriate value
    char *PATH=getenv("PATH");

    *cc=0x0;
    split(result, w, PATH, ":");
    for(i=0 ; !*cc && result[i]!=NULL; i++)
    {
        for(j=0; argv[j]!=NULL; j++)
        {
           sprintf(search,"%s/%s", result[i], argv[j]);

           if(realpath(search, resolved)!=NULL)
           {    
              if(access(resolved, X_OK)==0)
                 strcpy(cc, resolved);
           }  
        }
    }
    free(w);
    return cc;
}


int main(int argc, char **argv)
{
   char cc[PATH_MAX]={0x0};
   argv++;
   detect_cc(cc, argv);
   if(*cc)
     printf("found: %s\n", cc);
   else
     printf("Not found in PATH\n");

   return 0;  
}

用法:

 ./mywhich  gcc cc foo

它在找到的第一个文件上停止。修改代码以在您认为合适的情况下抑制消息。

于 2013-09-25T03:04:38.207 回答
0

您可以使用 popen() 而不是 system() 并显式捕获进程的输出。

于 2013-09-25T02:05:58.257 回答