[PATCH] D88794: [flang] Fix pimpl idiom for IntrinsicProcTable.
Michael Kruse via Phabricator via llvm-commits
llvm-commits at lists.llvm.org
Tue Oct 13 22:40:00 PDT 2020
Meinersbur updated this revision to Diff 298035.
Meinersbur edited the summary of this revision.
Meinersbur added a comment.
Add \#include <memory.h> to ensure std::unique_ptr is available in idioms.h
Repository:
rG LLVM Github Monorepo
CHANGES SINCE LAST ACTION
https://reviews.llvm.org/D88794/new/
https://reviews.llvm.org/D88794
Files:
flang/include/flang/Common/idioms.h
flang/include/flang/Evaluate/intrinsics.h
flang/lib/Evaluate/intrinsics.cpp
Index: flang/lib/Evaluate/intrinsics.cpp
===================================================================
--- flang/lib/Evaluate/intrinsics.cpp
+++ flang/lib/Evaluate/intrinsics.cpp
@@ -2070,16 +2070,12 @@
return DynamicType{category, defaults_.GetDefaultKind(category)};
}
-IntrinsicProcTable::~IntrinsicProcTable() {
- // Discard the configured tables.
- delete impl_;
- impl_ = nullptr;
-}
+IntrinsicProcTable::~IntrinsicProcTable() = default;
IntrinsicProcTable IntrinsicProcTable::Configure(
const common::IntrinsicTypeDefaultKinds &defaults) {
IntrinsicProcTable result;
- result.impl_ = new IntrinsicProcTable::Implementation(defaults);
+ result.impl_ = std::make_unique<IntrinsicProcTable::Implementation>(defaults);
return result;
}
Index: flang/include/flang/Evaluate/intrinsics.h
===================================================================
--- flang/include/flang/Evaluate/intrinsics.h
+++ flang/include/flang/Evaluate/intrinsics.h
@@ -15,6 +15,7 @@
#include "flang/Common/default-kinds.h"
#include "flang/Parser/char-block.h"
#include "flang/Parser/message.h"
+#include <memory>
#include <optional>
#include <string>
@@ -64,8 +65,12 @@
private:
class Implementation;
+ IntrinsicProcTable() = default;
+
public:
~IntrinsicProcTable();
+ IntrinsicProcTable(IntrinsicProcTable &&) = default;
+
static IntrinsicProcTable Configure(
const common::IntrinsicTypeDefaultKinds &);
@@ -100,7 +105,7 @@
llvm::raw_ostream &Dump(llvm::raw_ostream &) const;
private:
- Implementation *impl_{nullptr}; // owning pointer
+ std::unique_ptr<Implementation> impl_;
};
} // namespace Fortran::evaluate
#endif // FORTRAN_EVALUATE_INTRINSICS_H_
Index: flang/include/flang/Common/idioms.h
===================================================================
--- flang/include/flang/Common/idioms.h
+++ flang/include/flang/Common/idioms.h
@@ -31,6 +31,7 @@
#include <tuple>
#include <type_traits>
#include <variant>
+#include <memory>
#if __GNUC__ == 7
// Avoid a deduction bug in GNU 7.x headers by forcing the answer.
@@ -142,6 +143,14 @@
return *p;
}
+template <typename T>
+constexpr T &Deref(const std::unique_ptr<T> &p, const char *file, int line) {
+ if (!p) {
+ Fortran::common::die("nullptr dereference at %s(%d)", file, line);
+ }
+ return *p;
+}
+
// Given a const reference to a value, return a copy of the value.
template <typename A> A Clone(const A &x) { return x; }
-------------- next part --------------
A non-text attachment was scrubbed...
Name: D88794.298035.patch
Type: text/x-patch
Size: 2473 bytes
Desc: not available
URL: <http://lists.llvm.org/pipermail/llvm-commits/attachments/20201014/61393838/attachment.bin>
More information about the llvm-commits
mailing list