/* package whatever; // don't place package name! */
import java.util.*;
import java.lang.*;
import java.io.*;
import java.util.HashMap;
import java.util.Map;
import java.util.regex.Matcher;
import java.util.regex.Pattern;
/* Name of the class has to be "Main" only if the class is public. */
class Ideone
{
private static final Pattern STRIP_COLOR_PATTERN
= Pattern.
compile("(?i)" + String.
valueOf('ยง') + "[0-9A-FK-OR]");
private enum ChatColor
{
/**
* Represents black
*/
BLACK('0', 0x00),
/**
* Represents dark blue
*/
DARK_BLUE('1', 0x1),
/**
* Represents dark green
*/
DARK_GREEN('2', 0x2),
/**
* Represents dark blue (aqua)
*/
DARK_AQUA('3', 0x3),
/**
* Represents dark red
*/
DARK_RED('4', 0x4),
/**
* Represents dark purple
*/
DARK_PURPLE('5', 0x5),
/**
* Represents gold
*/
GOLD('6', 0x6),
/**
* Represents gray
*/
GRAY('7', 0x7),
/**
* Represents dark gray
*/
DARK_GRAY('8', 0x8),
/**
* Represents blue
*/
BLUE('9', 0x9),
/**
* Represents green
*/
GREEN('a', 0xA),
/**
* Represents aqua
*/
AQUA('b', 0xB),
/**
* Represents red
*/
RED('c', 0xC),
/**
* Represents light purple
*/
LIGHT_PURPLE('d', 0xD),
/**
* Represents yellow
*/
YELLOW('e', 0xE),
/**
* Represents white
*/
WHITE('f', 0xF),
/**
* Represents magical characters that change around randomly
*/
MAGIC('k', 0x10, true),
/**
* Makes the text bold.
*/
BOLD('l', 0x11, true),
/**
* Makes a line appear through the text.
*/
STRIKETHROUGH('m', 0x12, true),
/**
* Makes the text appear underlined.
*/
UNDERLINE('n', 0x13, true),
/**
* Makes the text italic.
*/
ITALIC('o', 0x14, true),
/**
* Resets all previous chat colors or formats.
*/
RESET('r', 0x15);
/**
* The special character which prefixes all chat colour codes. Use this if
* you need to dynamically convert colour codes from your custom format.
*/
public static final char COLOR_CHAR = '\u00A7';
private static final Pattern STRIP_COLOR_PATTERN
= Pattern.
compile("(?i)" + String.
valueOf(COLOR_CHAR
) + "[0-9A-FK-OR]");
private final int intCode;
private final char code;
private final boolean isFormat;
private final String toString
; private final static Map
<Integer, ChatColor
> BY_ID
= new HashMap
<>(); private final static Map
<Character, ChatColor
> BY_CHAR
= new HashMap
<>();
private ChatColor(char code, int intCode) {
this(code, intCode, false);
}
private ChatColor(char code, int intCode, boolean isFormat) {
this.code = code;
this.intCode = intCode;
this.isFormat = isFormat;
this.
toString = new String(new char[] {COLOR_CHAR, code
}); }
/**
* Gets the char value associated with this color
*
* @return A char value of this color code
*/
public char getChar() {
return code;
}
@Override
return toString;
}
/**
* Checks if this code is a format code as opposed to a color code.
*/
public boolean isFormat() {
return isFormat;
}
/**
* Checks if this code is a color code as opposed to a format code.
*/
public boolean isColor() {
return !isFormat && this != RESET;
}
/**
* Gets the color represented by the specified color code
*
* @param code Code to check
* @return Associative {@link org.bukkit.ChatColor} with the given code,
* or null if it doesn't exist
*/
public static ChatColor getByChar(char code) {
return BY_CHAR.get(code);
}
/**
* Gets the color represented by the specified color code
*
* @param code Code to check
* @return Associative {@link org.bukkit.ChatColor} with the given code,
* or null if it doesn't exist
*/
public static ChatColor getByChar
(String code
) { return BY_CHAR.get(code.charAt(0));
}
/**
* Strips the given message of all color codes
*
* @param input String to strip of color
* @return A copy of the input string, without any coloring
*/
if (input == null) {
return null;
}
return STRIP_COLOR_PATTERN.matcher(input).replaceAll("");
}
/**
* Translates a string using an alternate color code character into a
* string that uses the internal ChatColor.COLOR_CODE color code
* character. The alternate color code character will only be replaced if
* it is immediately followed by 0-9, A-F, a-f, K-O, k-o, R or r.
*
* @param altColorChar The alternate color code character to replace. Ex: &
* @param textToTranslate Text containing the alternate color code character.
* @return Text containing the ChatColor.COLOR_CODE color code character.
*/
public static String translateAlternateColorCodes
(char altColorChar,
String textToTranslate
) { char[] b = textToTranslate.toCharArray();
for (int i = 0; i < b.length - 1; i++) {
if (b[i] == altColorChar && "0123456789AaBbCcDdEeFfKkLlMmNnOoRr".indexOf(b[i+1]) > -1) {
b[i] = ChatColor.COLOR_CHAR;
}
}
}
/**
* Gets the ChatColors used at the end of the given input string.
*
* @param input Input string to retrieve the colors from.
* @return Any remaining ChatColors to pass onto the next line.
*/
int length = input.length();
// Search backwards from the end as it is faster
for (int index = length - 1; index > -1; index--) {
char section = input.charAt(index);
if (section == COLOR_CHAR && index < length - 1) {
char c = input.charAt(index + 1);
ChatColor color = getByChar(c);
if (color != null) {
result = color.toString() + result;
// Once we find a color or reset we can stop searching
if (color.isColor() || color.equals(RESET)) {
break;
}
}
}
}
return result;
}
static {
for (ChatColor color : values()) {
BY_ID.put(color.intCode, color);
BY_CHAR.put(color.code, color);
}
}
}
private interface Executor {
void execute();
}
public static void checkTime(int amount, Executor executor) {
long start
= System.
nanoTime();
for (int i = 0; i < amount; i++)
{
executor.execute();
}
System.
out.
println("Average per call: "+((end
- start
) / 1000000) + "ns"); }
public static String format1
(String input, ChatColor...
formats) {
StringBuilder result = new StringBuilder();
StringBuilder format = new StringBuilder();
for (ChatColor color : formats) format.append(color);
String formatString
= format.
toString();
for (int i = 0; i < input.length(); i ++) {
result.append(input.charAt(i));
if (input.charAt(i) == ChatColor.COLOR_CHAR) {
if (i + 1 < input.length()) {
ChatColor color = ChatColor.getByChar(input.charAt(++i));
if (color != null) {
result.append(color.getChar());
result.append(formatString);
}
}
}
}
result.append(ChatColor.RESET);
return result.toString();
}
public static String format2
(String input, ChatColor...
formats) {
StringBuilder format = new StringBuilder();
for (ChatColor color : formats) format.append(color);
char[] formatString = format.toString().toCharArray();
char[] o = input.toCharArray();
// List of indices where we should inject our format
LinkedList<Integer> indices = new LinkedList<>();
for (int i = 0; i < o.length - 1; i++) {
int j = i + 1;
if (o[i] == ChatColor.COLOR_CHAR && (('0' <= o[j] && o[j] <= '9') || ('a' <= o[j] && o[j] <= 'f') || ('A' <= o[j] && o[j] <= 'F'))) {
indices.add(j + 1);
i++; // Skip this char
}
}
char[] n = new char[o.length + formatString.length * indices.size() + 2];
n[n.length - 2] = ChatColor.COLOR_CHAR;
n[n.length - 1] = 'r';
Iterator<Integer> it = indices.iterator();
int offset = 0;
int previous = 0;
while (it.hasNext()) {
int next = it.next();
System.
arraycopy(o, previous, n, previous
+ offset, next
- previous
); System.
arraycopy(formatString,
0, n, next
+ offset, formatString.
length); previous = next;
offset += formatString.length;
}
System.
arraycopy(o, previous, n, previous
+ offset, o.
length - previous
); }
public static void main
(String[] args
) {
String name
= ChatColor.
RED + "Dragon" + ChatColor.
BLUE + "phase"; ChatColor[] formats = new ChatColor[]{ChatColor.BOLD, ChatColor.UNDERLINE};
System.
out.
println("Format1: " + format1
(name, formats
)); System.
out.
println("Format2: " + format2
(name, formats
)); checkTime(1000000, new Executor() {
public void execute() {
format1(name, formats);
}
});
checkTime(1000000, new Executor() {
public void execute() {
format2(name, formats);
}
});
}
}
/* package whatever; // don't place package name! */

