/* std::unique_ptr specializations for GDB. Copyright (C) 2016-2021 Free Software Foundation, Inc. This file is part of GDB. This program is free software; you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation; either version 3 of the License, or (at your option) any later version. This program is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details. You should have received a copy of the GNU General Public License along with this program. If not, see . */ #ifndef COMMON_GDB_UNIQUE_PTR_H #define COMMON_GDB_UNIQUE_PTR_H #include #include "gdbsupport/gdb-xfree.h" namespace gdb { /* Define gdb::unique_xmalloc_ptr, a std::unique_ptr that manages xmalloc'ed memory. */ /* The deleter for std::unique_xmalloc_ptr. Uses xfree. */ template struct xfree_deleter { void operator() (T *ptr) const { xfree (ptr); } }; /* Same, for arrays. */ template struct xfree_deleter { void operator() (T *ptr) const { xfree (ptr); } }; /* Import the standard unique_ptr to our namespace with a custom deleter. */ template using unique_xmalloc_ptr = std::unique_ptr>; /* A no-op deleter. */ template struct noop_deleter { void operator() (T *ptr) const { } }; } /* namespace gdb */ /* Dup STR and return a unique_xmalloc_ptr for the result. */ static inline gdb::unique_xmalloc_ptr make_unique_xstrdup (const char *str) { return gdb::unique_xmalloc_ptr (xstrdup (str)); } /* Dup the first N characters of STR and return a unique_xmalloc_ptr for the result. The result is always \0-terminated. */ static inline gdb::unique_xmalloc_ptr make_unique_xstrndup (const char *str, size_t n) { return gdb::unique_xmalloc_ptr (xstrndup (str, n)); } #endif /* COMMON_GDB_UNIQUE_PTR_H */