Made ByteSynkArray to use shared_ptr
Signed-off-by: Trial97 <alexandru.tripon97@gmail.com>
This commit is contained in:
		| @@ -134,7 +134,7 @@ void Technic::ListModel::performSearch() | ||||
|         ).arg(BuildConfig.TECHNIC_API_BASE_URL, BuildConfig.TECHNIC_API_BUILD, currentSearchTerm); | ||||
|         searchMode = List; | ||||
|     } | ||||
|     netJob->addNetAction(Net::Download::makeByteArray(QUrl(searchUrl), &response)); | ||||
|     netJob->addNetAction(Net::Download::makeByteArray(QUrl(searchUrl), response)); | ||||
|     jobPtr = netJob; | ||||
|     jobPtr->start(); | ||||
|     QObject::connect(netJob.get(), &NetJob::succeeded, this, &ListModel::searchRequestFinished); | ||||
| @@ -146,11 +146,11 @@ void Technic::ListModel::searchRequestFinished() | ||||
|     jobPtr.reset(); | ||||
|  | ||||
|     QJsonParseError parse_error; | ||||
|     QJsonDocument doc = QJsonDocument::fromJson(response, &parse_error); | ||||
|     if(parse_error.error != QJsonParseError::NoError) | ||||
|     { | ||||
|         qWarning() << "Error while parsing JSON response from Technic at " << parse_error.offset << " reason: " << parse_error.errorString(); | ||||
|         qWarning() << response; | ||||
|     QJsonDocument doc = QJsonDocument::fromJson(*response, &parse_error); | ||||
|     if (parse_error.error != QJsonParseError::NoError) { | ||||
|         qWarning() << "Error while parsing JSON response from Technic at " << parse_error.offset | ||||
|                    << " reason: " << parse_error.errorString(); | ||||
|         qWarning() << *response; | ||||
|         return; | ||||
|     } | ||||
|  | ||||
|   | ||||
| @@ -44,33 +44,32 @@ namespace Technic { | ||||
|  | ||||
| typedef std::function<void(QString)> LogoCallback; | ||||
|  | ||||
| class ListModel : public QAbstractListModel | ||||
| { | ||||
| class ListModel : public QAbstractListModel { | ||||
|     Q_OBJECT | ||||
|  | ||||
| public: | ||||
|     ListModel(QObject *parent); | ||||
|    public: | ||||
|     ListModel(QObject* parent); | ||||
|     virtual ~ListModel(); | ||||
|  | ||||
|     virtual QVariant data(const QModelIndex& index, int role) const; | ||||
|     virtual int columnCount(const QModelIndex& parent) const; | ||||
|     virtual int rowCount(const QModelIndex& parent) const; | ||||
|  | ||||
|     void getLogo(const QString &logo, const QString &logoUrl, LogoCallback callback); | ||||
|     void searchWithTerm(const QString & term); | ||||
|     void getLogo(const QString& logo, const QString& logoUrl, LogoCallback callback); | ||||
|     void searchWithTerm(const QString& term); | ||||
|  | ||||
| private slots: | ||||
|    private slots: | ||||
|     void searchRequestFinished(); | ||||
|     void searchRequestFailed(); | ||||
|  | ||||
|     void logoFailed(QString logo); | ||||
|     void logoLoaded(QString logo, QString out); | ||||
|  | ||||
| private: | ||||
|    private: | ||||
|     void performSearch(); | ||||
|     void requestLogo(QString logo, QString url); | ||||
|  | ||||
| private: | ||||
|    private: | ||||
|     QList<Modpack> modpacks; | ||||
|     QStringList m_failedLogos; | ||||
|     QStringList m_loadingLogos; | ||||
| @@ -78,17 +77,13 @@ private: | ||||
|     QMap<QString, LogoCallback> waitingCallbacks; | ||||
|  | ||||
|     QString currentSearchTerm; | ||||
|     enum SearchState { | ||||
|         None, | ||||
|         ResetRequested, | ||||
|         Finished | ||||
|     } searchState = None; | ||||
|     enum SearchState { None, ResetRequested, Finished } searchState = None; | ||||
|     enum SearchMode { | ||||
|         List, | ||||
|         Single, | ||||
|     } searchMode = List; | ||||
|     NetJob::Ptr jobPtr; | ||||
|     QByteArray response; | ||||
|     std::shared_ptr<QByteArray> response = std::make_shared<QByteArray>(); | ||||
| }; | ||||
|  | ||||
| } | ||||
| }  // namespace Technic | ||||
|   | ||||
| @@ -143,7 +143,7 @@ void TechnicPage::suggestCurrent() | ||||
|  | ||||
|     auto netJob = makeShared<NetJob>(QString("Technic::PackMeta(%1)").arg(current.name), APPLICATION->network()); | ||||
|     QString slug = current.slug; | ||||
|     netJob->addNetAction(Net::Download::makeByteArray(QString("%1modpack/%2?build=%3").arg(BuildConfig.TECHNIC_API_BASE_URL, slug, BuildConfig.TECHNIC_API_BUILD), &response)); | ||||
|     netJob->addNetAction(Net::Download::makeByteArray(QString("%1modpack/%2?build=%3").arg(BuildConfig.TECHNIC_API_BASE_URL, slug, BuildConfig.TECHNIC_API_BUILD), response)); | ||||
|     QObject::connect(netJob.get(), &NetJob::succeeded, this, [this, slug] | ||||
|     { | ||||
|         jobPtr.reset(); | ||||
| @@ -154,7 +154,7 @@ void TechnicPage::suggestCurrent() | ||||
|         } | ||||
|  | ||||
|         QJsonParseError parse_error {}; | ||||
|         QJsonDocument doc = QJsonDocument::fromJson(response, &parse_error); | ||||
|         QJsonDocument doc = QJsonDocument::fromJson(*response, &parse_error); | ||||
|         QJsonObject obj = doc.object(); | ||||
|         if(parse_error.error != QJsonParseError::NoError) | ||||
|         { | ||||
| @@ -249,7 +249,7 @@ void TechnicPage::metadataLoaded() | ||||
|  | ||||
|         auto netJob = makeShared<NetJob>(QString("Technic::SolderMeta(%1)").arg(current.name), APPLICATION->network()); | ||||
|         auto url = QString("%1/modpack/%2").arg(current.url, current.slug); | ||||
|         netJob->addNetAction(Net::Download::makeByteArray(QUrl(url), &response)); | ||||
|         netJob->addNetAction(Net::Download::makeByteArray(QUrl(url), response)); | ||||
|  | ||||
|         QObject::connect(netJob.get(), &NetJob::succeeded, this, &TechnicPage::onSolderLoaded); | ||||
|  | ||||
| @@ -291,11 +291,11 @@ void TechnicPage::onSolderLoaded() { | ||||
|  | ||||
|     current.versions.clear(); | ||||
|  | ||||
|     QJsonParseError parse_error {}; | ||||
|     auto doc = QJsonDocument::fromJson(response, &parse_error); | ||||
|     QJsonParseError parse_error{}; | ||||
|     auto doc = QJsonDocument::fromJson(*response, &parse_error); | ||||
|     if (parse_error.error != QJsonParseError::NoError) { | ||||
|         qWarning() << "Error while parsing JSON response from Solder at " << parse_error.offset << " reason: " << parse_error.errorString(); | ||||
|         qWarning() << response; | ||||
|         qWarning() << *response; | ||||
|         fallback(); | ||||
|         return; | ||||
|     } | ||||
| @@ -304,8 +304,7 @@ void TechnicPage::onSolderLoaded() { | ||||
|     TechnicSolder::Pack pack; | ||||
|     try { | ||||
|         TechnicSolder::loadPack(pack, obj); | ||||
|     } | ||||
|     catch (const JSONValidationError& err) { | ||||
|     } catch (const JSONValidationError& err) { | ||||
|         qCritical() << "Couldn't parse Solder pack metadata:" << err.cause(); | ||||
|         fallback(); | ||||
|         return; | ||||
|   | ||||
| @@ -104,5 +104,5 @@ private: | ||||
|     QString selectedVersion; | ||||
|  | ||||
|     NetJob::Ptr jobPtr; | ||||
|     QByteArray response; | ||||
|     std::shared_ptr<QByteArray> response = std::make_shared<QByteArray>(); | ||||
| }; | ||||
|   | ||||
		Reference in New Issue
	
	Block a user
	 Trial97
					Trial97