/* Some commonly-used VEC types. Copyright (C) 2012-2019 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_VECS_H #define COMMON_GDB_VECS_H /* Split STR, a list of DELIMITER-separated fields, into a char pointer vector. You may modify the returned strings. */ extern std::vector> delim_string_to_char_ptr_vec (const char *str, char delimiter); /* Like dirnames_to_char_ptr_vec, but append the directories to *VECP. */ extern void dirnames_to_char_ptr_vec_append (std::vector> *vecp, const char *dirnames); /* Split DIRNAMES by DIRNAME_SEPARATOR delimiter and return a list of all the elements in their original order. For empty string ("") DIRNAMES return list of one empty string ("") element. You may modify the returned strings. */ extern std::vector> dirnames_to_char_ptr_vec (const char *dirnames); /* Remove the element pointed by iterator IT from VEC, not preserving the order of the remaining elements. Return the removed element. */ template T unordered_remove (std::vector &vec, typename std::vector::iterator it) { gdb_assert (it >= vec.begin () && it < vec.end ()); T removed = std::move (*it); if (it != vec.end () - 1) *it = std::move (vec.back ()); vec.pop_back (); return removed; } /* Remove the element at position IX from VEC, not preserving the order of the remaining elements. Return the removed element. */ template T unordered_remove (std::vector &vec, typename std::vector::size_type ix) { gdb_assert (ix < vec.size ()); return unordered_remove (vec, vec.begin () + ix); } /* Remove the element at position IX from VEC, preserving the order the remaining elements. Return the removed element. */ template T ordered_remove (std::vector &vec, typename std::vector::size_type ix) { gdb_assert (ix < vec.size ()); T removed = std::move (vec[ix]); vec.erase (vec.begin () + ix); return removed; } #endif /* COMMON_GDB_VECS_H */