mirror of
git://sourceware.org/git/libabigail.git
synced 2025-02-13 12:07:06 +00:00
Fix the include guards of abg-dwarf-reader.h and abg-reporter-priv.h by moving them before any other includes where they actually belongs. Add missing include guards for abg-libxml-utils.h and abg-libzip-utils.h. * include/abg-dwarf-reader.h: Move include guard to the beginning. * include/abg-reporter-priv.h: Likewise. * include/abg-libxml-utils.h: Add include guard. * include/abg-libzip-utils.h: Likewise. Signed-off-by: Matthias Maennich <maennich@google.com>
77 lines
2.0 KiB
C++
77 lines
2.0 KiB
C++
// -*- mode: C++ -*-
|
|
//
|
|
// Copyright (C) 2013-2019 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 <http://www.gnu.org/licenses/>.
|
|
|
|
/// @file
|
|
|
|
#ifndef __ABG_LIBZIP_UTILS_H__
|
|
#define __ABG_LIBZIP_UTILS_H__
|
|
|
|
#include <zip.h>
|
|
#include "abg-cxx-compat.h"
|
|
|
|
namespace abigail
|
|
{
|
|
|
|
namespace zip_utils
|
|
{
|
|
|
|
using abg_compat::shared_ptr;
|
|
using std::string;
|
|
|
|
/// @brief Functor passed to shared_ptr constructor during
|
|
/// instantiation with zip*
|
|
///
|
|
/// Its aim is to delete zip* managed by shared_ptr.
|
|
struct archive_deleter
|
|
{
|
|
void
|
|
operator()(zip* archive)
|
|
{
|
|
/// ??? Maybe check the return code of close and throw if the
|
|
/// close fails? But then callers must be prepared to handle
|
|
/// this.
|
|
zip_close(archive);
|
|
}
|
|
};//end archive_deleter
|
|
|
|
/// @brief Functor passed to shared_ptr<zip_file>'s constructor.
|
|
///
|
|
/// Its aim is to close (actually delete) the zip_file* managed by the
|
|
/// shared_ptr.
|
|
struct zip_file_deleter
|
|
{
|
|
void
|
|
operator()(zip_file*f)
|
|
{
|
|
zip_fclose(f);
|
|
}
|
|
};
|
|
|
|
typedef shared_ptr<zip> zip_sptr;
|
|
zip_sptr open_archive(const string& path, int flags, int *errorp);
|
|
|
|
typedef shared_ptr<zip_file> zip_file_sptr;
|
|
zip_file_sptr open_file_in_archive(zip_sptr archive,
|
|
int file_index);
|
|
|
|
}// end namespace zip
|
|
}// end namespace abigail
|
|
#endif //__ABG_LIBZIP_UTILS_H__
|