ome-xml  5.6.0
WellSample.h
1 /*
2  * #%L
3  * OME-XML C++ library for working with OME-XML metadata structures.
4  * %%
5  * Copyright © 2006 - 2016 Open Microscopy Environment:
6  * - Massachusetts Institute of Technology
7  * - National Institutes of Health
8  * - University of Dundee
9  * - Board of Regents of the University of Wisconsin-Madison
10  * - Glencoe Software, Inc.
11  * %%
12  * Redistribution and use in source and binary forms, with or without
13  * modification, are permitted provided that the following conditions are met:
14  *
15  * 1. Redistributions of source code must retain the above copyright notice,
16  * this list of conditions and the following disclaimer.
17  * 2. Redistributions in binary form must reproduce the above copyright notice,
18  * this list of conditions and the following disclaimer in the documentation
19  * and/or other materials provided with the distribution.
20  *
21  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
22  * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
23  * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
24  * ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDERS OR CONTRIBUTORS BE
25  * LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
26  * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
27  * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
28  * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
29  * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
30  * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
31  * POSSIBILITY OF SUCH DAMAGE.
32  *
33  * The views and conclusions contained in the software and documentation are
34  * those of the authors and should not be interpreted as representing official
35  * policies, either expressed or implied, of any organization.
36  * #L%
37  */
38 
39 /*─────────────────────────────────────────────────────────────────────────────
40  *
41  * THIS IS AUTOMATICALLY GENERATED CODE. DO NOT MODIFY.
42  *
43  *─────────────────────────────────────────────────────────────────────────────
44  */
45 
46 #ifndef OME_XML_MODEL_WELLSAMPLE_H
47 #define OME_XML_MODEL_WELLSAMPLE_H
48 
49 #include <algorithm>
50 #include <list>
51 #include <stdexcept>
52 #include <string>
53 #include <vector>
54 
55 #include <ome/common/log.h>
56 
57 #include <ome/common/xml/dom/Document.h>
58 #include <ome/common/xml/dom/Element.h>
59 #include <ome/common/xml/dom/Node.h>
60 
61 #include <ome/xml/model/primitives/Quantity.h>
62 
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>
69 
70 namespace ome
71 {
72  namespace xml
73  {
74  namespace model
75  {
76 
77  // Forward declarations.
78  class OMEModel;
79  class PlateAcquisition;
80 
85  {
86  private:
87  class Impl;
89  std::shared_ptr<Impl> impl;
90 
91  public:
93  WellSample();
94 
100  WellSample (const WellSample& copy);
101 
103  virtual
104  ~WellSample ();
105 
120  static std::shared_ptr<WellSample>
121  create(const common::xml::dom::Element& element,
123 
124  // Documented in superclass.
125  const std::string&
126  elementName() const;
127 
128  // Documented in superclass.
129  bool
130  validElementName(const std::string& name) const;
131 
133  WellSample&
134  operator= (const WellSample&) = delete;
136 
137  // -- OMEModelObject API methods --
138 
140  virtual void
141  update(const common::xml::dom::Element& element,
143 
144  public:
145  // -- WellSample API methods --
146 
148  bool
149  link (std::shared_ptr<Reference>& reference,
150  std::shared_ptr<ome::xml::model::OMEModelObject>& object);
151 
158  getIndex () const;
159 
165  void
167 
173  std::shared_ptr<ome::xml::model::primitives::Quantity<ome::xml::model::enums::UnitsLength > >&
174  getPositionX ();
175 
181  const std::shared_ptr<ome::xml::model::primitives::Quantity<ome::xml::model::enums::UnitsLength > >&
182  getPositionX () const;
183 
189  void
191 
197  std::shared_ptr<ome::xml::model::primitives::Quantity<ome::xml::model::enums::UnitsLength > >&
198  getPositionY ();
199 
205  const std::shared_ptr<ome::xml::model::primitives::Quantity<ome::xml::model::enums::UnitsLength > >&
206  getPositionY () const;
207 
213  void
215 
221  std::shared_ptr<ome::xml::model::primitives::Timestamp>
222  getTimepoint ();
223 
229  const std::shared_ptr<ome::xml::model::primitives::Timestamp>
230  getTimepoint () const;
231 
237  void
238  setTimepoint (std::shared_ptr<ome::xml::model::primitives::Timestamp>& timepoint);
239 
245  const std::string&
246  getID () const;
247 
253  void
254  setID (const std::string& id);
255 
262  std::weak_ptr<ome::xml::model::Image>
263  getLinkedImage ();
264 
271  const std::weak_ptr<ome::xml::model::Image>
272  getLinkedImage () const;
273 
279  void
280  linkImage (std::shared_ptr<ome::xml::model::Image>& image);
281 
291  void
292  unlinkImage (std::shared_ptr<ome::xml::model::Image>& image);
293 
301 
309 
317  const std::weak_ptr<ome::xml::model::PlateAcquisition>&
319 
330  const std::weak_ptr<ome::xml::model::PlateAcquisition>&
332  const std::shared_ptr<ome::xml::model::PlateAcquisition>& plateAcquisition_BackReference);
333 
344  bool
345  linkPlateAcquisition (const std::shared_ptr<ome::xml::model::PlateAcquisition>& plateAcquisition_BackReference);
346 
362  bool
363  unlinkPlateAcquisition (const std::shared_ptr<ome::xml::model::PlateAcquisition>& plateAcquisition_BackReference);
364 
370  std::weak_ptr<ome::xml::model::Well>
371  getWell ();
372 
378  const std::weak_ptr<ome::xml::model::Well>
379  getWell () const;
380 
386  void
387  setWell (std::weak_ptr<ome::xml::model::Well>& well_BackReference);
388 
389  protected:
390  // Documented in base class.
391  virtual void
393  common::xml::dom::Element& element) const;
394 
395  public:
396  // Documented in superclass.
397  const std::string&
398  getXMLNamespace() const;
399  };
400 
401  }
402  }
403 }
404 
405 #endif // OME_XML_MODEL_WELLSAMPLE_H
406 
407 /*
408  * Local Variables:
409  * mode:C++
410  * End:
411  */
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