46 #ifndef OME_XML_MODEL_WELLSAMPLE_H 47 #define OME_XML_MODEL_WELLSAMPLE_H 57 #include <ome/common/xml/dom/Document.h> 58 #include <ome/common/xml/dom/Element.h> 59 #include <ome/common/xml/dom/Node.h> 61 #include <ome/xml/model/primitives/Quantity.h> 63 #include <ome/xml/model/Image.h> 64 #include <ome/xml/model/Well.h> 65 #include <ome/xml/model/detail/OMEModelObject.h> 66 #include <ome/xml/model/enums/UnitsLength.h> 67 #include <ome/xml/model/primitives/NonNegativeInteger.h> 68 #include <ome/xml/model/primitives/Timestamp.h> 79 class PlateAcquisition;
89 std::shared_ptr<Impl>
impl;
120 static std::shared_ptr<WellSample>
149 link (std::shared_ptr<Reference>& reference,
150 std::shared_ptr<ome::xml::model::OMEModelObject>&
object);
173 std::shared_ptr<ome::xml::model::primitives::Quantity<ome::xml::model::enums::UnitsLength > >&
181 const std::shared_ptr<ome::xml::model::primitives::Quantity<ome::xml::model::enums::UnitsLength > >&
197 std::shared_ptr<ome::xml::model::primitives::Quantity<ome::xml::model::enums::UnitsLength > >&
205 const std::shared_ptr<ome::xml::model::primitives::Quantity<ome::xml::model::enums::UnitsLength > >&
221 std::shared_ptr<ome::xml::model::primitives::Timestamp>
229 const std::shared_ptr<ome::xml::model::primitives::Timestamp>
238 setTimepoint (std::shared_ptr<ome::xml::model::primitives::Timestamp>& timepoint);
254 setID (
const std::string&
id);
262 std::weak_ptr<ome::xml::model::Image>
271 const std::weak_ptr<ome::xml::model::Image>
280 linkImage (std::shared_ptr<ome::xml::model::Image>& image);
292 unlinkImage (std::shared_ptr<ome::xml::model::Image>& image);
317 const std::weak_ptr<ome::xml::model::PlateAcquisition>&
330 const std::weak_ptr<ome::xml::model::PlateAcquisition>&
332 const std::shared_ptr<ome::xml::model::PlateAcquisition>& plateAcquisition_BackReference);
345 linkPlateAcquisition (
const std::shared_ptr<ome::xml::model::PlateAcquisition>& plateAcquisition_BackReference);
363 unlinkPlateAcquisition (
const std::shared_ptr<ome::xml::model::PlateAcquisition>& plateAcquisition_BackReference);
370 std::weak_ptr<ome::xml::model::Well>
378 const std::weak_ptr<ome::xml::model::Well>
387 setWell (std::weak_ptr<ome::xml::model::Well>& well_BackReference);
405 #endif // OME_XML_MODEL_WELLSAMPLE_H OME model interface (abstract top-level container)
Definition: OMEModel.h:61
void setIndex(const ome::xml::model::primitives::NonNegativeInteger &index)
Set the Index property.
Definition: WellSample.cpp:332
bool linkPlateAcquisition(const std::shared_ptr< ome::xml::model::PlateAcquisition > &plateAcquisition_BackReference)
Link PlateAcquisition.
Definition: WellSample.cpp:473
void setID(const std::string &id)
Set the ID property.
Definition: WellSample.cpp:409
virtual SKIP void update(const common::xml::dom::Element &element, ome::xml::model::OMEModel &model)
Update the object hierarchy recursively from an XML DOM tree.
Definition: WellSample.cpp:213
const ome::xml::model::primitives::NonNegativeInteger & getIndex() const
Get the Index property.
Definition: WellSample.cpp:325
bool unlinkPlateAcquisition(const std::shared_ptr< ome::xml::model::PlateAcquisition > &plateAcquisition_BackReference)
Unlink PlateAcquisition.
Definition: WellSample.cpp:486
const std::string & getID() const
Get the ID property.
Definition: WellSample.cpp:402
Private implementation details of WellSample model object.
Definition: WellSample.cpp:75
boost::multi_index_container< Ptr< T >, boost::multi_index::indexed_by< boost::multi_index::random_access<>, boost::multi_index::ordered_unique< boost::multi_index::identity< Ptr< T > >, std::owner_less< Ptr< T > > > > > type
Multi-index container type.
Definition: OMEModelObject.h:93
const std::weak_ptr< ome::xml::model::PlateAcquisition > & getLinkedPlateAcquisition(OMEModelObject::indexed_container< ome::xml::model::PlateAcquisition, std::weak_ptr >::type::size_type index) const
Get linked PlateAcquisition.
Definition: WellSample.cpp:457
OME model object (concrete implementation).
Definition: OMEModelObject.h:64
OMEModelObject::indexed_container< ome::xml::model::PlateAcquisition, std::weak_ptr >::type getLinkedPlateAcquisitionList() const
Get the linked PlateAcquisition list.
Definition: WellSample.cpp:451
std::weak_ptr< ome::xml::model::Well > getWell()
Get the Well property.
Definition: WellSample.cpp:503
virtual ~WellSample()
Destructor.
Definition: WellSample.cpp:186
static std::shared_ptr< WellSample > create(const common::xml::dom::Element &element, ome::xml::model::OMEModel &model)
Create a WellSample model object from DOM element.
Definition: WellSample.cpp:191
const std::weak_ptr< ome::xml::model::PlateAcquisition > & setLinkedPlateAcquisition(OMEModelObject::indexed_container< ome::xml::model::PlateAcquisition, std::weak_ptr >::type::size_type index, const std::shared_ptr< ome::xml::model::PlateAcquisition > &plateAcquisition_BackReference)
Set linked PlateAcquisition.
Definition: WellSample.cpp:463
void setTimepoint(std::shared_ptr< ome::xml::model::primitives::Timestamp > &timepoint)
Set the Timepoint property.
Definition: WellSample.cpp:395
bool link(std::shared_ptr< Reference > &reference, std::shared_ptr< ome::xml::model::OMEModelObject > &object)
Link a given OME model object to this model object.
Definition: WellSample.cpp:299
bool validElementName(const std::string &name) const
Check if a given element name is valid for processing by this model object.
Definition: WellSample.cpp:207
Multi-index container for efficient ordered insertion and deletion of model object references...
Definition: OMEModelObject.h:84
void setPositionX(const std::shared_ptr< ome::xml::model::primitives::Quantity< ome::xml::model::enums::UnitsLength > > &positionX)
Set the PositionX property.
Definition: WellSample.cpp:353
Open Microscopy Environment C++ implementation.
WellSample model object.
Definition: WellSample.h:84
OMEModelObject::indexed_container< ome::xml::model::PlateAcquisition, std::weak_ptr >::type::size_type sizeOfLinkedPlateAcquisitionList() const
Get size of linked PlateAcquisition list.
Definition: WellSample.cpp:445
void linkImage(std::shared_ptr< ome::xml::model::Image > &image)
Link Image.
Definition: WellSample.cpp:429
virtual void asXMLElementInternal(common::xml::dom::Document &document, common::xml::dom::Element &element) const
Transform the object hierarchy rooted at this element to XML.
Definition: WellSample.cpp:523
const std::string & getXMLNamespace() const
Get the XML namespace for this model object.
Definition: WellSample.cpp:599
const std::string & elementName() const
Get the element name of this model object.
Definition: WellSample.cpp:200
void setPositionY(const std::shared_ptr< ome::xml::model::primitives::Quantity< ome::xml::model::enums::UnitsLength > > &positionY)
Set the PositionY property.
Definition: WellSample.cpp:374
std::shared_ptr< ome::xml::model::primitives::Quantity< ome::xml::model::enums::UnitsLength > > & getPositionX()
Get the PositionX property.
Definition: WellSample.cpp:339
void setWell(std::weak_ptr< ome::xml::model::Well > &well_BackReference)
Set the Well property.
Definition: WellSample.cpp:517
std::shared_ptr< ome::xml::model::primitives::Timestamp > getTimepoint()
Get the Timepoint property.
Definition: WellSample.cpp:381
std::shared_ptr< ome::xml::model::primitives::Quantity< ome::xml::model::enums::UnitsLength > > & getPositionY()
Get the PositionY property.
Definition: WellSample.cpp:360
A quantity of a defined unit.
Definition: Quantity.h:57
void unlinkImage(std::shared_ptr< ome::xml::model::Image > &image)
Unlink Image.
Definition: WellSample.cpp:435
WellSample()
Default constructor.
Definition: WellSample.cpp:167
std::weak_ptr< ome::xml::model::Image > getLinkedImage()
Get linked Image.
Definition: WellSample.cpp:416
std::shared_ptr< Impl > impl
Private implementation details.
Definition: WellSample.h:87
A numeric type constrained to a subrange (or subranges) of its range limits.
Definition: ConstrainedNumeric.h:118