blob: 43c546102a2d6190936f1bfe3da3ea1b40239ae0 [file] [log] [blame]
//===- ExtractAPI/APIIgnoresList.h ---------------*- C++ -*-===//
//
// Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
// See https://llvm.org/LICENSE.txt for license information.
// SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
//
//===----------------------------------------------------------------------===//
///
/// \file This file defines APIIgnoresList which is a type that allows querying
/// a file containing symbols to ignore when extracting API information.
///
//===----------------------------------------------------------------------===//
#ifndef LLVM_CLANG_API_IGNORES_LIST_H
#define LLVM_CLANG_API_IGNORES_LIST_H
#include "clang/Basic/FileManager.h"
#include "llvm/ADT/SmallVector.h"
#include "llvm/ADT/StringRef.h"
#include "llvm/Support/Error.h"
#include "llvm/Support/raw_ostream.h"
#include <memory>
#include <system_error>
namespace llvm {
class MemoryBuffer;
} // namespace llvm
namespace clang {
namespace extractapi {
struct IgnoresFileNotFound : public llvm::ErrorInfo<IgnoresFileNotFound> {
std::string Path;
static char ID;
explicit IgnoresFileNotFound(StringRef Path) : Path(Path) {}
virtual void log(llvm::raw_ostream &os) const override;
virtual std::error_code convertToErrorCode() const override;
};
/// A type that provides access to a new line separated list of symbol names to
/// ignore when extracting API information.
struct APIIgnoresList {
/// The API to use for generating from the file at \p IgnoresFilePath.
///
/// \returns an initialized APIIgnoresList or an Error.
static llvm::Expected<APIIgnoresList> create(llvm::StringRef IgnoresFilePath,
FileManager &FM);
APIIgnoresList() = default;
/// Check if \p SymbolName is specified in the APIIgnoresList and if it should
/// therefore be ignored.
bool shouldIgnore(llvm::StringRef SymbolName) const;
private:
using SymbolNameList = llvm::SmallVector<llvm::StringRef, 32>;
APIIgnoresList(SymbolNameList SymbolsToIgnore,
std::unique_ptr<llvm::MemoryBuffer> Buffer)
: SymbolsToIgnore(std::move(SymbolsToIgnore)), Buffer(std::move(Buffer)) {
}
SymbolNameList SymbolsToIgnore;
std::unique_ptr<llvm::MemoryBuffer> Buffer;
};
} // namespace extractapi
} // namespace clang
#endif // LLVM_CLANG_API_IGNORES_LIST_H