More work on the downloader and 1.6 instance creation
This commit is contained in:
		@@ -416,7 +416,7 @@ void MainWindow::onLoginComplete(LoginResponse response)
 | 
			
		||||
{
 | 
			
		||||
	Q_ASSERT_X(m_activeInst != NULL, "onLoginComplete", "no active instance is set");
 | 
			
		||||
	
 | 
			
		||||
	if (!m_activeInst->shouldUpdateGame())
 | 
			
		||||
	if (!m_activeInst->shouldUpdate())
 | 
			
		||||
	{
 | 
			
		||||
		launchInstance(m_activeInst, response);
 | 
			
		||||
	}
 | 
			
		||||
 
 | 
			
		||||
@@ -80,16 +80,7 @@ class LIBMULTIMC_EXPORT Instance : public QObject
 | 
			
		||||
	 * This returns true if shouldForceUpdate game is true or if the intended and 
 | 
			
		||||
	 * current versions don't match.
 | 
			
		||||
	 */
 | 
			
		||||
	Q_PROPERTY(bool shouldUpdateGame READ shouldUpdateGame STORED false)
 | 
			
		||||
	
 | 
			
		||||
	/*!
 | 
			
		||||
	 * Whether or not the game will be forced to update on the next launch.
 | 
			
		||||
	 * If this is set to true, shouldUpdateGame will be true, regardless of whether or not
 | 
			
		||||
	 * the current and intended versions match.
 | 
			
		||||
	 * It should be noted that this is set to false automatically when game updates are run.
 | 
			
		||||
	 */
 | 
			
		||||
	Q_PROPERTY(bool shouldForceUpdateGame READ shouldForceUpdateGame WRITE setShouldForceUpdateGame)
 | 
			
		||||
	
 | 
			
		||||
	Q_PROPERTY(bool shouldUpdate READ shouldUpdate WRITE setShouldUpdate)
 | 
			
		||||
	
 | 
			
		||||
	/*!
 | 
			
		||||
	 * The instance's current version.
 | 
			
		||||
@@ -236,13 +227,16 @@ public:
 | 
			
		||||
	virtual QString intendedVersion() const { return settings().get("IntendedJarVersion").toString(); }
 | 
			
		||||
	virtual void setIntendedVersion(QString val) { settings().set("IntendedJarVersion", val); }
 | 
			
		||||
	
 | 
			
		||||
	virtual bool shouldUpdateGame() const 
 | 
			
		||||
	{ return shouldForceUpdateGame() || intendedVersion() != currentVersion(); }
 | 
			
		||||
	
 | 
			
		||||
	virtual bool shouldForceUpdateGame() const { return settings().get("ShouldForceUpdate").toBool(); }
 | 
			
		||||
	virtual void setShouldForceUpdateGame(bool val) { settings().set("ShouldForceUpdate", val); }
 | 
			
		||||
	
 | 
			
		||||
	
 | 
			
		||||
	virtual bool shouldUpdate() const 
 | 
			
		||||
	{
 | 
			
		||||
		QVariant var = settings().get("ShouldUpdate");
 | 
			
		||||
		if(!var.isValid() || var.toBool() == false)
 | 
			
		||||
		{
 | 
			
		||||
			return intendedVersion() != currentVersion();
 | 
			
		||||
		}
 | 
			
		||||
		return true;
 | 
			
		||||
	}
 | 
			
		||||
	virtual void setShouldUpdate(bool val) { settings().set("ShouldUpdate", val); }
 | 
			
		||||
 | 
			
		||||
	//// Timestamps ////
 | 
			
		||||
	
 | 
			
		||||
 
 | 
			
		||||
@@ -112,6 +112,52 @@ void GameUpdateTask::versionFileFinished()
 | 
			
		||||
		getLegacyJar();
 | 
			
		||||
		return;
 | 
			
		||||
	}
 | 
			
		||||
	/*
 | 
			
		||||
	// Iterate through the list.
 | 
			
		||||
	QJsonObject groupList = root.value("libraries").toObject();
 | 
			
		||||
	
 | 
			
		||||
	for (QJsonObject::iterator iter = groupList.begin(); 
 | 
			
		||||
			iter != groupList.end(); iter++)
 | 
			
		||||
	{
 | 
			
		||||
		QString groupName = iter.key();
 | 
			
		||||
		
 | 
			
		||||
		// If not an object, complain and skip to the next one.
 | 
			
		||||
		if (!iter.value().isObject())
 | 
			
		||||
		{
 | 
			
		||||
			qWarning(QString("Group '%1' in the group list should "
 | 
			
		||||
								"be an object.").arg(groupName).toUtf8());
 | 
			
		||||
			continue;
 | 
			
		||||
		}
 | 
			
		||||
		
 | 
			
		||||
		QJsonObject groupObj = iter.value().toObject();
 | 
			
		||||
		
 | 
			
		||||
		// Create the group object.
 | 
			
		||||
		InstanceGroup *group = new InstanceGroup(groupName, this);
 | 
			
		||||
		groups.push_back(group);
 | 
			
		||||
		
 | 
			
		||||
		// If 'hidden' isn't a bool value, just assume it's false.
 | 
			
		||||
		if (groupObj.value("hidden").isBool() && groupObj.value("hidden").toBool())
 | 
			
		||||
		{
 | 
			
		||||
			group->setHidden(groupObj.value("hidden").toBool());
 | 
			
		||||
		}
 | 
			
		||||
		
 | 
			
		||||
		if (!groupObj.value("instances").isArray())
 | 
			
		||||
		{
 | 
			
		||||
			qWarning(QString("Group '%1' in the group list is invalid. "
 | 
			
		||||
								"It should contain an array "
 | 
			
		||||
								"called 'instances'.").arg(groupName).toUtf8());
 | 
			
		||||
			continue;
 | 
			
		||||
		}
 | 
			
		||||
		
 | 
			
		||||
		// Iterate through the list of instances in the group.
 | 
			
		||||
		QJsonArray instancesArray = groupObj.value("instances").toArray();
 | 
			
		||||
		
 | 
			
		||||
		for (QJsonArray::iterator iter2 = instancesArray.begin(); 
 | 
			
		||||
				iter2 != instancesArray.end(); iter2++)
 | 
			
		||||
		{
 | 
			
		||||
			groupMap[(*iter2).toString()] = groupName;
 | 
			
		||||
		}
 | 
			
		||||
	}*/
 | 
			
		||||
	
 | 
			
		||||
	// save the version file in $instanceId/version.json and versions/$version/$version.json
 | 
			
		||||
	QString version_id = targetVersion->descriptor();
 | 
			
		||||
@@ -148,10 +194,9 @@ void GameUpdateTask::versionFileFinished()
 | 
			
		||||
 | 
			
		||||
void GameUpdateTask::jarlibFinished()
 | 
			
		||||
{
 | 
			
		||||
	m_inst->setCurrentVersion(targetVersion->descriptor());
 | 
			
		||||
	m_inst->setShouldUpdate(false);
 | 
			
		||||
	exit(1);
 | 
			
		||||
	// YAYAYAYAYYAYAAUAYAYYAYYY!!!!
 | 
			
		||||
	// WEE DID IT!
 | 
			
		||||
	// YESSSSS!
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
void GameUpdateTask::jarlibFailed()
 | 
			
		||||
 
 | 
			
		||||
@@ -34,7 +34,7 @@ Instance::Instance(const QString &rootDir, QObject *parent) :
 | 
			
		||||
	settings().registerSetting(new Setting("iconKey", "default"));
 | 
			
		||||
	settings().registerSetting(new Setting("notes", ""));
 | 
			
		||||
	settings().registerSetting(new Setting("NeedsRebuild", true));
 | 
			
		||||
	settings().registerSetting(new Setting("ShouldForceUpdate", false));
 | 
			
		||||
	settings().registerSetting(new Setting("ShouldUpdate", false));
 | 
			
		||||
	settings().registerSetting(new Setting("JarVersion", "Unknown"));
 | 
			
		||||
	settings().registerSetting(new Setting("LwjglVersion", "2.9.0"));
 | 
			
		||||
	settings().registerSetting(new Setting("IntendedJarVersion", ""));
 | 
			
		||||
 
 | 
			
		||||
@@ -49,7 +49,7 @@ bool SettingsObject::registerSetting(Setting *setting)
 | 
			
		||||
	// Connect signals.
 | 
			
		||||
	connectSignals(*setting);
 | 
			
		||||
	
 | 
			
		||||
	qDebug(QString("Registered setting %1.").arg(setting->id()).toUtf8());
 | 
			
		||||
	// qDebug(QString("Registered setting %1.").arg(setting->id()).toUtf8());
 | 
			
		||||
	return true;
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
 
 | 
			
		||||
@@ -40,6 +40,8 @@ public:
 | 
			
		||||
	
 | 
			
		||||
	/// save to file?
 | 
			
		||||
	bool m_save_to_file;
 | 
			
		||||
	/// is the saving file already open?
 | 
			
		||||
	bool m_opened_for_saving;
 | 
			
		||||
	/// if saving to file, use the one specified in this string
 | 
			
		||||
	QString m_target_path;
 | 
			
		||||
	/// this is the output file, if any
 | 
			
		||||
 
 | 
			
		||||
@@ -10,6 +10,7 @@ DownloadJob::DownloadJob ( QUrl url, QString target_path, QString expected_md5 )
 | 
			
		||||
	m_check_md5 = m_expected_md5.size();
 | 
			
		||||
	m_save_to_file = m_target_path.size();
 | 
			
		||||
	m_status = Job_NotStarted;
 | 
			
		||||
	m_opened_for_saving = false;
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
JobPtr DownloadJob::create ( QUrl url, QString target_path, QString expected_md5 )
 | 
			
		||||
@@ -32,36 +33,32 @@ void DownloadJob::start()
 | 
			
		||||
		QString filename = m_target_path;
 | 
			
		||||
		m_output_file.setFileName ( filename );
 | 
			
		||||
		// if there already is a file and md5 checking is in effect and it can be opened
 | 
			
		||||
		if ( m_check_md5 && m_output_file.exists() && m_output_file.open ( QIODevice::ReadOnly ) )
 | 
			
		||||
		if ( m_output_file.exists() && m_output_file.open ( QIODevice::ReadOnly ) )
 | 
			
		||||
		{
 | 
			
		||||
			// check the md5 against the expected one
 | 
			
		||||
			QString hash = QCryptographicHash::hash ( m_output_file.readAll(), QCryptographicHash::Md5 ).toHex().constData();
 | 
			
		||||
			m_output_file.close();
 | 
			
		||||
			// skip this file if they match
 | 
			
		||||
			if ( hash == m_expected_md5 )
 | 
			
		||||
			if ( m_check_md5 && hash == m_expected_md5 )
 | 
			
		||||
			{
 | 
			
		||||
				qDebug() << "Skipping " << m_url.toString() << ": md5 match.";
 | 
			
		||||
				emit finish();
 | 
			
		||||
				return;
 | 
			
		||||
			}
 | 
			
		||||
			else
 | 
			
		||||
			{
 | 
			
		||||
				m_expected_md5 = hash;
 | 
			
		||||
			}
 | 
			
		||||
		}
 | 
			
		||||
		if(!ensurePathExists(filename))
 | 
			
		||||
		{
 | 
			
		||||
			emit fail();
 | 
			
		||||
			return;
 | 
			
		||||
		}
 | 
			
		||||
		
 | 
			
		||||
		if ( !m_output_file.open ( QIODevice::WriteOnly ) )
 | 
			
		||||
		{
 | 
			
		||||
			/*
 | 
			
		||||
			 * Can't open the file... the job failed
 | 
			
		||||
			 */
 | 
			
		||||
			emit fail();
 | 
			
		||||
			return;
 | 
			
		||||
		}
 | 
			
		||||
	}
 | 
			
		||||
	qDebug() << "Downloading " << m_url.toString();
 | 
			
		||||
	QNetworkRequest request ( m_url );
 | 
			
		||||
	request.setRawHeader(QString("If-None-Match").toLatin1(), m_expected_md5.toLatin1()); 
 | 
			
		||||
	QNetworkReply * rep = m_manager->get ( request );
 | 
			
		||||
	m_reply = QSharedPointer<QNetworkReply> ( rep, &QObject::deleteLater );
 | 
			
		||||
	connect ( rep, SIGNAL ( downloadProgress ( qint64,qint64 ) ), SLOT ( downloadProgress ( qint64,qint64 ) ) );
 | 
			
		||||
@@ -122,6 +119,19 @@ void DownloadJob::downloadReadyRead()
 | 
			
		||||
{
 | 
			
		||||
	if( m_save_to_file )
 | 
			
		||||
	{
 | 
			
		||||
		if(!m_opened_for_saving)
 | 
			
		||||
		{
 | 
			
		||||
			if ( !m_output_file.open ( QIODevice::WriteOnly ) )
 | 
			
		||||
			{
 | 
			
		||||
				/*
 | 
			
		||||
				* Can't open the file... the job failed
 | 
			
		||||
				*/
 | 
			
		||||
				m_reply->abort();
 | 
			
		||||
				emit fail();
 | 
			
		||||
				return;
 | 
			
		||||
			}
 | 
			
		||||
			m_opened_for_saving = true;
 | 
			
		||||
		}
 | 
			
		||||
		m_output_file.write ( m_reply->readAll() );
 | 
			
		||||
	}
 | 
			
		||||
}
 | 
			
		||||
 
 | 
			
		||||
		Reference in New Issue
	
	Block a user