Proposal: user defined attributes
Adam D. Ruppe
destructionator at gmail.com
Fri Mar 16 07:51:58 PDT 2012
On Friday, 16 March 2012 at 14:11:35 UTC, Manu wrote:
> Surely the term you're looking for here is @annotate(...) ?
Meh, I don't care that much about names. I went
with "note" anticipating people would complain about
@add_user_defined_attribute() being too long :)
> What if you want to annotate with a variable?
That *might* work because a variable is an expression too.
I'm not sure though. Will probably have to implement to
know for sure.
Of course, a constant can be represented as a struct
for name and value:
struct Description { string s; }
@note(Description("yada yada yada")) int a;
> Surely this is just as easy: @modulename.attribute int myThing;
Yeah, I think so. I remember this being a counterpoint
last time we talked about it, but I don't recall the
specific argument made.
> Perhaps that's the key distinction between 'annotation' and a
> 'custom attributes' .. an annotation this way is a shared
> compile time constant, associating with its type info, as you
> suggest. A custom attribute is an instance-specific association
> vontaining variable data.
Yeah, "annotation" might be the better word. That's
what I want here, but too late to change the subject name
now.
> attribute myAttribute
I think this could be done as a struct, but I haven't
used this kind of attribute at all so not sure...
But what I'm thinking is:
struct myAttribute(Type) {
Type value;
alias value this;
bool bNeedsAttention;
@property void refresh(bool bRefresh) { bNeedsAttention =
bRefresh; }
}
myAttribute!int thing;
thing.refresh = true;
and thing can be substituted for an int anywhere else.
More information about the Digitalmars-d
mailing list