On 13.04.2018 23:16, Sven Barth via fpc-devel wrote:
Ondrej Pokorny <laza...@kluug.net <mailto:laza...@kluug.net>> schrieb am Fr., 13. Apr. 2018, 21:16:

    On 13.04.2018 14:08, Sven Barth via fpc-devel wrote:
    Ondrej Pokorny <laza...@kluug.net <mailto:laza...@kluug.net>>
    schrieb am Fr., 13. Apr. 2018, 12:52:

        I introduced the AS operator for enumerations in
        https://bugs.freepascal.org/view.php?id=33603


    What about enums with holes?

    No problem because Low() and High() work with these enums as well.
    See the test case project I attached to the bug report - it has a
    test with such an enum.


I wasn't talking about the boundaries. I meant undefined values inside the enum. If we want such a cast operator to work with such enums as well it should check for invalid values inside the enum, too. Otherwise the operator isn't worth it and should be forbidden for such enums.

Sven (or anybody else), could you please comment on https://bugs.freepascal.org/view.php?id=33603 ? I feel I am getting crazy.

From what I read, there seems to be a difference between FPC and Delphi understanding of "enums with holes":

1.) FPC understands the holes as undefined values - docs: https://www.freepascal.org/docs-html/ref/refsu4.html#x26-280003.1.1 :

Type
  EnumType = (one, two, three, forty := 40, thirty := 30);

It is necessary to keepfortyandthirtyin the correct order. When using enumeration types it is important to keep the following points in mind:

1. ThePredandSuccfunctions cannot be used on this kind of enumeration
   types. Trying to do this anyhow will result in a compiler error.

2.) Delphi understands the holes as well-defined values that only lack a name - docs: http://docwiki.embarcadero.com/RADStudio/Tokyo/en/Simple_Types_(Delphi)#Enumerated_Types_with_Explicitly_Assigned_Ordinality

type Size = (Small = 5, Medium = 10, Large = Small + Medium);

An enumerated type is, in effect, a subrange whose lowest and highest values correspond to the lowest and highest ordinalities of the constants in the declaration. In the previous example, the Size type has 11 possible values whose ordinalities range from 5 to 15. (Hence the type array[Size] of Char represents an array of 11 characters.) Only three of these values have names, but the others are accessible through typecasts and through routines such as Pred, Succ, Inc, and Dec.

----

Also, the difference is demonstrated in the fact that Delphi and FPC delphi mode allow to define an array of Size. OBJFPC mode doesn't allow it.

----

Therefore I enabled the IS/AS operators on enums with holes only in Delphi mode and disabled them in all other modes.

----

Am I right in my understanding?

Ondrej

_______________________________________________
fpc-devel maillist  -  fpc-devel@lists.freepascal.org
http://lists.freepascal.org/cgi-bin/mailman/listinfo/fpc-devel

Reply via email to