From 5898151b24ae44453ef4fd185c460ca4895c742a Mon Sep 17 00:00:00 2001 From: Victor Zverovich Date: Wed, 17 May 2023 14:23:07 -0700 Subject: [PATCH] Improve enum docs Summary: * Add missing annotations to the grammar of an enum (declaration). * Replace "enumeration" with "enum" both in the title and in the grammar for consistency with other declarations (e.g. we have "struct" instead of "structure"). * Spell out the delimiter as an an optional ",". While we also support semicolons for historical reasons, we warn about them, remove them during autoformat and it's probably a good idea to show the syntax we recommend. * Consolidate a few pieces of definition grammar for simplicity. * Remove another reference to C++ because enums in Thrift are only superficially similar. * Rephrase warnings/notes for clarity. Reviewed By: thedavekwon Differential Revision: D45956186 fbshipit-source-id: 0f8e0dd424f6a7364981328e41ff0db467ae5dbd --- thrift/doc/idl/index.md | 38 +++++++++++++++++++------------------- 1 file changed, 19 insertions(+), 19 deletions(-) diff --git a/thrift/doc/idl/index.md b/thrift/doc/idl/index.md index 7d06f78831f..9c2f13f1000 100644 --- a/thrift/doc/idl/index.md +++ b/thrift/doc/idl/index.md @@ -363,25 +363,21 @@ Thrift supports three kinds of definitions: type definitions, interface definiti ```grammar definition ::= type_definition | interface_definition | constant_definition -``` - -Definitions appear at the top level of a Thrift file. A common property of all definitions is that they introduce a name (an identifier) that can be used to denote the entity such as type. - -The name introduced by definitions can be used anywhere in the Thrift file (either before or after the location of the definition), and in other Thrift files that include this Thrift file. -```grammar type_definition ::= struct | union | exception - | enumeration + | enum | typedef -``` -```grammar interface_definition ::= service | interaction ``` +Definitions appear at the top level of a Thrift file. A common property of all definitions is that they introduce a name (an identifier) that can be used to denote the entity such as type. + +The name introduced by definitions can be used anywhere in the Thrift file (either before or after the location of the definition), and in other Thrift files that include this Thrift file. + ### Structs A struct declaration introduces a named struct type into your program and has the following form: @@ -504,17 +500,21 @@ The generated code for exceptions can be different from that of structs. For exa It is possible to serialize from an exception and deserialize into a compatible struct, and vice versa. ::: -### Enumerations +### Enums -``` -enumeration ::= - "enum" identifier "{" ( Enumerator delimiter )* "}" +A enum declaration introduces a named enumeration type into your program and has the following form: + +```grammar +enum ::= + [annotations] + "enum" identifier "{" + (enumerator [","])* + "}" -Enumerator ::= - identifier "=" integer +enumerator ::= identifier "=" integer ``` -Thrift supports C++ style enumeration types. The enumerators (the named constants) must be explicitly bound to an integer value. The identifier after the reserved word `enum` may be used to denote the enumeration type. +The enumerators (the named constants) must be explicitly bound to an integer value. The identifier after the reserved word `enum` may be used to denote the enumeration type. ```thrift enum SearchKind { @@ -526,11 +526,11 @@ enum SearchKind { ``` :::note -Because the default value for every enum is 0 (even if you do not define an enumerator for 0), it is recommended to include an `UNKNOWN` entry at 0 and use that value to indicate that the client or server didn't provide the value. The default constructor will initialize that value to `UNKNOWN` instead of some meaningful value. +Because the default value for every enum is 0 (even if you do not define an enumerator for 0), it is recommended to include an `UNKNOWN` entry with the value 0 and use it to indicate that the client or server didn't provide the value. This way missing values will be represented as `UNKNOWN` instead of something meaningful that happens to be defined to zero in the IDL. ::: :::caution -Enums are treated like integer by Thrift, if you send a value which is not in the valid range, the receiver may not check or convert the value to the default (it will just have an out of range value) or it may throw an exception on access. This can happen when a new client is talking to an old server. +Enums are treated like integers by Thrift, if you send a value which is not listed in the IDL, the receiver may not check or convert the value to the default (it will just have an out of range value) or it may throw an exception on access. This can happen when a new client is talking to an old server. ::: :::caution @@ -543,7 +543,7 @@ Removing and adding enum values can be dangerous - see [Schema Compatibility](/f typedef ::= [annotations] "typedef" type identifier [";"] ``` -A typedef introduces a name that denotes the type specification. It can be used to provide a simpler way to access complex types. +A typedef introduces a name that denotes the type. It can be used to provide a simpler way to access complex types. ```thrift typedef map StringMap