/** * Jungfraujoch * API to control Jungfraujoch developed by the Paul Scherrer Institute (Switzerland). Jungfraujoch is a data acquisition and analysis system for pixel array detectors, primarly PSI JUNGFRAU. Jungfraujoch uses FPGA boards to acquire data at high data rates. * * The version of the OpenAPI document: 1.0.0-rc.58 * Contact: filip.leonarski@psi.ch * * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech). * https://openapi-generator.tech * Do not edit the class manually. */ #include "Rotation_axis.h" #include "Helpers.h" #include namespace org::openapitools::server::model { Rotation_axis::Rotation_axis() { m_Name = "omega"; m_NameIsSet = false; m_Step = 0.0f; m_Start = 0.0f; m_StartIsSet = false; m_Helical_step_umIsSet = false; m_Screening_wedge_deg = 0.0f; m_Screening_wedge_degIsSet = false; } void Rotation_axis::validate() const { std::stringstream msg; if (!validate(msg)) { throw org::openapitools::server::helpers::ValidationException(msg.str()); } } bool Rotation_axis::validate(std::stringstream& msg) const { return validate(msg, ""); } bool Rotation_axis::validate(std::stringstream& msg, const std::string& pathPrefix) const { bool success = true; const std::string _pathPrefix = pathPrefix.empty() ? "Rotation_axis" : pathPrefix; if (nameIsSet()) { const std::string& value = m_Name; const std::string currentValuePath = _pathPrefix + ".name"; if (value.length() < 1) { success = false; msg << currentValuePath << ": must be at least 1 characters long;"; } } /* Vector */ { const std::vector& value = m_Vector; const std::string currentValuePath = _pathPrefix + ".vector"; if (value.size() < 3) { success = false; msg << currentValuePath << ": must have at least 3 elements;"; } if (value.size() > 3) { success = false; msg << currentValuePath << ": must have at most 3 elements;"; } { // Recursive validation of array elements const std::string oldValuePath = currentValuePath; int i = 0; for (const float& value : value) { const std::string currentValuePath = oldValuePath + "[" + std::to_string(i) + "]"; i++; } } } if (helicalStepUmIsSet()) { const std::vector& value = m_Helical_step_um; const std::string currentValuePath = _pathPrefix + ".helicalStepUm"; if (value.size() < 3) { success = false; msg << currentValuePath << ": must have at least 3 elements;"; } if (value.size() > 3) { success = false; msg << currentValuePath << ": must have at most 3 elements;"; } { // Recursive validation of array elements const std::string oldValuePath = currentValuePath; int i = 0; for (const float& value : value) { const std::string currentValuePath = oldValuePath + "[" + std::to_string(i) + "]"; i++; } } } return success; } bool Rotation_axis::operator==(const Rotation_axis& rhs) const { return ((!nameIsSet() && !rhs.nameIsSet()) || (nameIsSet() && rhs.nameIsSet() && getName() == rhs.getName())) && (getStep() == rhs.getStep()) && ((!startIsSet() && !rhs.startIsSet()) || (startIsSet() && rhs.startIsSet() && getStart() == rhs.getStart())) && (getVector() == rhs.getVector()) && ((!helicalStepUmIsSet() && !rhs.helicalStepUmIsSet()) || (helicalStepUmIsSet() && rhs.helicalStepUmIsSet() && getHelicalStepUm() == rhs.getHelicalStepUm())) && ((!screeningWedgeDegIsSet() && !rhs.screeningWedgeDegIsSet()) || (screeningWedgeDegIsSet() && rhs.screeningWedgeDegIsSet() && getScreeningWedgeDeg() == rhs.getScreeningWedgeDeg())) ; } bool Rotation_axis::operator!=(const Rotation_axis& rhs) const { return !(*this == rhs); } void to_json(nlohmann::json& j, const Rotation_axis& o) { j = nlohmann::json::object(); if(o.nameIsSet()) j["name"] = o.m_Name; j["step"] = o.m_Step; if(o.startIsSet()) j["start"] = o.m_Start; j["vector"] = o.m_Vector; if(o.helicalStepUmIsSet() || !o.m_Helical_step_um.empty()) j["helical_step_um"] = o.m_Helical_step_um; if(o.screeningWedgeDegIsSet()) j["screening_wedge_deg"] = o.m_Screening_wedge_deg; } void from_json(const nlohmann::json& j, Rotation_axis& o) { if(j.find("name") != j.end()) { j.at("name").get_to(o.m_Name); o.m_NameIsSet = true; } j.at("step").get_to(o.m_Step); if(j.find("start") != j.end()) { j.at("start").get_to(o.m_Start); o.m_StartIsSet = true; } j.at("vector").get_to(o.m_Vector); if(j.find("helical_step_um") != j.end()) { j.at("helical_step_um").get_to(o.m_Helical_step_um); o.m_Helical_step_umIsSet = true; } if(j.find("screening_wedge_deg") != j.end()) { j.at("screening_wedge_deg").get_to(o.m_Screening_wedge_deg); o.m_Screening_wedge_degIsSet = true; } } std::string Rotation_axis::getName() const { return m_Name; } void Rotation_axis::setName(std::string const& value) { m_Name = value; m_NameIsSet = true; } bool Rotation_axis::nameIsSet() const { return m_NameIsSet; } void Rotation_axis::unsetName() { m_NameIsSet = false; } float Rotation_axis::getStep() const { return m_Step; } void Rotation_axis::setStep(float const value) { m_Step = value; } float Rotation_axis::getStart() const { return m_Start; } void Rotation_axis::setStart(float const value) { m_Start = value; m_StartIsSet = true; } bool Rotation_axis::startIsSet() const { return m_StartIsSet; } void Rotation_axis::unsetStart() { m_StartIsSet = false; } std::vector Rotation_axis::getVector() const { return m_Vector; } void Rotation_axis::setVector(std::vector const value) { m_Vector = value; } std::vector Rotation_axis::getHelicalStepUm() const { return m_Helical_step_um; } void Rotation_axis::setHelicalStepUm(std::vector const value) { m_Helical_step_um = value; m_Helical_step_umIsSet = true; } bool Rotation_axis::helicalStepUmIsSet() const { return m_Helical_step_umIsSet; } void Rotation_axis::unsetHelical_step_um() { m_Helical_step_umIsSet = false; } float Rotation_axis::getScreeningWedgeDeg() const { return m_Screening_wedge_deg; } void Rotation_axis::setScreeningWedgeDeg(float const value) { m_Screening_wedge_deg = value; m_Screening_wedge_degIsSet = true; } bool Rotation_axis::screeningWedgeDegIsSet() const { return m_Screening_wedge_degIsSet; } void Rotation_axis::unsetScreening_wedge_deg() { m_Screening_wedge_degIsSet = false; } } // namespace org::openapitools::server::model