mirror of
https://github.com/DieReicheErethons/Brewery.git
synced 2025-01-23 21:21:20 +01:00
Implemented distortion override letters
This commit is contained in:
parent
71963232f3
commit
a8d6a78b69
@ -207,7 +207,7 @@ distortCommands:
|
|||||||
# Distort the Text written on a Sign while drunk [false]
|
# Distort the Text written on a Sign while drunk [false]
|
||||||
distortSignText: false
|
distortSignText: false
|
||||||
|
|
||||||
# Enclose a text with these Letters to bypass Chat Distortion (Use "," as Seperator) (list) [- '[,]']
|
# Enclose a text with these Letters to bypass Chat Distortion (Use "," as Separator) (list) [- '[,]']
|
||||||
distortBypass:
|
distortBypass:
|
||||||
- '*,*'
|
- '*,*'
|
||||||
- '[,]'
|
- '[,]'
|
||||||
|
@ -185,7 +185,10 @@ public class P extends JavaPlugin {
|
|||||||
Brew.colorInBrewer = config.getBoolean("colorInBrewer", false);
|
Brew.colorInBrewer = config.getBoolean("colorInBrewer", false);
|
||||||
Words.log = config.getBoolean("logRealChat", false);
|
Words.log = config.getBoolean("logRealChat", false);
|
||||||
Words.commands = config.getStringList("distortCommands");
|
Words.commands = config.getStringList("distortCommands");
|
||||||
Words.doSigns = config.getBoolean("distortSignText");
|
Words.doSigns = config.getBoolean("distortSignText", false);
|
||||||
|
for (String bypass : config.getStringList("distortBypass")) {
|
||||||
|
Words.ignoreText.add(bypass.split(","));
|
||||||
|
}
|
||||||
|
|
||||||
// loading recipes
|
// loading recipes
|
||||||
ConfigurationSection configSection = config.getConfigurationSection("recipes");
|
ConfigurationSection configSection = config.getConfigurationSection("recipes");
|
||||||
|
@ -19,6 +19,7 @@ public class Words {
|
|||||||
|
|
||||||
public static ArrayList<Words> words = new ArrayList<Words>();
|
public static ArrayList<Words> words = new ArrayList<Words>();
|
||||||
public static List<String> commands;
|
public static List<String> commands;
|
||||||
|
public static List<String[]> ignoreText = new ArrayList<String[]>();
|
||||||
public static FileConfiguration config;
|
public static FileConfiguration config;
|
||||||
public static Boolean doSigns;
|
public static Boolean doSigns;
|
||||||
public static Boolean log;
|
public static Boolean log;
|
||||||
@ -91,11 +92,8 @@ public class Words {
|
|||||||
P.p.log(P.p.languageReader.get("Player_TriedToSay", name, chat));
|
P.p.log(P.p.languageReader.get("Player_TriedToSay", name, chat));
|
||||||
}
|
}
|
||||||
String message = chat.substring(command.length() + 1);
|
String message = chat.substring(command.length() + 1);
|
||||||
for (Words word : words) {
|
message = distortMessage(message, bPlayer.getDrunkeness());
|
||||||
if (word.alcohol <= bPlayer.getDrunkeness()) {
|
|
||||||
message = word.distort(message);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
event.setMessage(chat.substring(0, command.length() + 1) + message);
|
event.setMessage(chat.substring(0, command.length() + 1) + message);
|
||||||
waitPlayers.put(name, System.currentTimeMillis());
|
waitPlayers.put(name, System.currentTimeMillis());
|
||||||
return;
|
return;
|
||||||
@ -116,11 +114,8 @@ public class Words {
|
|||||||
int index = 0;
|
int index = 0;
|
||||||
for (String message : event.getLines()) {
|
for (String message : event.getLines()) {
|
||||||
if (message.length() > 1) {
|
if (message.length() > 1) {
|
||||||
for (Words word : words) {
|
message = distortMessage(message, bPlayer.getDrunkeness());
|
||||||
if (word.alcohol <= bPlayer.getDrunkeness()) {
|
|
||||||
message = word.distort(message);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
if (message.length() > 15) {
|
if (message.length() > 15) {
|
||||||
message = message.substring(0, 14);
|
message = message.substring(0, 14);
|
||||||
}
|
}
|
||||||
@ -141,16 +136,56 @@ public class Words {
|
|||||||
if (log) {
|
if (log) {
|
||||||
P.p.log(P.p.languageReader.get("Player_TriedToSay", event.getPlayer().getName(), message));
|
P.p.log(P.p.languageReader.get("Player_TriedToSay", event.getPlayer().getName(), message));
|
||||||
}
|
}
|
||||||
for (Words word : words) {
|
event.setMessage(distortMessage(message, bPlayer.getDrunkeness()));
|
||||||
if (word.alcohol <= bPlayer.getDrunkeness()) {
|
|
||||||
message = word.distort(message);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
event.setMessage(message);
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// distorts a message, ignoring text enclosed in ignoreText letters
|
||||||
|
public static String distortMessage(String message, int drunkeness) {
|
||||||
|
if (!ignoreText.isEmpty()) {
|
||||||
|
for (String[] bypass : ignoreText) {
|
||||||
|
int indexStart = 0;
|
||||||
|
if (!bypass[0].equals("")) {
|
||||||
|
indexStart = message.indexOf(bypass[0]);
|
||||||
|
}
|
||||||
|
int indexEnd = message.length() - 1;
|
||||||
|
if (!bypass[1].equals("")) {
|
||||||
|
indexEnd = message.indexOf(bypass[1], indexStart + 2);
|
||||||
|
}
|
||||||
|
if (indexStart != -1 && indexEnd != -1) {
|
||||||
|
if (indexEnd > indexStart + 1) {
|
||||||
|
String ignoredMessage = message.substring(indexStart, indexEnd);
|
||||||
|
String msg0 = message.substring(0, indexStart);
|
||||||
|
String msg1 = message.substring(indexEnd);
|
||||||
|
|
||||||
|
if (msg0.length() > 1) {
|
||||||
|
msg0 = distortMessage(msg0, drunkeness);
|
||||||
|
}
|
||||||
|
if (msg1.length() > 1) {
|
||||||
|
msg1 = distortMessage(msg1, drunkeness);
|
||||||
|
}
|
||||||
|
|
||||||
|
return msg0 + ignoredMessage + msg1;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return distortString(message, drunkeness);
|
||||||
|
}
|
||||||
|
|
||||||
|
// distorts a message without checking ignoreText letters
|
||||||
|
private static String distortString(String message, int drunkeness) {
|
||||||
|
if (message.length() > 1) {
|
||||||
|
for (Words word : words) {
|
||||||
|
if (word.alcohol <= drunkeness) {
|
||||||
|
message = word.distort(message);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return message;
|
||||||
|
}
|
||||||
|
|
||||||
// replace "percent"% of "from" -> "to" in "words", when the string before
|
// replace "percent"% of "from" -> "to" in "words", when the string before
|
||||||
// each "from" "match"es "pre"
|
// each "from" "match"es "pre"
|
||||||
// Not yet ignoring case :(
|
// Not yet ignoring case :(
|
||||||
|
Loading…
Reference in New Issue
Block a user