You are viewing a plain text version of this content. The canonical link for it is here.
Posted to commits@thrift.apache.org by dr...@apache.org on 2010/03/05 08:51:52 UTC
svn commit: r919325 - in /incubator/thrift/trunk:
compiler/cpp/src/parse/t_field.h compiler/cpp/src/thrifty.yy
test/AnnotationTest.thrift
Author: dreiss
Date: Fri Mar 5 07:51:51 2010
New Revision: 919325
URL: http://svn.apache.org/viewvc?rev=919325&view=rev
Log:
THRIFT-564. Support arbitrary annotations on struct fields
This is subtly different from a type annotation, since some bits of
metadata only make sense in the context of a single structure field,
like whether the field is required, or whether the C++ code should use
a pointer for it.
This change doesn't define any meaningful annotations. It just sets up
the parsing infrastructure.
I have no idea if $10 will work with older versions of yacc. It seems
to work fine with bison.
Modified:
incubator/thrift/trunk/compiler/cpp/src/parse/t_field.h
incubator/thrift/trunk/compiler/cpp/src/thrifty.yy
incubator/thrift/trunk/test/AnnotationTest.thrift
Modified: incubator/thrift/trunk/compiler/cpp/src/parse/t_field.h
URL: http://svn.apache.org/viewvc/incubator/thrift/trunk/compiler/cpp/src/parse/t_field.h?rev=919325&r1=919324&r2=919325&view=diff
==============================================================================
--- incubator/thrift/trunk/compiler/cpp/src/parse/t_field.h (original)
+++ incubator/thrift/trunk/compiler/cpp/src/parse/t_field.h Fri Mar 5 07:51:51 2010
@@ -133,6 +133,7 @@
}
};
+ std::map<std::string, std::string> annotations_;
private:
t_type* type_;
Modified: incubator/thrift/trunk/compiler/cpp/src/thrifty.yy
URL: http://svn.apache.org/viewvc/incubator/thrift/trunk/compiler/cpp/src/thrifty.yy?rev=919325&r1=919324&r2=919325&view=diff
==============================================================================
--- incubator/thrift/trunk/compiler/cpp/src/thrifty.yy (original)
+++ incubator/thrift/trunk/compiler/cpp/src/thrifty.yy Fri Mar 5 07:51:51 2010
@@ -853,7 +853,7 @@
}
Field:
- CaptureDocText FieldIdentifier FieldRequiredness FieldType tok_identifier FieldValue XsdOptional XsdNillable XsdAttributes CommaOrSemicolonOptional
+ CaptureDocText FieldIdentifier FieldRequiredness FieldType tok_identifier FieldValue XsdOptional XsdNillable XsdAttributes TypeAnnotations CommaOrSemicolonOptional
{
pdebug("tok_int_constant : Field -> FieldType tok_identifier");
if ($2 < 0) {
@@ -878,6 +878,10 @@
if ($9 != NULL) {
$$->set_xsd_attrs($9);
}
+ if ($10 != NULL) {
+ $$->annotations_ = $10->annotations_;
+ delete $10;
+ }
}
FieldIdentifier:
Modified: incubator/thrift/trunk/test/AnnotationTest.thrift
URL: http://svn.apache.org/viewvc/incubator/thrift/trunk/test/AnnotationTest.thrift?rev=919325&r1=919324&r2=919325&view=diff
==============================================================================
--- incubator/thrift/trunk/test/AnnotationTest.thrift (original)
+++ incubator/thrift/trunk/test/AnnotationTest.thrift Fri Mar 5 07:51:51 2010
@@ -20,8 +20,8 @@
typedef list<i32> ( cpp.template = "std::list" ) int_linked_list
struct foo {
- 1: i32 bar;
- 2: i32 baz;
+ 1: i32 bar ( presence = "required" );
+ 2: i32 baz ( presence = "manual", cpp.use_pointer = "", );
3: i32 qux;
4: i32 bop;
} (