/* Copyright 2017 - 2021 R. Thomas * Copyright 2017 - 2021 Quarkslab * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ #ifndef LIEF_MACHO_DYLIB_COMMAND_H_ #define LIEF_MACHO_DYLIB_COMMAND_H_ #include #include #include #include "LIEF/types.hpp" #include "LIEF/visibility.h" #include "LIEF/MachO/LoadCommand.hpp" namespace LIEF { namespace MachO { struct dylib_command; class LIEF_API DylibCommand : public LoadCommand { public: using version_t = std::array; public: //! Helper to convert an integer into a version array static version_t int2version(uint32_t version); //! Helper to convert a version array into an integer static uint32_t version2int(version_t version); //! Factory function to generate a LC_LOAD_WEAK_DYLIB library static DylibCommand weak_dylib(const std::string& name, uint32_t timestamp = 0, uint32_t current_version = 0, uint32_t compat_version = 0); //! Factory function to generate a LC_ID_DYLIB library static DylibCommand id_dylib(const std::string& name, uint32_t timestamp = 0, uint32_t current_version = 0, uint32_t compat_version = 0); //! Factory function to generate a LC_LOAD_DYLIB library static DylibCommand load_dylib(const std::string& name, uint32_t timestamp = 2, uint32_t current_version = 0, uint32_t compat_version = 0); //! Factory function to generate a LC_REEXPORT_DYLIB library static DylibCommand reexport_dylib(const std::string& name, uint32_t timestamp = 0, uint32_t current_version = 0, uint32_t compat_version = 0); //! Factory function to generate a LC_LOAD_UPWARD_DYLIB library static DylibCommand load_upward_dylib(const std::string& name, uint32_t timestamp = 0, uint32_t current_version = 0, uint32_t compat_version = 0); //! Factory function to generate a LC_LAZY_LOAD_DYLIB library static DylibCommand lazy_load_dylib(const std::string& name, uint32_t timestamp = 0, uint32_t current_version = 0, uint32_t compat_version = 0); public: DylibCommand(void); DylibCommand(const dylib_command *cmd); DylibCommand& operator=(const DylibCommand& copy); DylibCommand(const DylibCommand& copy); virtual ~DylibCommand(void); virtual DylibCommand* clone(void) const override; //! Library name const std::string& name(void) const; //! Date and Time when the shared library was built uint32_t timestamp(void) const; //! Current version of the shared library version_t current_version(void) const; //! Compatibility version of the shared library version_t compatibility_version(void) const; void name(const std::string& name); void timestamp(uint32_t timestamp); void current_version(version_t currentVersion); void compatibility_version(version_t compatibilityVersion); virtual std::ostream& print(std::ostream& os) const override; bool operator==(const DylibCommand& rhs) const; bool operator!=(const DylibCommand& rhs) const; virtual void accept(Visitor& visitor) const override; private: static DylibCommand create(LOAD_COMMAND_TYPES type, const std::string& name, uint32_t timestamp, uint32_t current_version, uint32_t compat_version); std::string name_; uint32_t timestamp_; uint32_t current_version_; uint32_t compatibility_version_; }; } } #endif