import java.util.*;
import java.lang.*;
import java.io.*;
import java.util.HashMap;
import java.util.Map;
import java.util.regex.Matcher;
import java.util.regex.Pattern;

/* Name of the class has to be "Main" only if the class is public. */
class Ideone
{
	private static final Pattern STRIP_COLOR_PATTERN = Pattern.compile("(?i)" + String.valueOf('§') + "[0-9A-FK-OR]");

    private enum ChatColor
    {
        /**
         * Represents black
         */
        BLACK('0', 0x00),
        /**
         * Represents dark blue
         */
        DARK_BLUE('1', 0x1),
        /**
         * Represents dark green
         */
        DARK_GREEN('2', 0x2),
        /**
         * Represents dark blue (aqua)
         */
        DARK_AQUA('3', 0x3),
        /**
         * Represents dark red
         */
        DARK_RED('4', 0x4),
        /**
         * Represents dark purple
         */
        DARK_PURPLE('5', 0x5),
        /**
         * Represents gold
         */
        GOLD('6', 0x6),
        /**
         * Represents gray
         */
        GRAY('7', 0x7),
        /**
         * Represents dark gray
         */
        DARK_GRAY('8', 0x8),
        /**
         * Represents blue
         */
        BLUE('9', 0x9),
        /**
         * Represents green
         */
        GREEN('a', 0xA),
        /**
         * Represents aqua
         */
        AQUA('b', 0xB),
        /**
         * Represents red
         */
        RED('c', 0xC),
        /**
         * Represents light purple
         */
        LIGHT_PURPLE('d', 0xD),
        /**
         * Represents yellow
         */
        YELLOW('e', 0xE),
        /**
         * Represents white
         */
        WHITE('f', 0xF),
        /**
         * Represents magical characters that change around randomly
         */
        MAGIC('k', 0x10, true),
        /**
         * Makes the text bold.
         */
        BOLD('l', 0x11, true),
        /**
         * Makes a line appear through the text.
         */
        STRIKETHROUGH('m', 0x12, true),
        /**
         * Makes the text appear underlined.
         */
        UNDERLINE('n', 0x13, true),
        /**
         * Makes the text italic.
         */
        ITALIC('o', 0x14, true),
        /**
         * Resets all previous chat colors or formats.
         */
        RESET('r', 0x15);

