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

org.jetbrains.kotlin.maven.MavenPluginLogMessageCollector Maven / Gradle / Ivy

The newest version!
/*
 * Copyright 2010-2017 JetBrains s.r.o.
 *
 * 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 org.jetbrains.kotlin.maven;

import com.intellij.openapi.util.Pair;
import org.apache.maven.plugin.logging.Log;
import org.codehaus.plexus.compiler.CompilerMessage;
import org.jetbrains.annotations.NotNull;
import org.jetbrains.annotations.Nullable;
import org.jetbrains.kotlin.cli.common.messages.CompilerMessageSeverity;
import org.jetbrains.kotlin.cli.common.messages.CompilerMessageSourceLocation;
import org.jetbrains.kotlin.cli.common.messages.MessageCollector;

import java.util.ArrayList;
import java.util.Collections;
import java.util.List;
import java.util.stream.Collectors;

import static com.google.common.base.Preconditions.checkNotNull;

public class MavenPluginLogMessageCollector implements MessageCollector {
    private final Log log;
    private final ArrayList> collectedErrors = new ArrayList<>();

    public MavenPluginLogMessageCollector(Log log) {
        this.log = checkNotNull(log, "log shouldn't be null");
    }

    @Override
    public boolean hasErrors() {
        return !collectedErrors.isEmpty();
    }

    @NotNull
    public List> getCollectedErrors() {
        return Collections.unmodifiableList(collectedErrors);
    }

    @Override
    public void clear() {
        // Do nothing
    }

    @Override
    public void report(@NotNull CompilerMessageSeverity severity, @NotNull String message, @Nullable CompilerMessageSourceLocation location) {
        String position = location == null ? "" : location.getPath() + ": (" + (location.getLine() + ", " + location.getColumn()) + ") ";

        String text = position + message;

        switch (severity) {
            case EXCEPTION:
            case ERROR: {
                collectedErrors.add(new Pair<>(location, message));
                log.error(text);
                break;
            }
            case STRONG_WARNING:
            case WARNING: {
                log.warn(text);
                break;
            }
            case INFO: {
                log.info(text);
                break;
            }
            case LOGGING:
            case OUTPUT: {
                log.debug(text);
                break;
            }
            default: {
                log.warn("[Unknown severity " + severity + "] " + text);
            }
        }
    }

    public void throwKotlinCompilerException() throws KotlinCompilationFailureException {
        throw new KotlinCompilationFailureException(getCollectedErrors().stream().map(pair -> {
            CompilerMessageSourceLocation location = pair.getFirst();
            String message = pair.getSecond();
            if (location == null) {
                return new CompilerMessage(null, CompilerMessage.Kind.ERROR, 0, 0, 0, 0, message);
            }

            String lineContent = location.getLineContent();
            int lineContentLength = lineContent == null ? 0 : lineContent.length();

            return new CompilerMessage(
                    location.getPath(),
                    CompilerMessage.Kind.ERROR,
                    fixLocation(location.getLine()),
                    fixLocation(location.getColumn()),
                    fixLocation(location.getLine()),
                    Math.min(fixLocation(location.getColumn()), lineContentLength),
                    message
            );
        }).collect(Collectors.toList()));
    }

    private static int fixLocation(int n) {
        if (n < 0) {
            return 0;
        }
        return n;
    }
}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy