summaryrefslogtreecommitdiff
path: root/compiler
diff options
context:
space:
mode:
authorJiayu Liu <Jimexist@users.noreply.github.com>2022-05-06 03:19:57 +0800
committerGitHub <noreply@github.com>2022-05-05 15:19:57 -0400
commitada086529730b13eedb74a975db5167f405d18af (patch)
tree3311044cf35ddc4c9a45bd39d96eab4d74483268 /compiler
parent7fb21ebff73d6d1f87c67d7d0285ef39f704bce6 (diff)
downloadthrift-ada086529730b13eedb74a975db5167f405d18af.tar.gz
THRIFT-5544: annotations_as_metadata java code gen param (#2553)
Add a java code generation parameter called "annotations_as_metadata" to optionally include Thrift field annotations as metadata in the generated code.
Diffstat (limited to 'compiler')
-rw-r--r--compiler/cpp/src/thrift/generate/t_java_generator.cc41
1 files changed, 40 insertions, 1 deletions
diff --git a/compiler/cpp/src/thrift/generate/t_java_generator.cc b/compiler/cpp/src/thrift/generate/t_java_generator.cc
index a875c9b62..3ce1450b1 100644
--- a/compiler/cpp/src/thrift/generate/t_java_generator.cc
+++ b/compiler/cpp/src/thrift/generate/t_java_generator.cc
@@ -78,6 +78,7 @@ public:
suppress_generated_annotations_ = false;
rethrow_unhandled_exceptions_ = false;
unsafe_binaries_ = false;
+ annotations_as_metadata_ = false;
for (iter = parsed_options.begin(); iter != parsed_options.end(); ++iter) {
if (iter->first.compare("beans") == 0) {
bean_style_ = true;
@@ -124,6 +125,8 @@ public:
}
} else if (iter->first.compare("unsafe_binaries") == 0) {
unsafe_binaries_ = true;
+ } else if (iter->first.compare("annotations_as_metadata") == 0) {
+ annotations_as_metadata_ = true;
} else {
throw "unknown option java:" + iter->first;
}
@@ -188,6 +191,7 @@ public:
void generate_java_struct_read_object(std::ostream& out, t_struct* tstruct);
void generate_java_meta_data_map(std::ostream& out, t_struct* tstruct);
void generate_field_value_meta_data(std::ostream& out, t_type* type);
+ void generate_metadata_for_field_annotations(std::ostream& out, t_field* field);
std::string get_java_type_string(t_type* type);
void generate_java_struct_field_by_id(ostream& out, t_struct* tstruct);
void generate_reflection_setters(std::ostringstream& out,
@@ -439,6 +443,7 @@ private:
bool suppress_generated_annotations_;
bool rethrow_unhandled_exceptions_;
bool unsafe_binaries_;
+ bool annotations_as_metadata_;
};
/**
@@ -2856,6 +2861,11 @@ void t_java_generator::generate_java_meta_data_map(ostream& out, t_struct* tstru
// Create value meta data
generate_field_value_meta_data(out, field->get_type());
+
+ // Include the annotation into metadata when asked
+ if (annotations_as_metadata_) {
+ generate_metadata_for_field_annotations(out, field);
+ }
out << "));" << endl;
}
@@ -2924,6 +2934,33 @@ std::string t_java_generator::get_java_type_string(t_type* type) {
}
}
+void t_java_generator::generate_metadata_for_field_annotations(std::ostream& out, t_field* field) {
+ if (field->annotations_.size() == 0) {
+ return;
+ }
+ out << ", " << endl;
+ indent_up();
+ indent_up();
+ indent(out) << "java.util.stream.Stream.<java.util.Map.Entry<java.lang.String, "
+ "java.lang.String>>builder()"
+ << endl;
+
+ indent_up();
+ indent_up();
+ for (auto& annotation : field->annotations_) {
+ indent(out) << ".add(new java.util.AbstractMap.SimpleImmutableEntry<>(\"" + annotation.first
+ + "\", \"" + annotation.second + "\"))"
+ << endl;
+ }
+ indent(out) << ".build().collect(java.util.stream.Collectors.toMap(java.util.Map.Entry::getKey, "
+ "java.util.Map.Entry::getValue))";
+ indent_down();
+ indent_down();
+
+ indent_down();
+ indent_down();
+}
+
void t_java_generator::generate_field_value_meta_data(std::ostream& out, t_type* type) {
out << endl;
indent_up();
@@ -5740,4 +5777,6 @@ THRIFT_REGISTER_GENERATOR(
" generated_annotations=[undated|suppress]:\n"
" undated: suppress the date at @Generated annotations\n"
" suppress: suppress @Generated annotations entirely\n"
- " unsafe_binaries: Do not copy ByteBuffers in constructors, getters, and setters.\n")
+ " unsafe_binaries: Do not copy ByteBuffers in constructors, getters, and setters.\n"
+ " annotations_as_metadata:\n"
+ " Include Thrift field annotations as metadata in the generated code.\n")