X-Git-Url: https://git.pterodactylus.net/?p=Sone.git;a=blobdiff_plain;f=src%2Fmain%2Fjava%2Fnet%2Fpterodactylus%2Fsone%2Ffreenet%2FL10nFilter.java;h=ef6ef98a5c9003b355c925fc569a6f077194c4e4;hp=c8075c51c4de7717e9ccc0c103de1ec9ef54d3c5;hb=179e7da4d8d8a474d0b622d60b5f5d32d6ab4052;hpb=7017646bf42cb265b6df539bb6def40b91d2f968 diff --git a/src/main/java/net/pterodactylus/sone/freenet/L10nFilter.java b/src/main/java/net/pterodactylus/sone/freenet/L10nFilter.java index c8075c5..ef6ef98 100644 --- a/src/main/java/net/pterodactylus/sone/freenet/L10nFilter.java +++ b/src/main/java/net/pterodactylus/sone/freenet/L10nFilter.java @@ -1,5 +1,5 @@ /* - * Sone - L10nFilter.java - Copyright © 2010–2013 David Roden + * Sone - L10nFilter.java - Copyright © 2010–2019 David Roden * * This program is free software: you can redistribute it and/or modify * it under the terms of the GNU General Public License as published by @@ -23,6 +23,8 @@ import java.util.List; import java.util.Locale; import java.util.Map; +import javax.annotation.Nonnull; + import net.pterodactylus.sone.web.WebInterface; import net.pterodactylus.util.template.Filter; import net.pterodactylus.util.template.TemplateContext; @@ -30,8 +32,6 @@ import net.pterodactylus.util.template.TemplateContext; /** * {@link Filter} implementation replaces {@link String} values with their * translated equivalents. - * - * @author David ‘Bombe’ Roden */ public class L10nFilter implements Filter { @@ -53,17 +53,32 @@ public class L10nFilter implements Filter { */ @Override public String format(TemplateContext templateContext, Object data, Map parameters) { - if (parameters.isEmpty()) { - return webInterface.getL10n().getString(String.valueOf(data)); + List parameterValues = getParameters(data, parameters); + String text = getText(data); + if (parameterValues.isEmpty()) { + return webInterface.getL10n().getString(text); + } + return new MessageFormat(webInterface.getL10n().getString(text), new Locale(webInterface.getL10n().getSelectedLanguage().shortCode)).format(parameterValues.toArray()); + } + + @Nonnull + private String getText(Object data) { + return (data instanceof L10nText) ? ((L10nText) data).getText() : String.valueOf(data); + } + + @Nonnull + private List getParameters(Object data, Map parameters) { + if (data instanceof L10nText) { + return ((L10nText) data).getParameters(); } - List parameterValues = new ArrayList(); + List parameterValues = new ArrayList<>(); int parameterIndex = 0; while (parameters.containsKey(String.valueOf(parameterIndex))) { Object value = parameters.get(String.valueOf(parameterIndex)); parameterValues.add(value); ++parameterIndex; } - return new MessageFormat(webInterface.getL10n().getString(String.valueOf(data)), new Locale(webInterface.getL10n().getSelectedLanguage().shortCode)).format(parameterValues.toArray()); + return parameterValues; } }