mirror of
https://github.com/IntellectualSites/PlotSquared.git
synced 2024-11-22 05:06:44 +01:00
feat: plot-title flag value should allow single values (#3410)
This commit is contained in:
parent
42bf413528
commit
a003836dbc
@ -29,6 +29,7 @@ import com.plotsquared.core.configuration.caption.TranslatableCaption;
|
|||||||
import com.plotsquared.core.plot.PlotTitle;
|
import com.plotsquared.core.plot.PlotTitle;
|
||||||
import com.plotsquared.core.plot.flag.FlagParseException;
|
import com.plotsquared.core.plot.flag.FlagParseException;
|
||||||
import com.plotsquared.core.plot.flag.PlotFlag;
|
import com.plotsquared.core.plot.flag.PlotFlag;
|
||||||
|
import com.plotsquared.core.util.StringMan;
|
||||||
import org.checkerframework.checker.nullness.qual.NonNull;
|
import org.checkerframework.checker.nullness.qual.NonNull;
|
||||||
|
|
||||||
public class PlotTitleFlag extends PlotFlag<PlotTitle, PlotTitleFlag> {
|
public class PlotTitleFlag extends PlotFlag<PlotTitle, PlotTitleFlag> {
|
||||||
@ -56,17 +57,18 @@ public class PlotTitleFlag extends PlotFlag<PlotTitle, PlotTitleFlag> {
|
|||||||
if (!input.contains("\"")) {
|
if (!input.contains("\"")) {
|
||||||
return new PlotTitleFlag(new PlotTitle(input, ""));
|
return new PlotTitleFlag(new PlotTitle(input, ""));
|
||||||
}
|
}
|
||||||
input = input.substring(input.indexOf("\""));
|
|
||||||
input = input.substring(0, input.lastIndexOf("\"") + 1);
|
var split = StringMan.splitMessage(input);
|
||||||
String[] inputs = input.split("\"");
|
|
||||||
PlotTitle value;
|
if (split.isEmpty() || split.size() > 2) {
|
||||||
if (inputs.length == 2) {
|
|
||||||
value = new PlotTitle(inputs[1], "");
|
|
||||||
} else if (inputs.length > 3) {
|
|
||||||
value = new PlotTitle(inputs[1], inputs[3]);
|
|
||||||
} else {
|
|
||||||
throw new FlagParseException(this, input, TranslatableCaption.of("flags.flag_error_title"));
|
throw new FlagParseException(this, input, TranslatableCaption.of("flags.flag_error_title"));
|
||||||
}
|
}
|
||||||
|
PlotTitle value;
|
||||||
|
if (split.size() == 1) {
|
||||||
|
value = new PlotTitle(split.get(0), "");
|
||||||
|
} else {
|
||||||
|
value = new PlotTitle(split.get(0), split.get(1));
|
||||||
|
}
|
||||||
return new PlotTitleFlag(value);
|
return new PlotTitleFlag(value);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -30,16 +30,21 @@ import com.plotsquared.core.configuration.caption.Caption;
|
|||||||
import org.checkerframework.checker.nullness.qual.NonNull;
|
import org.checkerframework.checker.nullness.qual.NonNull;
|
||||||
|
|
||||||
import java.lang.reflect.Array;
|
import java.lang.reflect.Array;
|
||||||
|
import java.util.ArrayList;
|
||||||
import java.util.Arrays;
|
import java.util.Arrays;
|
||||||
import java.util.Collection;
|
import java.util.Collection;
|
||||||
import java.util.Comparator;
|
import java.util.Comparator;
|
||||||
import java.util.Iterator;
|
import java.util.Iterator;
|
||||||
|
import java.util.List;
|
||||||
import java.util.Map;
|
import java.util.Map;
|
||||||
import java.util.Map.Entry;
|
import java.util.Map.Entry;
|
||||||
import java.util.Set;
|
import java.util.Set;
|
||||||
|
import java.util.regex.Pattern;
|
||||||
|
|
||||||
public class StringMan {
|
public class StringMan {
|
||||||
|
|
||||||
|
private static final Pattern STRING_SPLIT_PATTERN = Pattern.compile("(?<quoted>\"[\\w ]+\")|(?<single>\\w+)");
|
||||||
|
|
||||||
public static String replaceFromMap(String string, Map<String, String> replacements) {
|
public static String replaceFromMap(String string, Map<String, String> replacements) {
|
||||||
StringBuilder sb = new StringBuilder(string);
|
StringBuilder sb = new StringBuilder(string);
|
||||||
int size = string.length();
|
int size = string.length();
|
||||||
@ -320,4 +325,46 @@ public class StringMan {
|
|||||||
return col;
|
return col;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @param message an input string
|
||||||
|
* @return a list of strings
|
||||||
|
* @since TODO
|
||||||
|
*
|
||||||
|
* <table border="1">
|
||||||
|
* <caption>Converts multiple quoted and single strings into a list of strings</caption>
|
||||||
|
* <thead>
|
||||||
|
* <tr>
|
||||||
|
* <th>Input</th>
|
||||||
|
* <th>Output</th>
|
||||||
|
* </tr>
|
||||||
|
* </thead>
|
||||||
|
* <tbody>
|
||||||
|
* <tr>
|
||||||
|
* <td>title "sub title"</td>
|
||||||
|
* <td>["title", "sub title"]</td>
|
||||||
|
* </tr>
|
||||||
|
* <tr>
|
||||||
|
* <td>"a title" subtitle</td>
|
||||||
|
* <td>["a title", "subtitle"]</td>
|
||||||
|
* </tr>
|
||||||
|
* <tr>
|
||||||
|
* <td>"title" "subtitle"</td>
|
||||||
|
* <td>["title", "subtitle"]</td>
|
||||||
|
* </tr>
|
||||||
|
* <tr>
|
||||||
|
* <td>"PlotSquared is going well" the authors "and many contributors"</td>
|
||||||
|
* <td>["PlotSquared is going well", "the", "authors", "and many contributors"]</td>
|
||||||
|
* </tr>
|
||||||
|
* </tbody>
|
||||||
|
* </table>
|
||||||
|
*/
|
||||||
|
public static @NonNull List<String> splitMessage(@NonNull String message) {
|
||||||
|
var matcher = StringMan.STRING_SPLIT_PATTERN.matcher(message);
|
||||||
|
List<String> splitMessages = new ArrayList<>();
|
||||||
|
while (matcher.find()) {
|
||||||
|
splitMessages.add(matcher.group(0).replaceAll("\"", ""));
|
||||||
|
}
|
||||||
|
return splitMessages;
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -25,9 +25,12 @@
|
|||||||
*/
|
*/
|
||||||
package com.plotsquared.core.plot;
|
package com.plotsquared.core.plot;
|
||||||
|
|
||||||
|
import com.plotsquared.core.configuration.caption.TranslatableCaption;
|
||||||
import com.plotsquared.core.database.AbstractDBTest;
|
import com.plotsquared.core.database.AbstractDBTest;
|
||||||
import com.plotsquared.core.database.DBFunc;
|
import com.plotsquared.core.database.DBFunc;
|
||||||
|
import com.plotsquared.core.plot.flag.FlagParseException;
|
||||||
import com.plotsquared.core.plot.flag.PlotFlag;
|
import com.plotsquared.core.plot.flag.PlotFlag;
|
||||||
|
import com.plotsquared.core.plot.flag.implementations.PlotTitleFlag;
|
||||||
import com.plotsquared.core.plot.flag.implementations.UseFlag;
|
import com.plotsquared.core.plot.flag.implementations.UseFlag;
|
||||||
import com.sk89q.worldedit.world.item.ItemType;
|
import com.sk89q.worldedit.world.item.ItemType;
|
||||||
import org.apache.logging.log4j.LogManager;
|
import org.apache.logging.log4j.LogManager;
|
||||||
@ -74,4 +77,62 @@ public class FlagTest {
|
|||||||
Assertions.assertEquals("use", flagName);
|
Assertions.assertEquals("use", flagName);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void shouldSuccessfullyParseTitleFlagWithTitleSingularAndSubTitleEmpty() {
|
||||||
|
Assertions.assertDoesNotThrow(() -> {
|
||||||
|
var title = PlotTitleFlag.TITLE_FLAG_DEFAULT.parse("\"test\" \"\"").getValue();
|
||||||
|
Assertions.assertEquals("test", title.title());
|
||||||
|
Assertions.assertEquals("", title.subtitle());
|
||||||
|
}, "Should not throw a FlagParseException");
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void shouldSuccessfullyParseTitleFlagWithTitleMultipleWordsAndSubTitleEmpty() {
|
||||||
|
Assertions.assertDoesNotThrow(() -> {
|
||||||
|
var title = PlotTitleFlag.TITLE_FLAG_DEFAULT.parse("\"test hello test\" \"\"").getValue();
|
||||||
|
Assertions.assertEquals("test hello test", title.title());
|
||||||
|
Assertions.assertEquals("", title.subtitle());
|
||||||
|
}, "Should not throw a FlagParseException");
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void shouldSuccessfullyParseTitleFlagWithTitleMultipleWordsAndSubTitleMultipleWords() {
|
||||||
|
Assertions.assertDoesNotThrow(() -> {
|
||||||
|
var title = PlotTitleFlag.TITLE_FLAG_DEFAULT.parse("\"test hello test\" \"a very long subtitle\"").getValue();
|
||||||
|
Assertions.assertEquals("test hello test", title.title());
|
||||||
|
Assertions.assertEquals("a very long subtitle", title.subtitle());
|
||||||
|
}, "Should not throw a FlagParseException");
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void shouldSuccessfullyParseTitleFlagWithTitleEmptyAndSubTitleSingleWord() {
|
||||||
|
Assertions.assertDoesNotThrow(() -> {
|
||||||
|
var title = PlotTitleFlag.TITLE_FLAG_DEFAULT.parse("\"\" \"single\"").getValue();
|
||||||
|
Assertions.assertEquals(" ", title.title());
|
||||||
|
Assertions.assertEquals("single", title.subtitle());
|
||||||
|
}, "Should not throw a FlagParseException");
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void shouldExtractTitleWhenASingleDoubleQuoteAtEndOfTitle() {
|
||||||
|
Assertions.assertDoesNotThrow(() -> {
|
||||||
|
var plotTitle = PlotTitleFlag.TITLE_FLAG_DEFAULT.parse("title\"").getValue();
|
||||||
|
Assertions.assertEquals("title", plotTitle.title());
|
||||||
|
Assertions.assertEquals("", plotTitle.subtitle());
|
||||||
|
}, "Should not throw a FlagParseException");
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void shouldThrowFlagParseExceptionWithQuotesGreater4() {
|
||||||
|
var exception = Assertions.assertThrows(
|
||||||
|
FlagParseException.class,
|
||||||
|
() -> PlotTitleFlag.TITLE_FLAG_DEFAULT.parse("\"title\" \"subtitle\" \"more\""),
|
||||||
|
"Needs to throw a FlagParseException"
|
||||||
|
);
|
||||||
|
Assertions.assertTrue(exception.getErrorMessage() instanceof TranslatableCaption);
|
||||||
|
Assertions.assertEquals(
|
||||||
|
"flags.flag_error_title",
|
||||||
|
((TranslatableCaption) exception.getErrorMessage()).getKey()
|
||||||
|
);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
@ -0,0 +1,61 @@
|
|||||||
|
/*
|
||||||
|
* _____ _ _ _____ _
|
||||||
|
* | __ \| | | | / ____| | |
|
||||||
|
* | |__) | | ___ | |_| (___ __ _ _ _ __ _ _ __ ___ __| |
|
||||||
|
* | ___/| |/ _ \| __|\___ \ / _` | | | |/ _` | '__/ _ \/ _` |
|
||||||
|
* | | | | (_) | |_ ____) | (_| | |_| | (_| | | | __/ (_| |
|
||||||
|
* |_| |_|\___/ \__|_____/ \__, |\__,_|\__,_|_| \___|\__,_|
|
||||||
|
* | |
|
||||||
|
* |_|
|
||||||
|
* PlotSquared plot management system for Minecraft
|
||||||
|
* Copyright (C) 2014 - 2022 IntellectualSites
|
||||||
|
*
|
||||||
|
* 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
|
||||||
|
* the Free Software Foundation, either version 3 of the License, or
|
||||||
|
* (at your option) any later version.
|
||||||
|
*
|
||||||
|
* This program 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 General Public License for more details.
|
||||||
|
*
|
||||||
|
* You should have received a copy of the GNU General Public License
|
||||||
|
* along with this program. If not, see <https://www.gnu.org/licenses/>.
|
||||||
|
*/
|
||||||
|
package com.plotsquared.core.util;
|
||||||
|
|
||||||
|
import org.junit.jupiter.api.Assertions;
|
||||||
|
import org.junit.jupiter.api.Test;
|
||||||
|
|
||||||
|
import java.util.List;
|
||||||
|
|
||||||
|
public class StringManTest {
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void ensureThatAllVariationsHasTheExpectedOutcome() {
|
||||||
|
|
||||||
|
List<Message> messages = List.of(
|
||||||
|
new Message("title", List.of("title")),
|
||||||
|
new Message("title \"sub title\"", List.of("title", "sub title")),
|
||||||
|
new Message("\"a title\" subtitle", List.of("a title", "subtitle")),
|
||||||
|
new Message("\"title\" \"subtitle\"", List.of("title", "subtitle"))
|
||||||
|
);
|
||||||
|
|
||||||
|
for (Message message : messages) {
|
||||||
|
var messageList = StringMan.splitMessage(message.input);
|
||||||
|
|
||||||
|
Assertions.assertEquals(message.expected.size(), messageList.size());
|
||||||
|
if (message.expected.size() > 0) {
|
||||||
|
Assertions.assertEquals(message.expected.get(0), messageList.get(0));
|
||||||
|
}
|
||||||
|
if (message.expected.size() > 1) {
|
||||||
|
Assertions.assertEquals(message.expected.get(1), messageList.get(1));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
private record Message(String input, List<String> expected) {
|
||||||
|
|
||||||
|
}
|
||||||
|
}
|
Loading…
Reference in New Issue
Block a user