Working 1.6 modding (currently only forge)

This commit is contained in:
Petr Mrázek
2013-09-22 04:21:36 +02:00
parent c2c7293083
commit ceca6959d2
35 changed files with 996 additions and 673 deletions

View File

@ -1,18 +1,19 @@
#include "OneSixLibrary.h"
#include "OneSixRule.h"
#include "OpSys.h"
#include <QJsonArray>
void OneSixLibrary::finalize()
{
QStringList parts = m_name.split ( ':' );
QStringList parts = m_name.split(':');
QString relative = parts[0];
relative.replace ( '.','/' );
relative.replace('.', '/');
relative += '/' + parts[1] + '/' + parts[2] + '/' + parts[1] + '-' + parts[2];
if ( !m_is_native )
if (!m_is_native)
relative += ".jar";
else
{
if ( m_native_suffixes.contains ( currentSystem ) )
if (m_native_suffixes.contains(currentSystem))
{
relative += "-" + m_native_suffixes[currentSystem] + ".jar";
}
@ -22,30 +23,30 @@ void OneSixLibrary::finalize()
relative += ".jar";
}
}
m_decentname = parts[1];
m_decentversion = parts[2];
m_storage_path = relative;
m_download_path = m_base_url + relative;
if ( m_rules.empty() )
m_download_url = m_base_url + relative;
if (m_rules.empty())
{
m_is_active = true;
}
else
{
RuleAction result = Disallow;
for ( auto rule: m_rules )
for (auto rule : m_rules)
{
RuleAction temp = rule->apply ( this );
if ( temp != Defer )
RuleAction temp = rule->apply(this);
if (temp != Defer)
result = temp;
}
m_is_active = ( result == Allow );
m_is_active = (result == Allow);
}
if ( m_is_native )
if (m_is_native)
{
m_is_active = m_is_active && m_native_suffixes.contains ( currentSystem );
m_is_active = m_is_active && m_native_suffixes.contains(currentSystem);
m_decenttype = "Native";
}
else
@ -54,11 +55,11 @@ void OneSixLibrary::finalize()
}
}
void OneSixLibrary::setName ( QString name )
void OneSixLibrary::setName(QString name)
{
m_name = name;
}
void OneSixLibrary::setBaseUrl ( QString base_url )
void OneSixLibrary::setBaseUrl(QString base_url)
{
m_base_url = base_url;
}
@ -66,12 +67,12 @@ void OneSixLibrary::setIsNative()
{
m_is_native = true;
}
void OneSixLibrary::addNative ( OpSys os, QString suffix )
void OneSixLibrary::addNative(OpSys os, QString suffix)
{
m_is_native = true;
m_native_suffixes[os] = suffix;
}
void OneSixLibrary::setRules ( QList< QSharedPointer< Rule > > rules )
void OneSixLibrary::setRules(QList<QSharedPointer<Rule>> rules)
{
m_rules = rules;
}
@ -83,11 +84,66 @@ bool OneSixLibrary::isNative()
{
return m_is_native;
}
QString OneSixLibrary::downloadPath()
QString OneSixLibrary::downloadUrl()
{
return m_download_path;
if(m_absolute_url.size())
return m_absolute_url;
return m_download_url;
}
QString OneSixLibrary::storagePath()
{
return m_storage_path;
}
void OneSixLibrary::setAbsoluteUrl(QString absolute_url)
{
m_absolute_url = absolute_url;
}
QString OneSixLibrary::absoluteUrl()
{
return m_absolute_url;
}
QJsonObject OneSixLibrary::toJson()
{
QJsonObject libRoot;
libRoot.insert("name", m_name);
if(m_absolute_url.size())
libRoot.insert("MMC-absulute_url", m_absolute_url);
if(m_base_url != "https://s3.amazonaws.com/Minecraft.Download/libraries/")
libRoot.insert("url", m_base_url);
if (isNative() && m_native_suffixes.size())
{
QJsonObject nativeList;
auto iter = m_native_suffixes.begin();
while (iter != m_native_suffixes.end())
{
nativeList.insert(OpSys_toString(iter.key()), iter.value());
iter++;
}
libRoot.insert("natives", nativeList);
}
if (isNative() && extract_excludes.size())
{
QJsonArray excludes;
QJsonObject extract;
for (auto exclude : extract_excludes)
{
excludes.append(exclude);
}
extract.insert("exclude", excludes);
libRoot.insert("extract", extract);
}
if (m_rules.size())
{
QJsonArray allRules;
for (auto &rule : m_rules)
{
QJsonObject ruleObj = rule->toJson();
allRules.append(ruleObj);
}
libRoot.insert("rules", allRules);
}
return libRoot;
}