ome-xml  5.5.1
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 
132  private:
134  WellSample&
135  operator= (const WellSample&);
136 
137  public:
138  // -- OMEModelObject API methods --
139 
141  virtual void
142  update(const common::xml::dom::Element& element,
144 
145  public:
146  // -- WellSample API methods --
147 
149  bool
150  link (std::shared_ptr<Reference>& reference,
151  std::shared_ptr<ome::xml::model::OMEModelObject>& object);
152 
159  getIndex () const;
160 
166  void
168 
174  std::shared_ptr<ome::xml::model::primitives::Quantity<ome::xml::model::enums::UnitsLength > >&
175  getPositionX ();
176 
182  const std::shared_ptr<ome::xml::model::primitives::Quantity<ome::xml::model::enums::UnitsLength > >&
183  getPositionX () const;
184 
190  void
192 
198  std::shared_ptr<ome::xml::model::primitives::Quantity<ome::xml::model::enums::UnitsLength > >&
199  getPositionY ();
200 
206  const std::shared_ptr<ome::xml::model::primitives::Quantity<ome::xml::model::enums::UnitsLength > >&
207  getPositionY () const;
208 
214  void
216 
222  std::shared_ptr<ome::xml::model::primitives::Timestamp>
223  getTimepoint ();
224 
230  const std::shared_ptr<ome::xml::model::primitives::Timestamp>
231  getTimepoint () const;
232 
238  void
239  setTimepoint (std::shared_ptr<ome::xml::model::primitives::Timestamp>& timepoint);
240 
246  const std::string&
247  getID () const;
248 
254  void
255  setID (const std::string& id);
256 
263  std::weak_ptr<ome::xml::model::Image>
264  getLinkedImage ();
265 
272  const std::weak_ptr<ome::xml::model::Image>
273  getLinkedImage () const;
274 
280  void
281  linkImage (std::shared_ptr<ome::xml::model::Image>& image);
282 
292  void
293  unlinkImage (std::shared_ptr<ome::xml::model::Image>& image);
294 
302 
310 
318  const std::weak_ptr<ome::xml::model::PlateAcquisition>&
320 
331  const std::weak_ptr<ome::xml::model::PlateAcquisition>&
333  const std::shared_ptr<ome::xml::model::PlateAcquisition>& plateAcquisition_BackReference);
334 
345  bool
346  linkPlateAcquisition (const std::shared_ptr<ome::xml::model::PlateAcquisition>& plateAcquisition_BackReference);
347 
363  bool
364  unlinkPlateAcquisition (const std::shared_ptr<ome::xml::model::PlateAcquisition>& plateAcquisition_BackReference);
365 
371  std::weak_ptr<ome::xml::model::Well>
372  getWell ();
373 
379  const std::weak_ptr<ome::xml::model::Well>
380  getWell () const;
381 
387  void
388  setWell (std::weak_ptr<ome::xml::model::Well>& well_BackReference);
389 
390  protected:
391  // Documented in base class.
392  virtual void
394  common::xml::dom::Element& element) const;
395 
396  public:
397  // Documented in superclass.
398  const std::string&
399  getXMLNamespace() const;
400  };
401 
402  }
403  }
404 }
405 
406 #endif // OME_XML_MODEL_WELLSAMPLE_H
407 
408 /*
409  * Local Variables:
410  * mode:C++
411  * End:
412  */
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:324
bool linkPlateAcquisition(const std::shared_ptr< ome::xml::model::PlateAcquisition > &plateAcquisition_BackReference)
Link PlateAcquisition.
Definition: WellSample.cpp:465
void setID(const std::string &id)
Set the ID property.
Definition: WellSample.cpp:401
virtual 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:205
const ome::xml::model::primitives::NonNegativeInteger & getIndex() const
Get the Index property.
Definition: WellSample.cpp:317
bool unlinkPlateAcquisition(const std::shared_ptr< ome::xml::model::PlateAcquisition > &plateAcquisition_BackReference)
Unlink PlateAcquisition.
Definition: WellSample.cpp:478
WellSample & operator=(const WellSample &)
Assignment operator (deleted).
const std::string & getID() const
Get the ID property.
Definition: WellSample.cpp:394
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:449
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:443
std::weak_ptr< ome::xml::model::Well > getWell()
Get the Well property.
Definition: WellSample.cpp:495
virtual ~WellSample()
Destructor.
Definition: WellSample.cpp:178
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:183
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:455
void setTimepoint(std::shared_ptr< ome::xml::model::primitives::Timestamp > &timepoint)
Set the Timepoint property.
Definition: WellSample.cpp:387
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:291
bool validElementName(const std::string &name) const
Check if a given element name is valid for processing by this model object.
Definition: WellSample.cpp:199
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:345
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:437
void linkImage(std::shared_ptr< ome::xml::model::Image > &image)
Link Image.
Definition: WellSample.cpp:421
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:515
const std::string & getXMLNamespace() const
Get the XML namespace for this model object.
Definition: WellSample.cpp:591
const std::string & elementName() const
Get the element name of this model object.
Definition: WellSample.cpp:192
void setPositionY(const std::shared_ptr< ome::xml::model::primitives::Quantity< ome::xml::model::enums::UnitsLength > > &positionY)
Set the PositionY property.
Definition: WellSample.cpp:366
std::shared_ptr< ome::xml::model::primitives::Quantity< ome::xml::model::enums::UnitsLength > > & getPositionX()
Get the PositionX property.
Definition: WellSample.cpp:331
void setWell(std::weak_ptr< ome::xml::model::Well > &well_BackReference)
Set the Well property.
Definition: WellSample.cpp:509
std::shared_ptr< ome::xml::model::primitives::Timestamp > getTimepoint()
Get the Timepoint property.
Definition: WellSample.cpp:373
std::shared_ptr< ome::xml::model::primitives::Quantity< ome::xml::model::enums::UnitsLength > > & getPositionY()
Get the PositionY property.
Definition: WellSample.cpp:352
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:427
WellSample()
Default constructor.
Definition: WellSample.cpp:163
std::weak_ptr< ome::xml::model::Image > getLinkedImage()
Get linked Image.
Definition: WellSample.cpp:408
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