From 60f4d5c821f7cc496aeee5f26de601bd783afaa6 Mon Sep 17 00:00:00 2001 From: Shai Szulanski Date: Wed, 15 Jan 2025 08:59:29 -0800 Subject: [PATCH] Bundle remaining annotation files Summary: Generalizes the mechanism in place for scope.thrift to all files without hardcoding a list. Uses the same mechanism to pass in the directory name that is used in build_templates.cc instead of using source_manager both for simplicity and for eventual OSS compatibility. Reviewed By: yoney Differential Revision: D68128288 fbshipit-source-id: 4191f46e0496e6e3844c7fa7aaa7c40d02d5688b --- thrift/annotation/build_annotations.cc | 51 +++++++++++++++++++------ thrift/annotation/bundled_annotations.h | 5 ++- 2 files changed, 43 insertions(+), 13 deletions(-) diff --git a/thrift/annotation/build_annotations.cc b/thrift/annotation/build_annotations.cc index 5f9a13224..fac718b88 100644 --- a/thrift/annotation/build_annotations.cc +++ b/thrift/annotation/build_annotations.cc @@ -14,10 +14,21 @@ * limitations under the License. */ +#include +#include +#include #include -#include "thrift/compiler/source_location.h" -int main() { +namespace fs = std::filesystem; + +int main(int argc, char** argv) { + if (argc != 2) { + fmt::print(stderr, "usage: {} templates-dir\n", argv[0]); + return 1; + } + + const auto path = fs::path(argv[1]); + // Print the header. fmt::print( "// {}generated\n" @@ -26,20 +37,38 @@ int main() { "\n", '@'); - // Read the file. - apache::thrift::compiler::source_manager sm; - std::string_view content = sm.get_file("scope.thrift")->text; - content.remove_suffix(1); // Remove trailing NUL. + // Read the files. + std::map files; + for (const auto& entry : fs::directory_iterator(path)) { + const auto& filepath = entry.path(); + if (filepath.extension() == ".thrift" && fs::is_regular_file(filepath)) { + std::ifstream file(filepath); + auto buf = std::string( + std::istreambuf_iterator(file), + std::istreambuf_iterator()); + files[fmt::format( + "thrift/annotation/{}", filepath.filename().generic_string())] = + std::move(buf); + } + } // Print the content. fmt::print( "namespace apache::thrift::detail {{\n" "\n" - "const std::string_view bundled_annotations::scope_file_content() {{\n" - " return R\"{0}({1}){0}\";\n" + "const std::map& bundled_annotations::files() {{\n" + " static const std::map files = {{\n"); + for (const auto& [path, content] : files) { + fmt::print( + " {{\"{1}\", R\"{0}({2}){0}\"}},\n", + "__FBTHRIFT_TAG__", + path, + content); + } + fmt::print( + " }};\n" + " return files;\n" "}}\n" "\n" - "}} // namespace apache::thrift::detail\n", - "__FBTHRIFT_TAG__", - content); + "}} // namespace apache::thrift::detail\n"); } diff --git a/thrift/annotation/bundled_annotations.h b/thrift/annotation/bundled_annotations.h index 447cc1463..77e2c2280 100644 --- a/thrift/annotation/bundled_annotations.h +++ b/thrift/annotation/bundled_annotations.h @@ -14,12 +14,13 @@ * limitations under the License. */ -#include +#include +#include namespace apache::thrift::detail { struct bundled_annotations { - static const std::string_view scope_file_content(); + static const std::map& files(); }; } // namespace apache::thrift::detail