From: Trevor Saunders Date: Tue, 26 Jul 2016 10:43:58 +0000 (+0000) Subject: add auto_sbitmap class X-Git-Url: https://git.libre-soc.org/?a=commitdiff_plain;h=62e2078514e307bc1b9fecff29977a5476fc7c45;p=gcc.git add auto_sbitmap class gcc/ChangeLog: 2016-07-26 Trevor Saunders * sbitmap.h (auto_sbitmap): New class. From-SVN: r238747 --- 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 */