#ifndef FILAMENT_GROUP_UTILS_HPP #define FILAMENT_GROUP_UTILS_HPP #include #include #include #include #include "PrintConfig.hpp" namespace Slic3r { namespace FilamentGroupUtils { struct Color { unsigned char r = 0; unsigned char g = 0; unsigned char b = 0; unsigned char a = 255; Color(unsigned char r_ = 0, unsigned char g_ = 0, unsigned char b_ = 0, unsigned a_ = 255) :r(r_), g(g_), b(b_), a(a_) {} Color(const std::string& hexstr); }; struct FilamentInfo { Color color; std::string type; int extruder_id; bool is_extended; // TODO: rename }; class FilamentGroupException: public std::exception { public: enum ErrorCode { EmptyAmsFilaments, ConflictLimits, Unknown }; private: ErrorCode code_; std::string message_; public: FilamentGroupException(ErrorCode code, const std::string& message) : code_(code), message_(message) {} ErrorCode code() const noexcept { return code_; } const char* what() const noexcept override { return message_.c_str(); } }; std::vector calc_max_group_size(const std::vector>& ams_counts,bool ignore_ext_filament); std::vector> build_machine_filaments(const std::vector>& filament_configs); bool collect_unprintable_limits(const std::vector>& physical_unprintables, const std::vector>& geometric_unprintables, std::vector>& unprintable_limits); bool remove_intersection(std::set& a, std::set& b); void extract_indices(const std::vector& used_filaments, const std::vector>& unprintable_elems, std::vector>& unprintable_idxs); void extract_unprintable_limit_indices(const std::vector>& unprintable_elems, const std::vector& used_filaments, std::map& unplaceable_limits); void extract_unprintable_limit_indices(const std::vector>& unprintable_elems, const std::vector& used_filaments, std::unordered_map>& unplaceable_limits); bool check_printable(const std::vector>& groups, const std::map& unprintable); } } #endif