// -*- mode: C++ -*- // // Copyright (C) 2013-2020 Red Hat, Inc. // // This file is part of the GNU Application Binary Interface Generic // Analysis and Instrumentation Library (libabigail). This library is // free software; you can redistribute it and/or modify it under the // terms of the GNU Lesser General Public License as published by the // Free Software Foundation; either version 3, or (at your option) any // later version. // This library 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 Lesser Public License for more details. // You should have received a copy of the GNU Lesser General Public // License along with this program; see the file COPYING-LGPLV3. If // not, see . /// @file /// /// Wrappers around regex types and functions. #ifndef __ABG_REGEX_H__ #define __ABG_REGEX_H__ #include #include #include #include "abg-cxx-compat.h" #include "abg-sptr-utils.h" namespace abigail { /// Namespace for regex types and functions. namespace regex { /// A convenience typedef for a shared pointer of regex_t. typedef abg_compat::shared_ptr regex_t_sptr; /// A delete functor for a shared_ptr of regex_t. struct regex_t_deleter { /// The operator called to de-allocate the pointer to regex_t /// embedded in a shared_ptr /// /// @param r the pointer to regex_t to de-allocate. void operator()(::regex_t* r) { regfree(r); delete r; } };//end struct regex_deleter /// A class to hold a reference to a string to regex escape. struct escape { escape(const std::string& str) : ref(str) { } const std::string& ref; }; std::ostream& operator<<(std::ostream& os, const escape& esc); std::string generate_from_strings(const std::vector& strs); regex_t_sptr compile(const std::string& str); bool match(const regex_t_sptr& r, const std::string& str); }// end namespace regex namespace sptr_utils { /// Specialization of sptr_utils::build_sptr for regex_t. /// /// This is used to wrap a pointer to regex_t into a /// shared_ptr. /// /// @param p the bare pointer to regex_t to wrap into a shared_ptr. /// /// @return the shared_ptr that wraps @p p. template<> regex::regex_t_sptr build_sptr(regex_t *p); /// Specialization of sptr_utils::build_sptr for regex_t. /// /// This creates a pointer to regex_t and wraps it into a shared_ptr. /// /// @return the shared_ptr wrapping the newly created regex_t* template<> regex::regex_t_sptr build_sptr(); }// end namespace sptr_utils }// end namespace abigail #endif //__ABG_REGEX_H__