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

com.microsoft.thrifty.schema.ErrorReporter.kt Maven / Gradle / Ivy

/*
 * Thrifty
 *
 * Copyright (c) Microsoft Corporation
 *
 * All rights reserved.
 *
 * 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
 *
 * THIS CODE IS PROVIDED ON AN  *AS IS* BASIS, WITHOUT WARRANTIES OR
 * CONDITIONS OF ANY KIND, EITHER EXPRESS OR IMPLIED, INCLUDING
 * WITHOUT LIMITATION ANY IMPLIED WARRANTIES OR CONDITIONS OF TITLE,
 * FITNESS FOR A PARTICULAR PURPOSE, MERCHANTABLITY OR NON-INFRINGEMENT.
 *
 * See the Apache Version 2.0 License for specific language governing permissions and limitations under the License.
 */
package com.microsoft.thrifty.schema

/**
 * An object that can collect warning and error reports generated during
 * parsing and schema validation.
 */
class ErrorReporter {
    /**
     * True if this reporter contains error-level reports.
     */
    var hasError = false
        private set

    private val reports_: MutableList = mutableListOf()

    /**
     * All reports collected by this reporter.
     */
    val reports: List
        get() = reports_

    /**
     * Reports a warning at the given [location].
     */
    fun warn(location: Location, message: String) {
        reports_.add(Report(Level.WARNING, location, message))
    }

    /**
     * Reports an error at the given [location].
     */
    fun error(location: Location, message: String) {
        hasError = true
        reports_.add(Report(Level.ERROR, location, message))
    }

    /**
     * Returns a list of formatted warning and error reports contained in this
     * reporter.
     */
    fun formattedReports(): List {
        val list = mutableListOf()
        val sb = StringBuilder()
        for (report in reports_) {
            when (report.level) {
                ErrorReporter.Level.WARNING -> sb.append("W: ")
                ErrorReporter.Level.ERROR -> sb.append("E: ")
            }

            sb.append(report.message)
            sb.append(" (at ")
            sb.append(report.location)
            sb.append(")")

            list += sb.toString()

            sb.setLength(0)
        }
        return list
    }

    /**
     * A structure containing a report level, content, and location.
     *
     * @property level The severity of the report.
     * @property location The point in a .thrift file containing the subject of the report.
     * @property message A description of the warning or error condition.
     */
    data class Report(
            val level: Level,
            val location: Location,
            val message: String
    )

    /**
     * The severities of reports.
     */
    enum class Level {
        /**
         * A warning is non-fatal, but should be investigated.
         */
        WARNING,

        /**
         * An error indicates that loading cannot proceed.
         */
        ERROR
    }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy