All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.eolang.parser.UnderlinedMessage Maven / Gradle / Ivy

The newest version!
/*
 * The MIT License (MIT)
 *
 * Copyright (c) 2016-2024 Objectionary.com
 *
 * Permission is hereby granted, free of charge, to any person obtaining a copy
 * of this software and associated documentation files (the "Software"), to deal
 * in the Software without restriction, including without limitation the rights
 * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
 * copies of the Software, and to permit persons to whom the Software is
 * furnished to do so, subject to the following conditions:
 *
 * The above copyright notice and this permission notice shall be included
 * in all copies or substantial portions of the Software.
 *
 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
 * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
 * FITNESS FOR A PARTICULAR PURPOSE AND NON-INFRINGEMENT. IN NO EVENT SHALL THE
 * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
 * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
 * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
 * SOFTWARE.
 */
package org.eolang.parser;

import java.util.Collections;

/**
 * Underlined message.
 * 

* For example, if you have a message "Problem is here" and you want to underline * the word "is", you can create an instance of this class with the following * parameters: origin="Problem is here", from=8, length=2. *

*

* The result will be: * {@code * Problem is here * ^^ * } *

* @since 0.50 * @todo #3332:30min Add more decorators for the error message. * For example, {@link ParsingErrors} currently contains logic related to the message formatting. * It's better to create a separate class for this purpose. */ final class UnderlinedMessage { /** * The message. */ private final String origin; /** * The position from which to start underlining. */ private final int from; /** * The length of the underline. */ private final int length; /** * Ctor. * @param origin The message. * @param from The position from which to start underlining. * @param length The length of the underline. */ UnderlinedMessage(final String origin, final int from, final int length) { this.origin = origin; this.from = from; this.length = length; } /** * Formatted message. * @return The formatted message. */ String formatted() { return String.format( "%s\n%s", this.origin, this.underline() ); } /** * Underline. * @return The underlined string. */ private String underline() { final String result; if (this.origin.isEmpty() || this.length <= 0 || this.from >= this.origin.length()) { result = ""; } else if (this.from < 0) { result = UnderlinedMessage.repeat("^", this.origin.length()); } else { result = String.format( "%s%s", UnderlinedMessage.repeat(" ", this.from), UnderlinedMessage.repeat("^", Math.min(this.length, this.origin.length())) ); } return result; } /** * Repeat a symbol n times. * @param symbol The symbol. * @param times The number of times to repeat the symbol. * @return The repeated symbol. */ private static String repeat(final String symbol, final int times) { return String.join("", Collections.nCopies(times, symbol)); } }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy