簡體   English   中英

在Ubuntu 14.04上使用icpc編譯Qt的編譯錯誤

[英]Compilation error compiling Qt with icpc on Ubuntu 14.04

我正在嘗試在Ubuntu 14.04上使用Intel icpc編譯Qt,並且在此文件上收到編譯錯誤-qpnghandler.cpp

從我擁有的qpnghandler.cpp文件中是相關代碼-

static
void setup_qt(QImage& image, png_structp png_ptr, png_infop info_ptr, float screen_gamma=0.0)
{
  if (screen_gamma != 0.0 && png_get_valid(png_ptr, info_ptr, PNG_INFO_gAMA)) {
    double file_gamma;
    png_get_gAMA(png_ptr, info_ptr, &file_gamma);
    png_set_gamma(png_ptr, screen_gamma, file_gamma);
}

png_uint_32 width;
png_uint_32 height;
int bit_depth;
int color_type;
png_get_IHDR(png_ptr, info_ptr, &width, &height, &bit_depth, &color_type, 0, 0, 0);

if (color_type == PNG_COLOR_TYPE_GRAY) {
    // Black & White or 8-bit grayscale
    if (bit_depth == 1 && info_ptr->channels == 1) {
        png_set_invert_mono(png_ptr);
        png_read_update_info(png_ptr, info_ptr);
        if (image.size() != QSize(width, height) || image.format() != QImage::Format_Mono) {
            image = QImage(width, height, QImage::Format_Mono);
            if (image.isNull())
                return;
        }
        image.setColorCount(2);
        image.setColor(1, qRgb(0,0,0));
        image.setColor(0, qRgb(255,255,255));
    } else if (bit_depth == 16 && png_get_valid(png_ptr, info_ptr, PNG_INFO_tRNS)) {
        png_set_expand(png_ptr);
        png_set_strip_16(png_ptr);
        png_set_gray_to_rgb(png_ptr);
        if (image.size() != QSize(width, height) || image.format() != QImage::Format_ARGB32) {
            image = QImage(width, height, QImage::Format_ARGB32);
            if (image.isNull())
                return;
        }
        if (QSysInfo::ByteOrder == QSysInfo::BigEndian)
            png_set_swap_alpha(png_ptr);

        png_read_update_info(png_ptr, info_ptr);
    } else {
        if (bit_depth == 16)
            png_set_strip_16(png_ptr);
        else if (bit_depth < 8)
            png_set_packing(png_ptr);
        int ncols = bit_depth < 8 ? 1 << bit_depth : 256;
        png_read_update_info(png_ptr, info_ptr);
        if (image.size() != QSize(width, height) || image.format() != QImage::Format_Indexed8) {
            image = QImage(width, height, QImage::Format_Indexed8);
            if (image.isNull())
                return;
        }
        image.setColorCount(ncols);
        for (int i=0; i<ncols; i++) {
            int c = i*255/(ncols-1);
            image.setColor(i, qRgba(c,c,c,0xff));
        }
        if (png_get_valid(png_ptr, info_ptr, PNG_INFO_tRNS)) {
#if PNG_LIBPNG_VER_MAJOR < 1 || (PNG_LIBPNG_VER_MAJOR == 1 && PNG_LIBPNG_VER_MINOR < 4)
            const int g = info_ptr->trans_values.gray;
#else
            const int g = info_ptr->trans_color.gray;
#endif
            if (g < ncols) {
                image.setColor(g, 0);
            }
        }
    }
} else if (color_type == PNG_COLOR_TYPE_PALETTE
           && png_get_valid(png_ptr, info_ptr, PNG_INFO_PLTE)
           && info_ptr->num_palette <= 256)
{
    // 1-bit and 8-bit color
    if (bit_depth != 1)
        png_set_packing(png_ptr);
    png_read_update_info(png_ptr, info_ptr);
    png_get_IHDR(png_ptr, info_ptr, &width, &height, &bit_depth, &color_type, 0, 0, 0);
    QImage::Format format = bit_depth == 1 ? QImage::Format_Mono : QImage::Format_Indexed8;
    if (image.size() != QSize(width, height) || image.format() != format) {
        image = QImage(width, height, format);
        if (image.isNull())
            return;
    }
    image.setColorCount(info_ptr->num_palette);
    int i = 0;
    if (png_get_valid(png_ptr, info_ptr, PNG_INFO_tRNS)) {
        while (i < info_ptr->num_trans) {
            image.setColor(i, qRgba(
                info_ptr->palette[i].red,
                info_ptr->palette[i].green,
                info_ptr->palette[i].blue,
 #if PNG_LIBPNG_VER_MAJOR < 1 || (PNG_LIBPNG_VER_MAJOR == 1 && PNG_LIBPNG_VER_MINOR < 4)
                info_ptr->trans[i]
 #else
                info_ptr->trans_alpha[i]
#endif
               )
           );
            i++;
        }
    }
    while (i < info_ptr->num_palette) {
        image.setColor(i, qRgba(
            info_ptr->palette[i].red,
            info_ptr->palette[i].green,
            info_ptr->palette[i].blue,
            0xff
           )
       );
        i++;
    }
} else {
    // 32-bit
    if (bit_depth == 16)
        png_set_strip_16(png_ptr);

    png_set_expand(png_ptr);

    if (color_type == PNG_COLOR_TYPE_GRAY_ALPHA)
        png_set_gray_to_rgb(png_ptr);

    QImage::Format format = QImage::Format_ARGB32;
    // Only add filler if no alpha, or we can get 5 channel data.
    if (!(color_type & PNG_COLOR_MASK_ALPHA)
        && !png_get_valid(png_ptr, info_ptr, PNG_INFO_tRNS)) {
        png_set_filler(png_ptr, 0xff, QSysInfo::ByteOrder == QSysInfo::BigEndian ?
                       PNG_FILLER_BEFORE : PNG_FILLER_AFTER);
        // We want 4 bytes, but it isn't an alpha channel
        format = QImage::Format_RGB32;
    }
    if (image.size() != QSize(width, height) || image.format() != format) {
        image = QImage(width, height, format);
        if (image.isNull())
            return;
    }

    if (QSysInfo::ByteOrder == QSysInfo::BigEndian)
        png_set_swap_alpha(png_ptr);

    png_read_update_info(png_ptr, info_ptr);
}

// Qt==ARGB==Big(ARGB)==Little(BGRA)
if (QSysInfo::ByteOrder == QSysInfo::LittleEndian) {
    png_set_bgr(png_ptr);
}

}

