From 8af092125830e4814de7d228513404cf7e75b420 Mon Sep 17 00:00:00 2001 From: Henner Zeller Date: Thu, 14 Dec 2023 05:50:53 -0800 Subject: [PATCH] Use a deleter type insteadl of function pointer to close FILE. gcc12 complains that some attribute of fclose() is not kept ('ignoring attributes on template argument 'int (*)(FILE*)'). Changing this to a deleter type which is anyway more clean. --- verilog/tools/kythe/kzip_creator.cc | 2 +- verilog/tools/kythe/kzip_creator.h | 5 ++++- 2 files changed, 5 insertions(+), 2 deletions(-) diff --git a/verilog/tools/kythe/kzip_creator.cc b/verilog/tools/kythe/kzip_creator.cc index 8a740b058..0482973a8 100644 --- a/verilog/tools/kythe/kzip_creator.cc +++ b/verilog/tools/kythe/kzip_creator.cc @@ -38,7 +38,7 @@ constexpr int kKZipCompressionLevel = 9; } // namespace KzipCreator::KzipCreator(absl::string_view output_path) - : zip_file_(fopen(std::string(output_path).c_str(), "wb"), &fclose), + : zip_file_(fopen(std::string(output_path).c_str(), "wb")), archive_(kKZipCompressionLevel, [this](absl::string_view s) { return fwrite(s.data(), 1, s.size(), zip_file_.get()) == s.size(); }) { diff --git a/verilog/tools/kythe/kzip_creator.h b/verilog/tools/kythe/kzip_creator.h index 6e4b01f2f..bfbbfe3ca 100644 --- a/verilog/tools/kythe/kzip_creator.h +++ b/verilog/tools/kythe/kzip_creator.h @@ -42,7 +42,10 @@ class KzipCreator final { const ::kythe::proto::IndexedCompilation &unit); private: - std::unique_ptr zip_file_; + struct file_closer { + void operator()(FILE *f) const noexcept { fclose(f); } + }; + std::unique_ptr zip_file_; verible::zip::Encoder archive_; };