Elements 2513 and 2521: Setting enum value from String

This is another thing that changed from Elements 2409 to 2513 and 2521, and currently breaks my code.

I need to assign a value to some enum, given the string representation of enum value. So far, I solved the problem by defining

  EnumType<T> = public T;
{$ELSE} // for .NET
  EnumType<T> = public extension class(T)
  where T is record;
    class method ValueOf(aStr: String): T;
      exit T(&Enum.Parse(typeOf(T), aStr));

This allowed me to make the assignments such as

SomeEnumType e := EnumType<SomeEnumType>.ValueOf("SomeStringValue");

I admit the solution is somewhat tricky, but it worked very well for any enum type, without the need to tamper with typeOf(), strange methods with many arguments, IFDEFS or similar. But now it does not compile any more and I cannot think of a similarly simple solution. Any ideas or suggestions? Is there any existing solution that I keep overlooking in the documentation? If not, I suggest a new feature: platform-independent mapping from string to enum value.

No ideas, no suggestions, no solutions?

Ok, let me then explicitly formulate

Feature request for Elements:

Platform-independent conversion from string to enum value, for any enum type.

What exactly fails? the Java or the .NET version, and whats the error?

Good idea yes.

Thanks, logged as bugs://84492

JAVA fails at the call

SomeEnumType e := EnumType<SomeEnumType>.ValueOf("SomeStringValue");


Error (E43) No static member "ValueOf" on type "EnumType<not nullable nullable SomeEnumType>"

Again: this this did work in Elements 2409.

Ah yes. What happened is that enums were inconsistent between Java ands the other platforms, because they mapped to reference types in Java, but where simple numeric value types every where else — and we made that consistent across platforms. As a side effect you might be losing access to Java-specifc APIs on the enum type, yes :(.

You can still force an enum own there Java platform to be based on the Java enum class, by specifying an ancestor for the enum (just as you can do X = public enum on Int64, you can do Y = public enum of java.lang.Enum. That will give you back the Java APIs (but at the cost of less platform compatibility.

Hopefully once we implement the above feature request that will make ti easier to have consistent enums and access to their string representation, across platforms.

I use the following code to do the conversion on Island/Windows, don’t know if it is the good way but just FYI
method AsEnum(const aStr: not nullable String): Tuple of (Boolean, nullable T);
result := (false, nil);
if not typeOf(T).IsEnum then exit;
for each el in typeOf(T).Constants do begin
if el.Name.Equals(aStr) then exit (true, T(el.Value));