        /**
         * The special character which prefixes all chat colour codes. Use this if
         * you need to dynamically convert colour codes from your custom format.
         */
        public static final char COLOR_CHAR = '\u00A7';
        private static final Pattern STRIP_COLOR_PATTERN = Pattern.compile("(?i)" + String.valueOf(COLOR_CHAR) + "[0-9A-FK-OR]");

        private final int intCode;
        private final char code;
        private final boolean isFormat;
        private final String toString;
        private final static Map<Integer, ChatColor> BY_ID = new HashMap<>();
        private final static Map<Character, ChatColor> BY_CHAR = new HashMap<>();

        private ChatColor(char code, int intCode) {
            this(code, intCode, false);
        }

        private ChatColor(char code, int intCode, boolean isFormat) {
            this.code = code;
            this.intCode = intCode;
            this.isFormat = isFormat;
            this.toString = new String(new char[] {COLOR_CHAR, code});
        }

        /**
         * Gets the char value associated with this color
         *
         * @return A char value of this color code
         */
        public char getChar() {
            return code;
        }

        @Override
        public String toString() {
            return toString;
        }

        /**
         * Checks if this code is a format code as opposed to a color code.
         */
        public boolean isFormat() {
            return isFormat;
        }

        /**
         * Checks if this code is a color code as opposed to a format code.
         */
        public boolean isColor() {
            return !isFormat && this != RESET;
        }

        /**
         * Gets the color represented by the specified color code
         *
         * @param code Code to check
         * @return Associative {@link org.bukkit.ChatColor} with the given code,
         *     or null if it doesn't exist
         */
        public static ChatColor getByChar(char code) {
            return BY_CHAR.get(code);
        }

        /**
         * Gets the color represented by the specified color code
         *
         * @param code Code to check
         * @return Associative {@link org.bukkit.ChatColor} with the given code,
         *     or null if it doesn't exist
         */
        public static ChatColor getByChar(String code) {
            return BY_CHAR.get(code.charAt(0));
        }

        /**
         * Strips the given message of all color codes
         *
         * @param input String to strip of color
         * @return A copy of the input string, without any coloring
         */
        public static String stripColor(final String input) {
            if (input == null) {
                return null;
            }

            return STRIP_COLOR_PATTERN.matcher(input).replaceAll("");
        }

