digitalmars.D - with for reduced bloat
- Michelle Long (7/7) Dec 23 2018 enum X { A, B, C}
- Jonathan Marler (8/15) Dec 23 2018 You could even support this by default, without requiring `with`.
- Michelle Long (9/34) Dec 24 2018 This could still be valid. It is the proper type. With is just
- Neia Neutuladh (25/40) Dec 23 2018 How would that deal with name collisions, static imports, and nested
enum X { A, B, C}
void foo(X x);
foo(X.A);
vs
enum X { A, B, C}
void foo(with X x);
foo(A);
 Dec 23 2018
On Monday, 24 December 2018 at 02:04:26 UTC, Michelle Long wrote:
 enum X { A, B, C}
 void foo(X x);
 foo(X.A);
 vs
 enum X { A, B, C}
 void foo(with X x);
 foo(A);
You could even support this by default, without requiring `with`. 
It could break code but it's probably rare that symbols passed to 
an enum argument collide with members of the enum itself, i.e.
const A = X.B;
Foo(A); // this is probably rare
But we would have to decide which one to give precedence, the 
enum member scope or the the current scope.
 Dec 23 2018
On Monday, 24 December 2018 at 02:13:45 UTC, Jonathan Marler wrote:On Monday, 24 December 2018 at 02:04:26 UTC, Michelle Long wrote:This could still be valid. It is the proper type. With is just for name resolution. Essentially the compiler just prefixes the passed symbol with the enum given but if it knows it is already of the correct type then it can just use that.enum X { A, B, C} void foo(X x); foo(X.A); vs enum X { A, B, C} void foo(with X x); foo(A);You could even support this by default, without requiring `with`. It could break code but it's probably rare that symbols passed to an enum argument collide with members of the enum itself, i.e. const A = X.B; Foo(A); // this is probably rareBut we would have to decide which one to give precedence, the enum member scope or the the current scope.I think it only makes sense to use the enum in the function signature since that is the desired one. If it does not match at the call site then an error is thrown.
 Dec 24 2018
On Mon, 24 Dec 2018 02:04:26 +0000, Michelle Long wrote:
 enum X { A, B, C}
 
 void foo(X x);
 
 foo(X.A);
 
 
 vs
 
 
 enum X { A, B, C}
 
 void foo(with X x);
 
 foo(A);
How would that deal with name collisions, static imports, and nested 
symbols?
Like the standard naming convention is to have camelCase enum value names. 
So it would be something like:
---
bool caseSensitive = false;
getopt(
  args,
  // std.getopt.config.caseSensitive, std.getopt.config.allowBundling
  caseSensitive, allowBundling,
  "c|case-sensitive", "do a case-sensitive search", &caseSensitive);
---
Yuck.
The call site determines how to refer to symbols currently. It's still a 
bit complex, dealing with imports, explicit declarations and aliases, type 
hierarchies, and with statements. This would add even more complexity.
You can reduce the amount of call-site fluff with something like:
---
enum X { a, b, c; }
static foreach (m; __traits(allMembers, X))
{
  mixin("enum " ~ m ~ " = X." ~ m ~ ";");
}
---
 Dec 23 2018








 
  
  
 
 Michelle Long <HappyDance321 gmail.com>
 Michelle Long <HappyDance321 gmail.com> 