J
Joshua Cranmer
I am trying to create an options class that manages options for a
project. In this class, the options are internally stored as Strings that
can be cast to (depending on circumstances) integers, booleans, or even
enums. However, I am having trouble getting the code to compile:
public final class Options {
private Options() {}
private static HashMap<String, String> opts = new HashMap<String,
String>();
private static HashMap<String, Class<?>> types = new HashMap<String,
Class<?>>();
public static String getOption(String name) {
return opts.get(name);
}
public static <T extends Enum<T>> T getAsEnum(String name) {
Class<?> c = types.get(name);
if (!c.isEnum())
throw new RuntimeException("Option "+name+" is not an enum!");
Class<T> ec = c.asSubclass(Enum.class);
return Enum.valueOf(ec, getOption(name));
}
}
The exact error:
C:\Documents and Settings\Josh\Desktop\Programming\Java\Decompiler_new
\util\Options.java:43: incompatible types
found : java.lang.Class<capture of ? extends java.lang.Enum>
required: java.lang.Class<T>
Class<T> ec = c.asSubclass(Enum.class);
^
If it helps, this is one of the intended usages:
// Options.opts has pair "log","ERROR"
// and Options.types has pair "log",LogLevel.class
// via my options scheme
@Option("log",LogLevel.class,"ERROR")
public class Logger {
// various methods
private static void log(String message, LogLevel severity) {
if (severity.ordinal() < Options.getAsEnum("log").ordinal())
return;
// log the message somehow
}
private enum LogLevel {
ERROR, WARNING, VERBOSE, DEBUG;
}
}
P.S. I know my error-handling is as of right now unacceptable; I am going
to start fixing that once I implement my logger, for which I need my
getAsEnum function to work.
project. In this class, the options are internally stored as Strings that
can be cast to (depending on circumstances) integers, booleans, or even
enums. However, I am having trouble getting the code to compile:
public final class Options {
private Options() {}
private static HashMap<String, String> opts = new HashMap<String,
String>();
private static HashMap<String, Class<?>> types = new HashMap<String,
Class<?>>();
public static String getOption(String name) {
return opts.get(name);
}
public static <T extends Enum<T>> T getAsEnum(String name) {
Class<?> c = types.get(name);
if (!c.isEnum())
throw new RuntimeException("Option "+name+" is not an enum!");
Class<T> ec = c.asSubclass(Enum.class);
return Enum.valueOf(ec, getOption(name));
}
}
The exact error:
C:\Documents and Settings\Josh\Desktop\Programming\Java\Decompiler_new
\util\Options.java:43: incompatible types
found : java.lang.Class<capture of ? extends java.lang.Enum>
required: java.lang.Class<T>
Class<T> ec = c.asSubclass(Enum.class);
^
If it helps, this is one of the intended usages:
// Options.opts has pair "log","ERROR"
// and Options.types has pair "log",LogLevel.class
// via my options scheme
@Option("log",LogLevel.class,"ERROR")
public class Logger {
// various methods
private static void log(String message, LogLevel severity) {
if (severity.ordinal() < Options.getAsEnum("log").ordinal())
return;
// log the message somehow
}
private enum LogLevel {
ERROR, WARNING, VERBOSE, DEBUG;
}
}
P.S. I know my error-handling is as of right now unacceptable; I am going
to start fixing that once I implement my logger, for which I need my
getAsEnum function to work.