mirror of
https://github.com/MultiMC/MultiMC5.git
synced 2025-01-15 19:51:31 +00:00
Merge pull request #5365 from arthomnix/feature/neoforged
NOISSUE Add NeoForge support to mrpack importer and exporter
This commit is contained in:
commit
0912669610
@ -1,4 +1,4 @@
|
|||||||
/* Copyright 2013-2021 MultiMC Contributors
|
/* Copyright 2013-2024 MultiMC Contributors
|
||||||
*
|
*
|
||||||
* Licensed under the Apache License, Version 2.0 (the "License");
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
* you may not use this file except in compliance with the License.
|
* you may not use this file except in compliance with the License.
|
||||||
@ -293,7 +293,7 @@ bool mergeOverrides(const QString &fromDir, const QString &toDir) {
|
|||||||
|
|
||||||
void InstanceImportTask::processModrinth() {
|
void InstanceImportTask::processModrinth() {
|
||||||
std::vector<Modrinth::File> files;
|
std::vector<Modrinth::File> files;
|
||||||
QString minecraftVersion, fabricVersion, quiltVersion, forgeVersion;
|
QString minecraftVersion, fabricVersion, quiltVersion, forgeVersion, neoforgeVersion;
|
||||||
try
|
try
|
||||||
{
|
{
|
||||||
QString indexPath = FS::PathCombine(m_stagingPath, "modrinth.index.json");
|
QString indexPath = FS::PathCombine(m_stagingPath, "modrinth.index.json");
|
||||||
@ -392,6 +392,12 @@ void InstanceImportTask::processModrinth() {
|
|||||||
throw JSONValidationError("Duplicate Forge version");
|
throw JSONValidationError("Duplicate Forge version");
|
||||||
forgeVersion = Json::requireValueString(*it, "Forge version");
|
forgeVersion = Json::requireValueString(*it, "Forge version");
|
||||||
}
|
}
|
||||||
|
else if (name == "neoforge")
|
||||||
|
{
|
||||||
|
if (!neoforgeVersion.isEmpty())
|
||||||
|
throw JSONValidationError("Duplicate NeoForge version");
|
||||||
|
neoforgeVersion = Json::requireValueString(*it, "NeoForge version");
|
||||||
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
throw JSONValidationError("Unknown dependency type: " + name);
|
throw JSONValidationError("Unknown dependency type: " + name);
|
||||||
@ -446,6 +452,8 @@ void InstanceImportTask::processModrinth() {
|
|||||||
components->setComponentVersion("org.quiltmc.quilt-loader", quiltVersion, true);
|
components->setComponentVersion("org.quiltmc.quilt-loader", quiltVersion, true);
|
||||||
if (!forgeVersion.isEmpty())
|
if (!forgeVersion.isEmpty())
|
||||||
components->setComponentVersion("net.minecraftforge", forgeVersion, true);
|
components->setComponentVersion("net.minecraftforge", forgeVersion, true);
|
||||||
|
if (!neoforgeVersion.isEmpty())
|
||||||
|
components->setComponentVersion("net.neoforged", neoforgeVersion, true);
|
||||||
if (m_instIcon != "default")
|
if (m_instIcon != "default")
|
||||||
{
|
{
|
||||||
instance.setIconKey(m_instIcon);
|
instance.setIconKey(m_instIcon);
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright 2023 arthomnix
|
* Copyright 2023-2024 arthomnix
|
||||||
*
|
*
|
||||||
* This source is subject to the Microsoft Public License (MS-PL).
|
* This source is subject to the Microsoft Public License (MS-PL).
|
||||||
* Please see the COPYING.md file for more information.
|
* Please see the COPYING.md file for more information.
|
||||||
@ -213,6 +213,9 @@ void InstanceExportTask::lookupSucceeded()
|
|||||||
if (!m_settings.quiltVersion.isEmpty()) {
|
if (!m_settings.quiltVersion.isEmpty()) {
|
||||||
dependencies.insert("quilt-loader", m_settings.quiltVersion);
|
dependencies.insert("quilt-loader", m_settings.quiltVersion);
|
||||||
}
|
}
|
||||||
|
if (!m_settings.neoforgeVersion.isEmpty()) {
|
||||||
|
dependencies.insert("neoforge", m_settings.neoforgeVersion);
|
||||||
|
}
|
||||||
|
|
||||||
indexJson.insert("dependencies", dependencies);
|
indexJson.insert("dependencies", dependencies);
|
||||||
|
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright 2023 arthomnix
|
* Copyright 2023-2024 arthomnix
|
||||||
*
|
*
|
||||||
* This source is subject to the Microsoft Public License (MS-PL).
|
* This source is subject to the Microsoft Public License (MS-PL).
|
||||||
* Please see the COPYING.md file for more information.
|
* Please see the COPYING.md file for more information.
|
||||||
@ -33,6 +33,7 @@ struct ExportSettings
|
|||||||
QString forgeVersion;
|
QString forgeVersion;
|
||||||
QString fabricVersion;
|
QString fabricVersion;
|
||||||
QString quiltVersion;
|
QString quiltVersion;
|
||||||
|
QString neoforgeVersion;
|
||||||
|
|
||||||
QString exportPath;
|
QString exportPath;
|
||||||
};
|
};
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright 2023 arthomnix
|
* Copyright 2023-2024 arthomnix
|
||||||
*
|
*
|
||||||
* This source is subject to the Microsoft Public License (MS-PL).
|
* This source is subject to the Microsoft Public License (MS-PL).
|
||||||
* Please see the COPYING.md file for more information.
|
* Please see the COPYING.md file for more information.
|
||||||
@ -107,6 +107,7 @@ void ModrinthExportDialog::accept()
|
|||||||
settings.forgeVersion = minecraftInstance->getPackProfile()->getComponentVersion("net.minecraftforge");
|
settings.forgeVersion = minecraftInstance->getPackProfile()->getComponentVersion("net.minecraftforge");
|
||||||
settings.fabricVersion = minecraftInstance->getPackProfile()->getComponentVersion("net.fabricmc.fabric-loader");
|
settings.fabricVersion = minecraftInstance->getPackProfile()->getComponentVersion("net.fabricmc.fabric-loader");
|
||||||
settings.quiltVersion = minecraftInstance->getPackProfile()->getComponentVersion("org.quiltmc.quilt-loader");
|
settings.quiltVersion = minecraftInstance->getPackProfile()->getComponentVersion("org.quiltmc.quilt-loader");
|
||||||
|
settings.neoforgeVersion = minecraftInstance->getPackProfile()->getComponentVersion("net.neoforged");
|
||||||
|
|
||||||
settings.exportPath = ui->file->text();
|
settings.exportPath = ui->file->text();
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user