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

org.checkerframework.javacutil.BugInCF Maven / Gradle / Ivy

Go to download

The Checker Framework enhances Java's type system to make it more powerful and useful. This lets software developers detect and prevent errors in their Java programs. The Checker Framework includes compiler plug-ins ("checkers") that find bugs or verify their absence. It also permits you to write your own compiler plug-ins.

There is a newer version: 3.44.0
Show newest version
package org.checkerframework.javacutil;

import org.checkerframework.checker.formatter.qual.FormatMethod;
import org.checkerframework.checker.nullness.qual.Nullable;

/**
 * Exception type indicating a bug in the framework.
 *
 * 

To indicate a bug in a checker implementation, use {@link TypeSystemError}. To indicate that * an end user made a mistake, use {@link UserError}. */ @SuppressWarnings("serial") public class BugInCF extends RuntimeException { /** * Constructs a new BugInCF with the specified detail message and no cause (use this at the root * cause). * * @param message the detail message */ public BugInCF(String message) { this(message, new Throwable()); } /** * Constructs a new BugInCF with a detail message composed from the given arguments, and with no * cause (use the current callstack as the root cause). * * @param fmt the format string * @param args the arguments for the format string */ @FormatMethod public BugInCF(String fmt, @Nullable Object... args) { this(String.format(fmt, args), new Throwable()); } /** * Constructs a new BugInCF with the specified cause. * * @param cause the cause; its detail message will be used and must be non-null */ @SuppressWarnings("nullness") public BugInCF(Throwable cause) { this(cause.getMessage(), new Throwable()); } /** * Constructs a new BugInCF with the specified cause and with a detail message composed from the * given arguments. * * @param cause the cause * @param fmt the format string * @param args the arguments for the format string */ @FormatMethod public BugInCF(Throwable cause, String fmt, @Nullable Object... args) { this(String.format(fmt, args), cause); } /** * Constructs a new BugInCF with the specified detail message and cause. * * @param message the detail message * @param cause the cause */ public BugInCF(String message, Throwable cause) { super(message, cause); if (message == null) { throw new BugInCF("Must have a detail message."); } if (cause == null) { throw new BugInCF("Must have a cause throwable."); } } }





© 2015 - 2024 Weber Informatics LLC | Privacy Policy