有人可以指導我對文件進行哪些修改,以便編譯qpnghandler.cpp嗎?

icpc -c -wd654,1572 -g -pthread -I/usr/include/glib-2.0 -I/usr/lib/x86_64-linux-gnu/glib-2.0/include -O2 -fvisibility=hidden -fvisibility-inlines-hidden -D_REENTRANT -I/usr/include/freetype2 -fPIC -DQT_SHARED -DQT_BUILD_GUI_LIB -DQT_NO_USING_NAMESPACE -DQT_NO_CAST_TO_ASCII -DQT_ASCII_CAST_WARNINGS -DQT3_SUPPORT -DQT_MOC_COMPAT -DQT_HAVE_MMX -DQT_HAVE_SSE -DQT_HAVE_MMXEXT -DQT_HAVE_SSE2 -DQT_NO_OPENTYPE -DQT_NO_STYLE_MAC -DQT_NO_STYLE_WINDOWSVISTA -DQT_NO_STYLE_WINDOWSXP -DQT_NO_STYLE_WINDOWSCE -DQT_NO_STYLE_WINDOWSMOBILE -DQT_NO_STYLE_S60 -DQ_INTERNAL_QAPP_SRC -DQT_NO_DEBUG -DQT_CORE_LIB -D_LARGEFILE64_SOURCE -D_LARGEFILE_SOURCE -I../../mkspecs/linux-icc -I. -I../../include/QtCore -I../../include -I../../include/QtGui -I.rcc/release-shared -I../3rdparty/xorg -I/usr/include/freetype2 -I../3rdparty/harfbuzz/src -Idialogs -I.moc/release-shared -I/usr/X11R6/include -I.uic/release-shared -o .obj/release-shared/qpnghandler.o image/qpnghandler.cpp

image/qpnghandler.cpp(169): error: pointer to incomplete class type is not allowed
      if (bit_depth == 1 && info_ptr->channels == 1) {
                            ^

image/qpnghandler.cpp(214): error: pointer to incomplete class type is not allowed
              const int g = info_ptr->trans_color.gray;
                            ^

image/qpnghandler.cpp(223): error: pointer to incomplete class type is not allowed
             && info_ptr->num_palette <= 256)
                ^

image/qpnghandler.cpp(236): error: pointer to incomplete class type is not allowed
      image.setColorCount(info_ptr->num_palette);
                          ^

image/qpnghandler.cpp(239): error: pointer to incomplete class type is not allowed
          while (i < info_ptr->num_trans) {
                     ^

 image/qpnghandler.cpp(241): error: pointer to incomplete class type is not allowed
                  info_ptr->palette[i].red,
                  ^

image/qpnghandler.cpp(242): error: pointer to incomplete class type is not allowed
                  info_ptr->palette[i].green,
                  ^

TL; DR:您正在針對新的libpng編譯古老的Qt。 這個新的libpng以不兼容的方式更改了其API。 較新的Qt支持此較新的libpng很好。

Qt 4.6於2009年發布。如果由於某種原因而受困於Qt 4.x,則絕對應該使用4.8分支-因為它包含安全性和可移植性修補程序,例如可解決您遇到的問題的修補程序。 但是,對Qt 4.x分支的上游支持已經結束,因此,如果您正在積極從事此項目(並且希望將來繼續進行此工作),您應該考慮將代碼移植到Qt5.x。 )。

如果出於某種原因拼命要創建Frankenstein版本的Qt 4.6(也許您正在將Qt 4中的一個棘手的錯誤一分為二,並且想追溯到七年前的歷史中來查看該版本是否也有問題),則應該查看使用libpng的1.4分支。 如果由於某種原因無法實現,那么您可以小心地將Qt的PNG代碼移植到libpng-1.5libpng-1.6的API中。 有關如何執行此操作的詳細信息,請參見libpng 1.5.10錯誤:取消引用不完整類型的指針

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM