FreeWRL,"格式不是字符串文字,没有格式参数"

dam*_*ian 2 c printf android-ndk

所以我正在尝试构建freewrl android库,这是在本机android代码中,这意味着在C中.我不熟悉C,并且认为既然包含了构建脚本,它应该可以正常运行的盒子.- 它不是.在解决了一些小问题之后,这就是我现在正在看的内容:

/opt/freewrl/Android/jni/../../freex3d/src/lib/main/ConsoleMessage.c: In function 'fwvsnprintf':
/opt/freewrl/Android/jni/../../freex3d/src/lib/main/ConsoleMessage.c:333:4: error: format not a string literal and no format arguments [-Werror=format-security]
cc1: some warnings being treated as errors
make: *** [/opt/freewrl/Android/obj/local/armeabi/objs/FreeWRL/__/__/freex3d/src/lib/main/ConsoleMessage.o] Error 1
Run Code Online (Sandbox Code Playgroud)

ConsoleMessage.c中与之相关的代码如下:

count += sprintf(tempbuf, format);/* printf it verbatim             */
Run Code Online (Sandbox Code Playgroud)

这是以下构造或函数的一部分:

int fwvsnprintf(char *buffer,int buffer_length, const char *fmt, va_list ap)
{
    int i,j,count;
    //char tempbuf[STRING_LENGTH];
    //char format[STRING_LENGTH];
    char *tempbuf;
    char *format;
    char c;
    double d;
    unsigned u;
    char *s;
    void *v;
    tempbuf = malloc(buffer_length);
    format = malloc(buffer_length);
    count = 0;
    buffer[0] = '\0';
    while (*fmt) 
    {
        tempbuf[0] = '\0';
        for (j = 0; fmt[j] && fmt[j] != '%'; j++) {
            format[j] = fmt[j]; /* not a format string  */
        }

        if (j) {
            format[j] = '\0';
            count += sprintf(tempbuf, format);/* printf it verbatim             */
            fmt += j;
        } else {
            for (j = 0; !isalpha(fmt[j]); j++) {     /* find end of format specifier */
                format[j] = fmt[j];
                if (j && fmt[j] == '%')             /* special case printing '%'        */
                    break;
            }
            format[j] = fmt[j];         /* finish writing specifier      */
            format[j + 1] = '\0';           /* don't forget NULL terminator */
            fmt += j + 1;

            switch (format[j]) {             /* cases for all specifiers         */
            case 'd':
            case 'i':                       /* many use identical actions    */
                i = va_arg(ap, int);         /* process the argument     */
                count += sprintf(tempbuf, format, i); /* and printf it       */
                break;
            case 'o':
            case 'x':
            case 'X':
            case 'u':
                u = va_arg(ap, unsigned);
                count += sprintf(tempbuf, format, u);
                break;
            case 'c':
                c = (char) va_arg(ap, int);     /* must cast!            */
                count += sprintf(tempbuf, format, c);
                break;
            case 's':
                s = va_arg(ap, char *);
                /* limit string to a certain length */
                if ((strlen(s) + count) > buffer_length) {
                    char tmpstr[100];
                    int ltc;
                    ltc = (int) strlen(s);
                    if (ltc>80) ltc=80;
                    strncpy (tmpstr, s, ltc);
                    tmpstr[ltc] = '.'; ltc++;
                    tmpstr[ltc] = '.'; ltc++;
                    tmpstr[ltc] = '.'; ltc++;
                    tmpstr[ltc] = '\0';

                    count += sprintf (tempbuf, format, tmpstr);
                } else count += sprintf(tempbuf, format, s);
                break;
            case 'f':
            case 'e':
            case 'E':
            case 'g':
            case 'G':
                d = va_arg(ap, double);
                count += sprintf(tempbuf, format, d);
                break;
            case 'p':
                v = va_arg(ap, void *);
                count += sprintf(tempbuf, format, v);
                break;
            case 'n':
                count += sprintf(tempbuf, "%d", count);
                break;
            case '%':
                count += sprintf(tempbuf, "%%");
                break;
            default:
                ERROR_MSG("ConsoleMessage: invalid format specifier: %c\n", format[j]);
            }
        }
        if( (strlen(tempbuf) + strlen(buffer)) < (buffer_length) -10) 
        {
            strcat (buffer,tempbuf);
        }
    }
    free(tempbuf);
    free(format);
    return 1;
}
Run Code Online (Sandbox Code Playgroud)

因此,据我所见,format充满了内容fmt,这是一个参数,直到%读取.tempbuf看起来像'\ 0'对我来说是一个空字节.但就我而言,这是我所能得到的,所以我很感激任何帮助,因为我正在努力建立这个库.先感谢您.

Jay*_*hoi 7

根据错误,似乎在您makefile-Werror=format-security标志中默认启用,并且非常好,不会导致字符串格式的任何安全问题,如in printfscanffunction.So警告在源中被视为错误.因此,如果您不担心安全性,请禁用它.或者请在代码中的任何地方更改相同的语句,如下所示可能会删除错误.

count += sprintf(tempbuf,"%s",format);/* printf it verbatim             */
Run Code Online (Sandbox Code Playgroud)

为安全使用snprintf喜欢

count += snprintf(tempbuf,buffer_length,"%s",format);/* printf it verbatim             */
Run Code Online (Sandbox Code Playgroud)