[ 
https://issues.apache.org/jira/browse/THRIFT-5843?page=com.atlassian.jira.plugin.system.issuetabpanels:comment-tabpanel&focusedCommentId=17909522#comment-17909522
 ] 

Triton Circonflexe commented on THRIFT-5843:
--------------------------------------------

Hello [~fishywang],

Jumping in just to answer your question: they are open enumerations (SAST tools 
might signal incomplete handling and whatnot but compilers won’t bulge).
I think that’s a good idea to have the option as it is increasingly becoming 
included in companies development guidelines.

> Represent Thrift enums as C++ enum classes
> ------------------------------------------
>
>                 Key: THRIFT-5843
>                 URL: https://issues.apache.org/jira/browse/THRIFT-5843
>             Project: Thrift
>          Issue Type: Improvement
>          Components: C++ - Compiler
>    Affects Versions: 0.21.0
>            Reporter: Tim Crews
>            Priority: Minor
>   Original Estimate: 48h
>  Remaining Estimate: 48h
>
> Add a *cpp:enum_classes* option to the C++ compiler so that a Thrift enum 
> declaration like this:
> {{enum PrintDirection}}
> {
> {{  Down = 68,}}
> {{  Up = 85}}
> {{}}}
> becomes a C++ [scoped 
> enumeration|https://en.cppreference.com/w/cpp/language/enum#Scoped_enumerations]
>  declaration like this:
> {{enum class PrintDirection {}}
> {{  Down = 68,}}
> {{  Up = 85}}
> {{};}}
> This is very similar to the existing *cpp::pure_enums* option, but it 
> addresses the drawback that all of the enumerators (the values like Down and 
> Up) are in the same namespace as the enumerators from other enum types.
> I already have a working implementation of this feature that I have been 
> using on a private fork of Thrift for about five years, so the only work 
> required would be to prepare the pull request.



--
This message was sent by Atlassian Jira
(v8.20.10#820010)

Reply via email to