From ff32834e66f881415549ae94747b5382cf2463ad Mon Sep 17 00:00:00 2001 From: Andreas Sturmlechner Date: Tue, 27 Feb 2018 21:53:26 +0100 Subject: games-strategy/hedgewars: Add upstream patch to build w/ Qt5 See also: https://issues.hedgewars.org/show_bug.cgi?id=159 https://hg.hedgewars.org/hedgewars/log?rev=branch(qt5transition) Bug: https://bugs.gentoo.org/645504 Package-Manager: Portage-2.3.24, Repoman-2.3.6 --- .../hedgewars/files/hedgewars-0.9.23-qt5-1.patch | 87 ++++ .../hedgewars/files/hedgewars-0.9.23-qt5-2.patch | 477 +++++++++++++++++++++ .../hedgewars/hedgewars-0.9.23-r1.ebuild | 92 ++++ 3 files changed, 656 insertions(+) create mode 100644 games-strategy/hedgewars/files/hedgewars-0.9.23-qt5-1.patch create mode 100644 games-strategy/hedgewars/files/hedgewars-0.9.23-qt5-2.patch create mode 100644 games-strategy/hedgewars/hedgewars-0.9.23-r1.ebuild (limited to 'games-strategy/hedgewars') diff --git a/games-strategy/hedgewars/files/hedgewars-0.9.23-qt5-1.patch b/games-strategy/hedgewars/files/hedgewars-0.9.23-qt5-1.patch new file mode 100644 index 00000000000..ec96bd8ef45 --- /dev/null +++ b/games-strategy/hedgewars/files/hedgewars-0.9.23-qt5-1.patch @@ -0,0 +1,87 @@ + +# HG changeset patch +# User unc0rr +# Date 1516824334 -3600 +# Node ID 8869b5256720f0378bf9d5edc68ecb7e1f376039 +# Parent 856570ddd409bec11645c90b5a92fb79c5f2a4e1 +Configure for Qt5 + +diff -r 856570ddd409 -r 8869b5256720 QTfrontend/CMakeLists.txt +--- a/QTfrontend/CMakeLists.txt Mon Jan 15 12:15:56 2018 -0500 ++++ b/QTfrontend/CMakeLists.txt Wed Jan 24 21:05:34 2018 +0100 +@@ -1,24 +1,6 @@ +-# Configure for Qt4 +-set(QT_MIN_VERSION "4.7.0") +-include(CheckLibraryExists) ++find_package(Qt5 COMPONENTS Core Gui Network Svg Xml OpenGL) + +-set(QT_USE_QTCORE TRUE) +-set(QT_USE_QTGUI TRUE) +-set(QT_USE_QTNETWORK TRUE) +-set(QT_USE_QTSVG FALSE) +-set(QT_USE_QTXML FALSE) +-set(QT_USE_QTOPENGL FALSE) +-set(QT_USE_QTMAIN TRUE) +- +-find_package(Qt4 REQUIRED) +-include(${QT_USE_FILE}) +- +-# https://bugreports.qt-project.org/browse/QTBUG-17333 +-if(APPLE AND +- ${QTVERSION} VERSION_GREATER "4.7.0" AND +- ${QTVERSION} VERSION_LESS "4.7.4") +- message(FATAL_ERROR "This version of Qt is known *not* to work, please update or use a lower version") +-endif() ++include(CheckLibraryExists) + + find_package(SDL2 REQUIRED) + find_package(SDL2_mixer 2 REQUIRED) #audio in SDLInteraction +@@ -159,9 +141,9 @@ + endif() + endif() + +-qt4_add_resources(hwfr_rez_src ${hwfr_rez}) ++qt5_add_resources(hwfr_rez_src ${hwfr_rez}) + +-qt4_wrap_cpp(hwfr_moc_srcs ${hwfr_moc_hdrs}) ++qt5_wrap_cpp(hwfr_moc_srcs ${hwfr_moc_hdrs}) + + + if(APPLE) +@@ -198,14 +180,14 @@ + + list(APPEND HW_LINK_LIBS + physfs physlayer +- ${QT_LIBRARIES} ++ Qt5::Core Qt5::Gui Qt5::Network Qt5::Svg Qt5::Xml Qt5::OpenGL + ) + + list(APPEND HW_LINK_LIBS + ${SDL2_LIBRARY} + ${SDL2_MIXER_LIBRARIES} + ) +- ++ + if(WIN32 AND NOT UNIX) + if(NOT SDL2_LIBRARY) + list(APPEND HW_LINK_LIBS SDL2) +diff -r 856570ddd409 -r 8869b5256720 share/hedgewars/Data/Locale/CMakeLists.txt +--- a/share/hedgewars/Data/Locale/CMakeLists.txt Mon Jan 15 12:15:56 2018 -0500 ++++ b/share/hedgewars/Data/Locale/CMakeLists.txt Wed Jan 24 21:05:34 2018 +0100 +@@ -1,5 +1,4 @@ +-find_package(Qt4 REQUIRED) +-include(${QT_USE_FILE}) ++find_package(Qt5 COMPONENTS LinguistTools) + + file(GLOB txttrans2 ??.txt) + file(GLOB txttrans5 ?????.txt) +@@ -9,7 +8,7 @@ + file(GLOB campaignfiles campaigns_*.txt) + file(GLOB tipfiles tips_*.xml) + +-QT4_ADD_TRANSLATION(QM ${tsfiles}) ++QT5_ADD_TRANSLATION(QM ${tsfiles}) + + add_custom_target (release-translation ALL + DEPENDS ${QM} + diff --git a/games-strategy/hedgewars/files/hedgewars-0.9.23-qt5-2.patch b/games-strategy/hedgewars/files/hedgewars-0.9.23-qt5-2.patch new file mode 100644 index 00000000000..eb4e465f009 --- /dev/null +++ b/games-strategy/hedgewars/files/hedgewars-0.9.23-qt5-2.patch @@ -0,0 +1,477 @@ + +# HG changeset patch +# User unc0rr +# Date 1516828810 -3600 +# Node ID fc47fc4af6bd6f399035923453cd85c8f50146f7 +# Parent 8869b5256720f0378bf9d5edc68ecb7e1f376039 +Finish porting. Seems to work, but no thorough testing has been performed + +diff -r 8869b5256720 -r fc47fc4af6bd QTfrontend/CMakeLists.txt +--- a/QTfrontend/CMakeLists.txt Wed Jan 24 21:05:34 2018 +0100 ++++ b/QTfrontend/CMakeLists.txt Wed Jan 24 22:20:10 2018 +0100 +@@ -1,5 +1,7 @@ + find_package(Qt5 COMPONENTS Core Gui Network Svg Xml OpenGL) + ++include_directories(${Qt5Core_PRIVATE_INCLUDE_DIRS}) ++ + include(CheckLibraryExists) + + find_package(SDL2 REQUIRED) +diff -r 8869b5256720 -r fc47fc4af6bd QTfrontend/main.cpp +--- a/QTfrontend/main.cpp Wed Jan 24 21:05:34 2018 +0100 ++++ b/QTfrontend/main.cpp Wed Jan 24 22:20:10 2018 +0100 +@@ -20,7 +20,6 @@ + + #include + #include +-#include + #include + #include + #include +@@ -252,7 +251,7 @@ + splash.show(); + #endif + +- app.setStyle(new QPlastiqueStyle()); ++ //app.setStyle(new QPlastiqueStyle()); + + QDateTime now = QDateTime::currentDateTime(); + srand(now.toTime_t()); +@@ -332,7 +331,7 @@ + + // Fallback to current input locale if "C" locale is returned + if(cc == "C") +- cc = HWApplication::keyboardInputLocale().name(); ++ cc = HWApplication::inputMethod()->locale().name(); + } + + // Load locale files into translators +diff -r 8869b5256720 -r fc47fc4af6bd QTfrontend/model/ammoSchemeModel.cpp +--- a/QTfrontend/model/ammoSchemeModel.cpp Wed Jan 24 21:05:34 2018 +0100 ++++ b/QTfrontend/model/ammoSchemeModel.cpp Wed Jan 24 22:20:10 2018 +0100 +@@ -569,7 +569,7 @@ + << QVariant() // scriptparam 43 + ; + +- QList construction; ++ QList construction; + construction + << predefSchemesNames[10] // name 0 + << QVariant(false) // fortsmode 1 +@@ -617,7 +617,7 @@ + << QVariant() // scriptparam 43 + ; + +- QList hedgeeditor; ++ QList hedgeeditor; + hedgeeditor + << predefSchemesNames[11] // name 0 + << QVariant(false) // fortsmode 1 +@@ -664,9 +664,9 @@ + << QVariant(0) // world edge 42 + << QVariant() // scriptparam 43 + ; +- +- +- ++ ++ ++ + schemes.append(defaultScheme); + schemes.append(proMode); + schemes.append(shoppa); +@@ -896,10 +896,12 @@ + return; + } + ++ beginResetModel(); ++ + cfg[cfg.size()-1] = cfg[cfg.size()-1].mid(1); + + for(int i = 0; i < cfg.size(); ++i) + netScheme[i] = QVariant(cfg[i]); + +- reset(); ++ endResetModel(); + } +diff -r 8869b5256720 -r fc47fc4af6bd QTfrontend/model/playerslistmodel.cpp +--- a/QTfrontend/model/playerslistmodel.cpp Wed Jan 24 21:05:34 2018 +0100 ++++ b/QTfrontend/model/playerslistmodel.cpp Wed Jan 24 22:20:10 2018 +0100 +@@ -309,10 +309,10 @@ + } + + if(index.data(Ignore).toBool()) +- setData(index, Qt::gray, Qt::ForegroundRole); ++ setData(index, QColor(Qt::gray), Qt::ForegroundRole); + else + if(index.data(Friend).toBool()) +- setData(index, Qt::green, Qt::ForegroundRole); ++ setData(index, QColor(Qt::green), Qt::ForegroundRole); + else + setData(index, QBrush(QColor(0xff, 0xcc, 0x00)), Qt::ForegroundRole); + } +diff -r 8869b5256720 -r fc47fc4af6bd QTfrontend/net/hwmap.cpp +--- a/QTfrontend/net/hwmap.cpp Wed Jan 24 21:05:34 2018 +0100 ++++ b/QTfrontend/net/hwmap.cpp Wed Jan 24 22:20:10 2018 +0100 +@@ -79,7 +79,7 @@ + { + quint8 *buf = (quint8*) readbuffer.constData(); + QImage im(buf, 256, 128, QImage::Format_Mono); +- im.setNumColors(2); ++ im.setColorCount(2); + + QPixmap px(QSize(256, 128)); + QPixmap pxres(px.size()); +diff -r 8869b5256720 -r fc47fc4af6bd QTfrontend/net/netudpwidget.cpp +--- a/QTfrontend/net/netudpwidget.cpp Wed Jan 24 21:05:34 2018 +0100 ++++ b/QTfrontend/net/netudpwidget.cpp Wed Jan 24 22:20:10 2018 +0100 +@@ -33,15 +33,19 @@ + + void HWNetUdpModel::updateList() + { +- games.clear(); ++ beginResetModel(); ++ ++ games.clear(); + +- reset(); ++ endResetModel(); + +- pUdpSocket->writeDatagram("hedgewars client", QHostAddress::Broadcast, NETGAME_DEFAULT_PORT); ++ pUdpSocket->writeDatagram("hedgewars client", QHostAddress::Broadcast, NETGAME_DEFAULT_PORT); + } + + void HWNetUdpModel::onClientRead() + { ++ beginResetModel(); ++ + while (pUdpSocket->hasPendingDatagrams()) + { + QByteArray datagram; +@@ -60,7 +64,7 @@ + } + } + +- reset(); ++ endResetModel(); + } + + QVariant HWNetUdpModel::data(const QModelIndex &index, +diff -r 8869b5256720 -r fc47fc4af6bd QTfrontend/net/newnetclient.cpp +--- a/QTfrontend/net/newnetclient.cpp Wed Jan 24 21:05:34 2018 +0100 ++++ b/QTfrontend/net/newnetclient.cpp Wed Jan 24 22:20:10 2018 +0100 +@@ -242,7 +242,7 @@ + void HWNewNet::SendPasswordHash(const QString & hash) + { + // don't send it immediately, only store and check if server asked us for a password +- m_passwordHash = hash.toAscii(); ++ m_passwordHash = hash.toLatin1(); + + maybeSendPassword(); + } +@@ -271,7 +271,7 @@ + if (lst[0] == "ERROR") + { + if (lst.size() == 2) +- emit Error(HWApplication::translate("server", lst[1].toAscii().constData())); ++ emit Error(HWApplication::translate("server", lst[1].toLatin1().constData())); + else + emit Error("Unknown error"); + return; +@@ -280,7 +280,7 @@ + if (lst[0] == "WARNING") + { + if (lst.size() == 2) +- emit Warning(HWApplication::translate("server", lst[1].toAscii().constData())); ++ emit Warning(HWApplication::translate("server", lst[1].toLatin1().constData())); + else + emit Warning("Unknown warning"); + return; +@@ -447,7 +447,7 @@ + while(flags.size() > 1) + { + flags.remove(0, 1); +- char c = flags[0].toAscii(); ++ char c = flags[0].toLatin1(); + bool inRoom = (netClientState == InRoom || netClientState == InGame); + + switch(c) +@@ -673,7 +673,7 @@ + } + m_game_connected = false; + Disconnect(); +- emit disconnected(HWApplication::translate("server", lst[1].toAscii().constData())); ++ emit disconnected(HWApplication::translate("server", lst[1].toLatin1().constData())); + return; + } + +@@ -727,7 +727,7 @@ + } + for(int i = 1; i < lst.size(); ++i) + { +- QByteArray em = QByteArray::fromBase64(lst[i].toAscii()); ++ QByteArray em = QByteArray::fromBase64(lst[i].toLatin1()); + emit FromNet(em); + } + return; +@@ -1155,18 +1155,18 @@ + return; + + QString hash = QCryptographicHash::hash( +- m_clientSalt.toAscii() +- .append(m_serverSalt.toAscii()) ++ m_clientSalt.toLatin1() ++ .append(m_serverSalt.toLatin1()) + .append(m_passwordHash) +- .append(cProtoVer->toAscii()) ++ .append(cProtoVer->toLatin1()) + .append("!hedgewars") + , QCryptographicHash::Sha1).toHex(); + + m_serverHash = QCryptographicHash::hash( +- m_serverSalt.toAscii() +- .append(m_clientSalt.toAscii()) ++ m_serverSalt.toLatin1() ++ .append(m_clientSalt.toLatin1()) + .append(m_passwordHash) +- .append(cProtoVer->toAscii()) ++ .append(cProtoVer->toLatin1()) + .append("!hedgewars") + , QCryptographicHash::Sha1).toHex(); + +diff -r 8869b5256720 -r fc47fc4af6bd QTfrontend/net/proto.h +--- a/QTfrontend/net/proto.h Wed Jan 24 21:05:34 2018 +0100 ++++ b/QTfrontend/net/proto.h Wed Jan 24 22:20:10 2018 +0100 +@@ -22,7 +22,7 @@ + #include + #include + #include +- ++#include + + class HWProto : public QObject + { +diff -r 8869b5256720 -r fc47fc4af6bd QTfrontend/ui/dialog/upload_video.cpp +--- a/QTfrontend/ui/dialog/upload_video.cpp Wed Jan 24 21:05:34 2018 +0100 ++++ b/QTfrontend/ui/dialog/upload_video.cpp Wed Jan 24 22:20:10 2018 +0100 +@@ -38,7 +38,7 @@ + + // User-agent string used in http requests. + // Don't make it a global varibale - crash on linux because of cVersionString +-#define USER_AGENT ("Hedgewars-QtFrontend/" + *cVersionString).toAscii() ++#define USER_AGENT ("Hedgewars-QtFrontend/" + *cVersionString).toLatin1() + + // This is developer key obtained from http://code.google.com/apis/youtube/dashboard/ + // If you are reusing this code outside Hedgewars, don't use this developer key, +@@ -193,7 +193,7 @@ + + QString account(QUrl::toPercentEncoding(leAccount->text())); + QString pass(QUrl::toPercentEncoding(lePassword->text())); +- QByteArray data = QString("Email=%1&Passwd=%2&service=youtube&source=Hedgewars").arg(account).arg(pass).toAscii(); ++ QByteArray data = QString("Email=%1&Passwd=%2&service=youtube&source=Hedgewars").arg(account).arg(pass).toUtf8(); + + QNetworkReply *reply = netManager->post(request, data); + connect(reply, SIGNAL(finished()), this, SLOT(authFinished())); +@@ -246,7 +246,7 @@ + return; + } + +- QByteArray auth = ("GoogleLogin auth=" + authToken).toAscii(); ++ QByteArray auth = ("GoogleLogin auth=" + authToken).toLatin1(); + + // We have authenticated, now we can send metadata and start upload + // Documentation is here: https://developers.google.com/youtube/2.0/developers_guide_protocol_resumable_uploads#Resumable_uploads +diff -r 8869b5256720 -r fc47fc4af6bd QTfrontend/ui/page/pageadmin.cpp +--- a/QTfrontend/ui/page/pageadmin.cpp Wed Jan 24 21:05:34 2018 +0100 ++++ b/QTfrontend/ui/page/pageadmin.cpp Wed Jan 24 22:20:10 2018 +0100 +@@ -98,7 +98,7 @@ + << tr("Expiration") + << tr("Reason") + ); +- twBans->horizontalHeader()->setResizeMode(2, QHeaderView::Stretch); ++ twBans->horizontalHeader()->setSectionResizeMode(2, QHeaderView::Stretch); + twBans->setEditTriggers(QAbstractItemView::NoEditTriggers); + twBans->setSelectionBehavior(QAbstractItemView::SelectRows); + twBans->setSelectionMode(QAbstractItemView::SingleSelection); +diff -r 8869b5256720 -r fc47fc4af6bd QTfrontend/ui/page/pagenet.cpp +--- a/QTfrontend/ui/page/pagenet.cpp Wed Jan 24 21:05:34 2018 +0100 ++++ b/QTfrontend/ui/page/pagenet.cpp Wed Jan 24 22:20:10 2018 +0100 +@@ -99,7 +99,7 @@ + { + tvServersList->setModel(new HWNetUdpModel(tvServersList)); + +- tvServersList->horizontalHeader()->setResizeMode(0, QHeaderView::Stretch); ++ tvServersList->horizontalHeader()->setSectionResizeMode(0, QHeaderView::Stretch); + + static_cast(tvServersList->model())->updateList(); + +diff -r 8869b5256720 -r fc47fc4af6bd QTfrontend/ui/page/pageroomslist.cpp +--- a/QTfrontend/ui/page/pageroomslist.cpp Wed Jan 24 21:05:34 2018 +0100 ++++ b/QTfrontend/ui/page/pageroomslist.cpp Wed Jan 24 22:20:10 2018 +0100 +@@ -154,7 +154,7 @@ + roomsList = new RoomTableView(this); + roomsList->setSelectionBehavior(QAbstractItemView::SelectRows); + roomsList->verticalHeader()->setVisible(false); +- roomsList->horizontalHeader()->setResizeMode(QHeaderView::Interactive); ++ roomsList->horizontalHeader()->setSectionResizeMode(QHeaderView::Interactive); + roomsList->setAlternatingRowColors(true); + roomsList->setShowGrid(false); + roomsList->setSelectionMode(QAbstractItemView::SingleSelection); +@@ -587,7 +587,7 @@ + + h->setSortIndicatorShown(true); + h->setSortIndicator(RoomsListModel::StateColumn, Qt::AscendingOrder); +- h->setResizeMode(RoomsListModel::NameColumn, QHeaderView::Stretch); ++ h->setSectionResizeMode(RoomsListModel::NameColumn, QHeaderView::Stretch); + + if (!restoreHeaderState()) + { +diff -r 8869b5256720 -r fc47fc4af6bd QTfrontend/ui/page/pagevideos.cpp +--- a/QTfrontend/ui/page/pagevideos.cpp Wed Jan 24 21:05:34 2018 +0100 ++++ b/QTfrontend/ui/page/pagevideos.cpp Wed Jan 24 22:20:10 2018 +0100 +@@ -133,8 +133,8 @@ + filesTable->setMinimumWidth(400); + + QHeaderView * header = filesTable->horizontalHeader(); +- header->setResizeMode(vcName, QHeaderView::ResizeToContents); +- header->setResizeMode(vcSize, QHeaderView::Fixed); ++ header->setSectionResizeMode(vcName, QHeaderView::ResizeToContents); ++ header->setSectionResizeMode(vcSize, QHeaderView::Fixed); + header->resizeSection(vcSize, 100); + header->setStretchLastSection(true); + +@@ -851,7 +851,7 @@ + + static QString unprotectPass(QString str) + { +- QByteArray array = QByteArray::fromBase64(str.toAscii()); ++ QByteArray array = QByteArray::fromBase64(str.toLatin1()); + for (int i = 0; i < array.size(); i++) + array[i] = array[i] ^ 0xC4 ^ i; + return QString::fromUtf8(array); +diff -r 8869b5256720 -r fc47fc4af6bd QTfrontend/ui/widget/about.cpp +--- a/QTfrontend/ui/widget/about.cpp Wed Jan 24 21:05:34 2018 +0100 ++++ b/QTfrontend/ui/widget/about.cpp Wed Jan 24 22:20:10 2018 +0100 +@@ -26,6 +26,7 @@ + #include + #include + #include ++#include + #include "hwconsts.h" + #include "SDLInteraction.h" + #include "SDL.h" +diff -r 8869b5256720 -r fc47fc4af6bd QTfrontend/ui/widget/chatwidget.cpp +--- a/QTfrontend/ui/widget/chatwidget.cpp Wed Jan 24 21:05:34 2018 +0100 ++++ b/QTfrontend/ui/widget/chatwidget.cpp Wed Jan 24 22:20:10 2018 +0100 +@@ -32,6 +32,7 @@ + #include + #include + #include ++#include + + #include "DataManager.h" + #include "hwconsts.h" +@@ -312,7 +313,7 @@ + else if (link.scheme() == "hwnick") + { + // decode nick +- QString nick = QString::fromUtf8(QByteArray::fromBase64(link.encodedQuery())); ++ QString nick = QString::fromUtf8(QByteArray::fromBase64(link.query(QUrl::FullyDecoded).toLatin1())); + QModelIndexList mil = chatNicks->model()->match(chatNicks->model()->index(0, 0), Qt::DisplayRole, nick); + + bool isOffline = (mil.size() < 1); +@@ -374,10 +375,10 @@ + { + if (nickname != m_userNick) + return QString("%2").arg( +- QString(nickname.toUtf8().toBase64())).arg(Qt::escape(nickname)); ++ QString(nickname.toUtf8().toBase64())).arg(nickname.toHtmlEscaped()); + + // unlinked nick (if own one) +- return QString("%1").arg(Qt::escape(nickname)); ++ return QString("%1").arg(nickname.toHtmlEscaped()); + } + + const QRegExp HWChatWidget::URLREGEXP = QRegExp("(http(s)?://)?(www\\.)?((([^/:?&#]+\\.)?hedgewars\\.org|code\\.google\\.com|googlecode\\.com|hh\\.unit22\\.org)(/[^ ]*)?)"); +@@ -399,7 +400,7 @@ + + QString HWChatWidget::messageToHTML(const QString & message) + { +- QString formattedStr = Qt::escape(message); ++ QString formattedStr = message.toHtmlEscaped(); + // link some urls + formattedStr = formattedStr.replace(URLREGEXP, "\\4"); + return formattedStr; +@@ -606,9 +607,9 @@ + { + addLine("msg_PlayerInfo", QString(" >>> %1 - %2 %3 %4") + .arg(linkedNick(nick)) +- .arg(Qt::escape(ip == "[]"?"":ip)) +- .arg(Qt::escape(version)) +- .arg(Qt::escape(roomInfo)) ++ .arg(QString(ip == "[]"?"":ip).toHtmlEscaped()) ++ .arg(version.toHtmlEscaped()) ++ .arg(roomInfo.toHtmlEscaped()) + ); + } + +diff -r 8869b5256720 -r fc47fc4af6bd QTfrontend/ui/widget/feedbackdialog.cpp +--- a/QTfrontend/ui/widget/feedbackdialog.cpp Wed Jan 24 21:05:34 2018 +0100 ++++ b/QTfrontend/ui/widget/feedbackdialog.cpp Wed Jan 24 22:20:10 2018 +0100 +@@ -20,7 +20,7 @@ + #include + #include + #include +-#include ++#include + #include + #include + #include +@@ -474,7 +474,7 @@ + this, SLOT(finishedSlot(QNetworkReply*))); + + QNetworkRequest header(QUrl("https://hedgewars.org/feedback/?submit")); +- header.setRawHeader("Content-Length", QString::number(body.size()).toAscii()); ++ header.setRawHeader("Content-Length", QString::number(body.size()).toLatin1()); + header.setRawHeader("Content-Type", "application/x-www-form-urlencoded"); + + nam->post(header, body); +diff -r 8869b5256720 -r fc47fc4af6bd QTfrontend/ui/widget/keybinder.cpp +--- a/QTfrontend/ui/widget/keybinder.cpp Wed Jan 24 21:05:34 2018 +0100 ++++ b/QTfrontend/ui/widget/keybinder.cpp Wed Jan 24 22:20:10 2018 +0100 +@@ -154,7 +154,7 @@ + curTable = new QTableWidget(0, 2); + curTable->verticalHeader()->setVisible(false); + curTable->horizontalHeader()->setVisible(false); +- curTable->horizontalHeader()->setResizeMode(QHeaderView::Stretch); ++ curTable->horizontalHeader()->setSectionResizeMode(QHeaderView::Stretch); + curTable->verticalHeader()->setDefaultSectionSize(rowHeight); + curTable->setShowGrid(false); + curTable->setStyleSheet("QTableWidget { border: none; } "); +diff -r 8869b5256720 -r fc47fc4af6bd QTfrontend/ui/widget/mapContainer.cpp +--- a/QTfrontend/ui/widget/mapContainer.cpp Wed Jan 24 21:05:34 2018 +0100 ++++ b/QTfrontend/ui/widget/mapContainer.cpp Wed Jan 24 22:20:10 2018 +0100 +@@ -984,7 +984,7 @@ + { + m_theme = selectedTheme = current.data(ThemeModel::ActualNameRole).toString(); + m_themeID = current.row(); +- QIcon icon = qVariantValue(current.data(Qt::DecorationRole)); ++ QIcon icon = current.data(Qt::DecorationRole).value(); + //QSize iconSize = icon.actualSize(QSize(65535, 65535)); + //btnTheme->setFixedHeight(64); + //btnTheme->setIconSize(iconSize); +diff -r 8869b5256720 -r fc47fc4af6bd QTfrontend/util/FileEngine.h +--- a/QTfrontend/util/FileEngine.h Wed Jan 24 21:05:34 2018 +0100 ++++ b/QTfrontend/util/FileEngine.h Wed Jan 24 22:20:10 2018 +0100 +@@ -1,9 +1,7 @@ + #ifndef _FileEngine_h + #define _FileEngine_h + +-#include +-#include +-#include ++#include + #include + + #include "physfs.h" + diff --git a/games-strategy/hedgewars/hedgewars-0.9.23-r1.ebuild b/games-strategy/hedgewars/hedgewars-0.9.23-r1.ebuild new file mode 100644 index 00000000000..59115e25924 --- /dev/null +++ b/games-strategy/hedgewars/hedgewars-0.9.23-r1.ebuild @@ -0,0 +1,92 @@ +# Copyright 1999-2018 Gentoo Foundation +# Distributed under the terms of the GNU General Public License v2 + +EAPI=6 + +CMAKE_MAKEFILE_GENERATOR=emake +inherit cmake-utils desktop xdg-utils + +MY_P=${PN}-src-${PV} +DEB_PATCH_VER=7 + +DESCRIPTION="A turn-based strategy, artillery, action and comedy game" +HOMEPAGE="https://www.hedgewars.org/" +SRC_URI="https://www.hedgewars.org/download/releases/${MY_P}.tar.bz2 + mirror://debian/pool/main/h/${PN}/${PN}_0.9.22-dfsg-${DEB_PATCH_VER}.debian.tar.xz" + +LICENSE="GPL-2 Apache-2.0 FDL-1.3" +SLOT="0" +KEYWORDS="~amd64 ~x86" +IUSE="libav" + +QA_FLAGS_IGNORED="/usr/bin/hwengine" # pascal sucks +QA_PRESTRIPPED="/usr/bin/hwengine" # pascal sucks + +# qtcore:5= - depends on private header +CDEPEND=" + >=dev-games/physfs-3.0.1 + dev-lang/lua:0= + dev-qt/qtcore:5= + dev-qt/qtgui:5 + dev-qt/qtnetwork:5 + dev-qt/qtwidgets:5 + media-libs/libpng:0= + media-libs/libsdl2:= + media-libs/sdl2-image:= + media-libs/sdl2-mixer:= + media-libs/sdl2-net:= + media-libs/sdl2-ttf:= + sys-libs/zlib:= + libav? ( media-video/libav:= ) + !libav? ( media-video/ffmpeg:= )" +DEPEND="${CDEPEND} + >=dev-lang/fpc-2.4" +RDEPEND="${CDEPEND} + app-arch/xz-utils + >=media-fonts/dejavu-2.28 + media-fonts/wqy-zenhei" + +S="${WORKDIR}"/${MY_P} + +PATCHES=( + "${FILESDIR}"/${PN}-0.9.22-rpath-fix.patch + "${FILESDIR}"/${P}-qt5-{1,2}.patch # bug 645504 +) + +src_configure() { + local mycmakeargs=( + -DMINIMAL_FLAGS=ON + -DDATA_INSTALL_DIR="${EPREFIX}/usr/share/${PN}" + -Dtarget_binary_install_dir="${EPREFIX}/usr/bin" + -Dtarget_library_install_dir="${EPREFIX}/usr/$(get_libdir)" + -DNOSERVER=TRUE + -DCMAKE_VERBOSE_MAKEFILE=TRUE + -DPHYSFS_SYSTEM=ON + # Need to tell the build system where the fonts are located + # as it uses PhysFS' symbolic link protection mode which + # prevents us from symlinking the fonts into the right directory + # https://hg.hedgewars.org/hedgewars/rev/76ad55807c24 + # https://icculus.org/physfs/docs/html/physfs_8h.html#aad451d9b3f46f627a1be8caee2eef9b7 + -DFONTS_DIRS="${EPREFIX}/usr/share/fonts/wqy-zenhei;${EPREFIX}/usr/share/fonts/dejavu" + # upstream sets RPATH that leads to weird breakage + # https://bugzilla.redhat.com/show_bug.cgi?id=1200193 + -DCMAKE_SKIP_RPATH=ON + ) + cmake-utils_src_configure +} + +src_install() { + cmake-utils_src_install + + doicon misc/hedgewars.png + make_desktop_entry ${PN} Hedgewars + doman man/${PN}.6 +} + +pkg_postinst() { + xdg_desktop_database_update +} + +pkg_postrm() { + xdg_desktop_database_update +} -- cgit v1.2.1