net.java.sip.communicator.impl.protocol.irc.Utils.java Source code

Java tutorial

Introduction

Here is the source code for net.java.sip.communicator.impl.protocol.irc.Utils.java

Source

/*
 * Jitsi, the OpenSource Java VoIP and Instant Messaging client.
 *
 * Copyright @ 2015 Atlassian Pty Ltd
 *
 * Licensed under the Apache License, Version 2.0 (the "License");
 * you may not use this file except in compliance with the License.
 * You may obtain a copy of the License at
 *
 *     http://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 */
package net.java.sip.communicator.impl.protocol.irc;

import net.java.sip.communicator.util.*;

import org.apache.commons.lang3.*;

/**
 * Some IRC-related utility methods.
 *
 * @author Danny van Heumen
 */
public final class Utils {
    /**
     * Logger.
     */
    private static final Logger LOGGER = Logger.getLogger(Utils.class);

    /**
     * Index indicating the end of the foreground color code.
     */
    private static final int INDEX_END_FOREGROUND_COLOR_CODE = 2;

    /**
     * Index indicating the end of the background color code. (additional 1 for
     * comma separating foreground color code from background color code)
     */
    private static final int INDEX_END_BACKGROUND_COLOR_CODE = 3;

    /**
     * Private constructor since we do not need to construct anything.
     */
    private Utils() {
    }

    /**
     * Parse IRC text message and process possible control codes.
     *
     * @param text the message
     * @return returns the processed message or null if text message was null,
     *         since there is nothing to modify there
     */
    public static String parseIrcMessage(final String text) {
        if (text == null) {
            return null;
        }

        FormattedTextBuilder builder = new FormattedTextBuilder();
        for (int i = 0; i < text.length(); i++) {
            char val = text.charAt(i);
            switch (val) {
            case ControlChar.Bold.CODE:
                if (builder.isActive(ControlChar.Bold.class)) {
                    builder.cancel(ControlChar.Bold.class, true);
                } else {
                    builder.apply(new ControlChar.Bold());
                }
                break;
            case ControlChar.Italics.CODE:
                if (builder.isActive(ControlChar.Italics.class)) {
                    builder.cancel(ControlChar.Italics.class, true);
                } else {
                    builder.apply(new ControlChar.Italics());
                }
                break;
            case ControlChar.Underline.CODE:
                if (builder.isActive(ControlChar.Underline.class)) {
                    builder.cancel(ControlChar.Underline.class, true);
                } else {
                    builder.apply(new ControlChar.Underline());
                }
                break;
            case ControlChar.ColorFormat.CODE:
                // first parse foreground color code
                Color foreground = parseForegroundColor(text.substring(i + 1));
                if (foreground == null) {
                    builder.cancel(ControlChar.ColorFormat.class, false);
                } else {
                    i += INDEX_END_FOREGROUND_COLOR_CODE;
                    Color background = parseBackgroundColor(text.substring(i + 1));
                    if (background != null) {
                        i += INDEX_END_BACKGROUND_COLOR_CODE;
                    }
                    builder.apply(new ControlChar.ColorFormat(foreground, background));
                }
                // Need to implement support for color 99 (Transparent)
                break;
            case ControlChar.Normal.CODE:
                builder.cancelAll();
                break;
            default:
                // value is a normal character, escape html entities and append
                builder.append(StringEscapeUtils.escapeHtml4("" + val));
                break;
            }
        }
        return builder.done();
    }

    /**
     * Parse background color code starting with the separator.
     *
     * @param text the text starting with the background color (separator)
     * @return returns the background color
     */
    private static Color parseBackgroundColor(final String text) {
        try {
            if (text.charAt(0) == ',') {
                // if available, also parse background color
                int color = Integer.parseInt("" + text.charAt(1) + text.charAt(2));
                color = color % Color.values().length;
                return Color.values()[color];
            }
            return null;
        } catch (StringIndexOutOfBoundsException e) {
            // Abort parsing background color. Assume only
            // foreground color available.
            LOGGER.trace("Abort parsing background color because text ended. "
                    + "Assuming only foreground color was available.");
            return null;
        } catch (NumberFormatException e) {
            // No background color defined, ignoring ...
            LOGGER.trace("No background color defined. Ignoring ...");
            return null;
        }
    }

    /**
     * Parse foreground color and return corresponding Color instance.
     *
     * @param text the text to parse, starting with color code
     * @return returns Color instance
     */
    private static Color parseForegroundColor(final String text) {
        try {
            int color = Integer.parseInt("" + text.charAt(0) + text.charAt(1));
            color = color % Color.values().length;
            return Color.values()[color];
        } catch (StringIndexOutOfBoundsException e) {
            // Invalid control code, since text has ended.
            LOGGER.trace("ArrayIndexOutOfBounds during foreground " + "color control code parsing.");
            return null;
        } catch (NumberFormatException e) {
            LOGGER.trace("Invalid foreground color code encountered.", e);
            return null;
        }
    }

    /**
     * Format message as normal HTML-formatted message.
     *
     * @param message original IRC message
     * @return returns HTML-formatted normal message
     */
    public static String styleAsMessage(final String message) {
        return message;
    }

    /**
     * Format message as HTML-formatted notice.
     *
     * @param message original IRC message
     * @param user user nick name
     * @return returns HTML-formatted notice
     */
    public static String styleAsNotice(final String message, final String user) {
        return "<i>" + user + "</i>: " + message;
    }

    /**
     * Format message as HTML-formatted away message.
     *
     * @param text away message
     * @return returns HTML-formatted message
     */
    public static String styleAsAwayMessage(final String text) {
        return "<i>Away: " + text + "</i>";
    }
}