        /**
         * Translates a string using an alternate color code character into a
         * string that uses the internal ChatColor.COLOR_CODE color code
         * character. The alternate color code character will only be replaced if
         * it is immediately followed by 0-9, A-F, a-f, K-O, k-o, R or r.
         *
         * @param altColorChar The alternate color code character to replace. Ex: &
         * @param textToTranslate Text containing the alternate color code character.
         * @return Text containing the ChatColor.COLOR_CODE color code character.
         */
        public static String translateAlternateColorCodes(char altColorChar, String textToTranslate) {
            char[] b = textToTranslate.toCharArray();
            for (int i = 0; i < b.length - 1; i++) {
                if (b[i] == altColorChar && "0123456789AaBbCcDdEeFfKkLlMmNnOoRr".indexOf(b[i+1]) > -1) {
                    b[i] = ChatColor.COLOR_CHAR;
                    b[i+1] = Character.toLowerCase(b[i+1]);
                }
            }
            return new String(b);
        }

        /**
         * Gets the ChatColors used at the end of the given input string.
         *
         * @param input Input string to retrieve the colors from.
         * @return Any remaining ChatColors to pass onto the next line.
         */
        public static String getLastColors(String input) {
            String result = "";
            int length = input.length();

            // Search backwards from the end as it is faster
            for (int index = length - 1; index > -1; index--) {
                char section = input.charAt(index);
                if (section == COLOR_CHAR && index < length - 1) {
                    char c = input.charAt(index + 1);
                    ChatColor color = getByChar(c);

                    if (color != null) {
                        result = color.toString() + result;

                        // Once we find a color or reset we can stop searching
                        if (color.isColor() || color.equals(RESET)) {
                            break;
                        }
                    }
                }
            }

            return result;
        }

        static {
            for (ChatColor color : values()) {
                BY_ID.put(color.intCode, color);
                BY_CHAR.put(color.code, color);
            }
        }
    }
    
    private interface Executor {
    	void execute();
    }
    
    public static void checkTime(int amount, Executor executor) {
        long start = System.nanoTime();
        
        for (int i = 0; i < amount; i++)
        {
            executor.execute();
        }
        
        long end = System.nanoTime();
        
        System.out.println("Average per call: "+((end - start) / 1000000) + "ns");
    }

    public static String format1(String input, ChatColor...formats)
    {
    	StringBuilder result = new StringBuilder();

        StringBuilder format = new StringBuilder();
        for (ChatColor color : formats) format.append(color);
        String formatString = format.toString();
    	
    	for (int i = 0; i < input.length(); i ++) {
    		result.append(input.charAt(i));
    		
    		if (input.charAt(i) == ChatColor.COLOR_CHAR) {
    			if (i + 1 < input.length()) {
	    			ChatColor color = ChatColor.getByChar(input.charAt(++i));
	    			
	    			if (color != null) {
	    				result.append(color.getChar());
	    				result.append(formatString);
	    			}
    			}
    		}
    	}
    	
    	result.append(ChatColor.RESET);
    	
    	return result.toString();
    }
    
    public static String format2(String input, ChatColor...formats)
    {
    	StringBuilder format = new StringBuilder();
		for (ChatColor color : formats) format.append(color);
		char[] formatString = format.toString().toCharArray();
		char[] o = input.toCharArray();
		// List of indices where we should inject our format
		LinkedList<Integer> indices = new LinkedList<>();
		for (int i = 0; i < o.length - 1; i++) {
		    int j = i + 1;
		    if (o[i] == ChatColor.COLOR_CHAR && (('0' <= o[j] && o[j] <= '9') || ('a' <= o[j] && o[j] <= 'f') || ('A' <= o[j] && o[j] <= 'F'))) {
		        indices.add(j + 1);
		        i++; // Skip this char
		    }
		}
		char[] n = new char[o.length + formatString.length * indices.size() + 2];
		n[n.length - 2] = ChatColor.COLOR_CHAR;
		n[n.length - 1] = 'r';
		Iterator<Integer> it = indices.iterator();
		int offset = 0;
		int previous = 0;
		while (it.hasNext()) {
		    int next = it.next();
		    System.arraycopy(o, previous, n, previous + offset, next - previous);
		    System.arraycopy(formatString, 0, n, next + offset, formatString.length);
		    previous = next;
		    offset += formatString.length;
		}
	    System.arraycopy(o, previous, n, previous + offset, o.length - previous);
		return new String(n);
    }

    public static void main(String[] args)
    {
        String name = ChatColor.RED + "Dragon" + ChatColor.BLUE + "phase";
        ChatColor[] formats = new ChatColor[]{ChatColor.BOLD, ChatColor.UNDERLINE};
        
        System.out.println("Format1: " + format1(name, formats));
        System.out.println("Format2: " + format2(name, formats));
        checkTime(1000000, new Executor() {
        	public void execute() {
        		format1(name, formats);
        	}
        });
        
        checkTime(1000000, new Executor() {
        	public void execute() {
        		format2(name, formats);
        	}
        });
    }
}