001/*
002 * Copyright (c) 2012-2021 Institut National des Sciences Appliquées de Lyon (INSA Lyon) and others
003 *
004 * This program and the accompanying materials are made available under the
005 * terms of the Eclipse Public License 2.0 which is available at
006 * http://www.eclipse.org/legal/epl-2.0.
007 *
008 * SPDX-License-Identifier: EPL-2.0
009 */
010
011package org.eclipse.golo.runtime;
012
013import gololang.Tuple;
014
015import java.util.Arrays;
016import java.util.HashSet;
017
018import static gololang.Messages.message;
019import static gololang.Messages.warning;
020import static org.eclipse.golo.cli.command.Metadata.GUIDE_BASE;
021
022/**
023 * A static class to deal with several kinds of warnings.
024 */
025public final class Warnings {
026  private Warnings() {
027    // utility class
028  }
029
030  private static final boolean NO_PARAMETER_NAMES = load("golo.warnings.no-parameter-names", "true");
031  private static final boolean UNAVAILABLE_CLASS = load("golo.warnings.unavailable-class", "false");
032  private static final boolean DEPRECATED = load("golo.warnings.deprecated", "true");
033  private static final boolean MULTIPLE_PACKAGE_DESCRIPTION = load("golo.warnings.doc.multiple-package-desc", "true");
034  private static final HashSet<Tuple> SEEN_DEPRECATIONS = new HashSet<>();
035
036  private static boolean load(String property, String def) {
037    return Boolean.valueOf(System.getProperty(property, def));
038  }
039
040  public static void multiplePackageDescription(String packageName) {
041    if (MULTIPLE_PACKAGE_DESCRIPTION) {
042      warning(message("multiple_package_desc", packageName, GUIDE_BASE));
043    }
044  }
045
046  public static void noParameterNames(String methodName, String[] argumentNames) {
047    if (NO_PARAMETER_NAMES || gololang.Runtime.debugMode()) {
048      warning(message("no_parameter_names", methodName, Arrays.toString(argumentNames), GUIDE_BASE));
049    }
050  }
051
052  public static void unavailableClass(String className, String callerModule) {
053    if ((UNAVAILABLE_CLASS || gololang.Runtime.debugMode()) && !className.startsWith("java.lang") && !className.startsWith("gololang")) {
054      warning(message("unavailable_class", className, callerModule, GUIDE_BASE));
055    }
056  }
057
058  public static void deprecatedElement(String object, String caller) {
059    if (DEPRECATED) {
060      Tuple seen = new Tuple(object, caller);
061      if (!SEEN_DEPRECATIONS.contains(seen)) {
062        SEEN_DEPRECATIONS.add(seen);
063        warning(message("deprecated_element", object, caller, GUIDE_BASE));
064      }
065    }
066  }
067}