/* * Copyright 2012-2015 Sergey Ignatov * * 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.intellij.erlang.jps.rebar; import com.intellij.openapi.compiler.CompilerMessageCategory; import com.intellij.openapi.util.text.StringUtil; import org.jetbrains.annotations.NotNull; import org.jetbrains.annotations.Nullable; import java.util.regex.Matcher; import java.util.regex.Pattern; public class RebarMessage { private static final Pattern LOG_MESSAGE_PATTERN = Pattern.compile("(ERROR|WARN|INFO|DEBUG):(.+)"); private final CompilerMessageCategory myCategory; private final String myDetails; private RebarMessage(@NotNull CompilerMessageCategory category, @NotNull String details) { this.myCategory = category; this.myDetails = details; } @Nullable public static RebarMessage create(@NotNull String message) { Matcher matcher = LOG_MESSAGE_PATTERN.matcher(StringUtil.trimTrailing(message)); if (!matcher.matches()) return null; String type = matcher.group(1); String details = matcher.group(2); return new RebarMessage(findCategory(type), details); } @NotNull public CompilerMessageCategory getCategory() { return myCategory; } @NotNull public String getDetails() { return myDetails; } @NotNull private static CompilerMessageCategory findCategory(@NotNull String type) { if ("ERROR".equals(type)) { return CompilerMessageCategory.ERROR; } if ("WARN".equals(type)) { return CompilerMessageCategory.WARNING; } return CompilerMessageCategory.INFORMATION; } }