blob: f6d9d94ec8b55148e62b6ba047cc2a0325938e29 [file] [log] [blame]
/* Distributed under the OSI-approved BSD 3-Clause License. See accompanying
file Copyright.txt or https://cmake.org/licensing for details. */
#pragma once
#include "cmConfigure.h" // IWYU pragma: keep
#include <iosfwd>
#include <memory>
#include <string>
#include <cm/optional>
#include <cm/string_view>
#if !defined(CMake_USE_XCOFF_PARSER)
# error "This file may be included only if CMake_USE_XCOFF_PARSER is enabled."
#endif
class cmXCOFFInternal;
/** \class cmXCOFF
* \brief XCOFF parser.
*/
class cmXCOFF
{
public:
enum class Mode
{
ReadOnly,
ReadWrite
};
/** Construct with the name of the XCOFF input file to parse. */
cmXCOFF(const char* fname, Mode = Mode::ReadOnly);
/** Destruct. */
~cmXCOFF();
cmXCOFF(cmXCOFF&&) noexcept;
cmXCOFF(cmXCOFF const&) = delete;
cmXCOFF& operator=(cmXCOFF&&) noexcept;
cmXCOFF& operator=(cmXCOFF const&) = delete;
/** Get the error message if any. */
std::string const& GetErrorMessage() const { return this->ErrorMessage; }
/** Boolean conversion. True if the XCOFF file is valid. */
explicit operator bool() const { return this->Valid(); }
/** Get the LIBPATH (RPATH) parsed from the file, if any. */
cm::optional<cm::string_view> GetLibPath() const;
/** Set the LIBPATH (RPATH).
Works only if cmXCOFF was constructed with Mode::ReadWrite. */
bool SetLibPath(cm::string_view libPath);
/** Remove the LIBPATH (RPATH).
Works only if cmXCOFF was constructed with Mode::ReadWrite. */
bool RemoveLibPath();
private:
friend class cmXCOFFInternal;
bool Valid() const;
std::unique_ptr<cmXCOFFInternal> Internal;
std::string ErrorMessage;
};