From 62e2078514e307bc1b9fecff29977a5476fc7c45 Mon Sep 17 00:00:00 2001 From: Trevor Saunders Date: Tue, 26 Jul 2016 10:43:58 +0000 Subject: [PATCH] add auto_sbitmap class gcc/ChangeLog: 2016-07-26 Trevor Saunders * sbitmap.h (auto_sbitmap): New class. From-SVN: r238747 --- gcc/ChangeLog | 4 ++++ gcc/sbitmap.h | 25 +++++++++++++++++++++++++ 2 files changed, 29 insertions(+) diff --git a/gcc/ChangeLog b/gcc/ChangeLog index cbb70a79428..79f79ebc55b 100644 --- a/gcc/ChangeLog +++ b/gcc/ChangeLog @@ -1,3 +1,7 @@ +2016-07-26 Trevor Saunders + + * sbitmap.h (auto_sbitmap): New class. + 2016-07-26 Alan Modra PR target/72103 diff --git a/gcc/sbitmap.h b/gcc/sbitmap.h index c2081710bd2..bd734f96edd 100644 --- a/gcc/sbitmap.h +++ b/gcc/sbitmap.h @@ -256,4 +256,29 @@ extern int bitmap_last_set_bit (const_sbitmap); extern void debug_bitmap (const_sbitmap); extern sbitmap sbitmap_realloc (sbitmap, unsigned int); + +/* a class that ties the lifetime of a sbitmap to its scope. */ +class auto_sbitmap +{ +public: + explicit auto_sbitmap (unsigned int size) : + m_bitmap (sbitmap_alloc (size)) {} + ~auto_sbitmap () { sbitmap_free (m_bitmap); } + + /* Allow calling sbitmap functions on our bitmap. */ + operator sbitmap () { return m_bitmap; } + +private: + /* Prevent making a copy that refers to our sbitmap. */ + auto_sbitmap (const auto_sbitmap &); + auto_sbitmap &operator = (const auto_sbitmap &); +#if __cplusplus >= 201103L + auto_sbitmap (auto_sbitmap &&); + auto_sbitmap &operator = (auto_sbitmap &&); +#endif + + /* The bitmap we are managing. */ + sbitmap m_bitmap; +}; + #endif /* ! GCC_SBITMAP_H */