2018-04-07 15:48:43 +00:00
|
|
|
/*
|
|
|
|
* Minecraft Forge
|
2018-09-21 09:15:03 +00:00
|
|
|
* Copyright (c) 2016-2018.
|
2018-04-07 15:48:43 +00:00
|
|
|
*
|
|
|
|
* This library is free software; you can redistribute it and/or
|
|
|
|
* modify it under the terms of the GNU Lesser General Public
|
|
|
|
* License as published by the Free Software Foundation version 2.1
|
|
|
|
* of the License.
|
|
|
|
*
|
|
|
|
* This library is distributed in the hope that it will be useful,
|
|
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
|
|
|
* Lesser General Public License for more details.
|
|
|
|
*
|
|
|
|
* You should have received a copy of the GNU Lesser General Public
|
|
|
|
* License along with this library; if not, write to the Free Software
|
|
|
|
* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
|
|
|
|
*/
|
|
|
|
|
|
|
|
package net.minecraftforge.fml.loading;
|
|
|
|
|
2018-06-06 15:37:56 +00:00
|
|
|
import net.minecraftforge.common.ForgeVersion;
|
2018-06-11 01:36:50 +00:00
|
|
|
import net.minecraftforge.fml.language.IModLanguageProvider;
|
2018-04-07 15:48:43 +00:00
|
|
|
import net.minecraftforge.fml.loading.moddiscovery.ModFile;
|
2018-08-27 17:10:07 +00:00
|
|
|
import org.apache.logging.log4j.LogManager;
|
|
|
|
import org.apache.logging.log4j.Logger;
|
2018-10-04 02:47:07 +00:00
|
|
|
import org.apache.maven.artifact.versioning.ArtifactVersion;
|
|
|
|
import org.apache.maven.artifact.versioning.DefaultArtifactVersion;
|
|
|
|
import org.apache.maven.artifact.versioning.VersionRange;
|
2018-04-07 15:48:43 +00:00
|
|
|
|
|
|
|
import java.nio.file.Path;
|
|
|
|
import java.util.ArrayList;
|
|
|
|
import java.util.HashMap;
|
|
|
|
import java.util.List;
|
|
|
|
import java.util.Map;
|
|
|
|
import java.util.ServiceLoader;
|
2018-06-19 18:04:05 +00:00
|
|
|
import java.util.function.Consumer;
|
2018-04-07 15:48:43 +00:00
|
|
|
import java.util.stream.Stream;
|
|
|
|
|
|
|
|
import static net.minecraftforge.fml.Logging.CORE;
|
|
|
|
|
|
|
|
public class LanguageLoadingProvider
|
|
|
|
{
|
2018-08-27 17:10:07 +00:00
|
|
|
private static final Logger LOGGER = LogManager.getLogger();
|
2018-04-07 15:48:43 +00:00
|
|
|
private final List<IModLanguageProvider> languageProviders = new ArrayList<>();
|
|
|
|
private final ServiceLoader<IModLanguageProvider> serviceLoader;
|
2018-06-06 15:37:56 +00:00
|
|
|
private final Map<String, ModLanguageWrapper> languageProviderMap = new HashMap<>();
|
2018-04-07 15:48:43 +00:00
|
|
|
|
2018-06-19 18:04:05 +00:00
|
|
|
public void forEach(final Consumer<IModLanguageProvider> consumer)
|
|
|
|
{
|
|
|
|
languageProviders.forEach(consumer);
|
|
|
|
}
|
|
|
|
|
2018-06-06 15:37:56 +00:00
|
|
|
private static class ModLanguageWrapper {
|
|
|
|
private final IModLanguageProvider modLanguageProvider;
|
|
|
|
private final ArtifactVersion version;
|
|
|
|
|
|
|
|
public ModLanguageWrapper(IModLanguageProvider modLanguageProvider, ArtifactVersion version)
|
|
|
|
{
|
|
|
|
this.modLanguageProvider = modLanguageProvider;
|
|
|
|
this.version = version;
|
|
|
|
}
|
|
|
|
|
|
|
|
public ArtifactVersion getVersion()
|
|
|
|
{
|
|
|
|
return version;
|
|
|
|
}
|
|
|
|
|
|
|
|
public IModLanguageProvider getModLanguageProvider()
|
|
|
|
{
|
|
|
|
return modLanguageProvider;
|
|
|
|
}
|
|
|
|
}
|
2018-04-07 15:48:43 +00:00
|
|
|
LanguageLoadingProvider() {
|
|
|
|
serviceLoader = ServiceLoader.load(IModLanguageProvider.class);
|
|
|
|
serviceLoader.forEach(languageProviders::add);
|
|
|
|
|
|
|
|
languageProviders.forEach(lp -> {
|
|
|
|
final Package pkg = lp.getClass().getPackage();
|
2018-06-06 15:37:56 +00:00
|
|
|
String implementationVersion = pkg.getImplementationVersion();
|
|
|
|
if (implementationVersion == null) {
|
2018-10-04 04:57:08 +00:00
|
|
|
implementationVersion = ForgeVersion.getSpec();
|
2018-06-06 15:37:56 +00:00
|
|
|
}
|
2018-08-27 17:10:07 +00:00
|
|
|
LOGGER.debug(CORE, "Found system classpath language provider {}, version {}", lp.name(), implementationVersion);
|
2018-06-06 15:37:56 +00:00
|
|
|
languageProviderMap.put(lp.name(), new ModLanguageWrapper(lp, new DefaultArtifactVersion(implementationVersion)));
|
2018-04-07 15:48:43 +00:00
|
|
|
});
|
|
|
|
}
|
|
|
|
|
|
|
|
public void addAdditionalLanguages(List<ModFile> modFiles)
|
|
|
|
{
|
|
|
|
if (modFiles==null) return;
|
|
|
|
Stream<Path> langPaths = modFiles.stream().map(ModFile::getFilePath);
|
|
|
|
serviceLoader.reload();
|
|
|
|
}
|
|
|
|
|
2018-06-06 15:37:56 +00:00
|
|
|
public IModLanguageProvider findLanguage(String modLoader, VersionRange modLoaderVersion) {
|
|
|
|
final ModLanguageWrapper mlw = languageProviderMap.get(modLoader);
|
|
|
|
if (mlw == null) {
|
|
|
|
throw new MissingLanguageException("Missing language "+modLoader);
|
|
|
|
}
|
|
|
|
if (!modLoaderVersion.containsVersion(mlw.getVersion())) {
|
|
|
|
throw new MissingLanguageException("Missing language "+ modLoader + " matching range "+modLoaderVersion + " found "+mlw.getVersion());
|
|
|
|
}
|
|
|
|
|
|
|
|
return mlw.getModLanguageProvider();
|
2018-04-07 15:48:43 +00:00
|
|
|
}
|
|
|
|
}
|