All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.hl7.fhir.r4.model.Location Maven / Gradle / Ivy

Go to download

Builds the hapi fhir r4. Requires hapi-fhir-base and hapi-fhir-utilities be built first and be excluded from any other poms requiring it.

The newest version!
package org.hl7.fhir.r4.model;

import java.math.BigDecimal;

/*
  Copyright (c) 2011+, HL7, Inc.
  All rights reserved.
  
  Redistribution and use in source and binary forms, with or without modification, 
  are permitted provided that the following conditions are met:
  
   * Redistributions of source code must retain the above copyright notice, this 
     list of conditions and the following disclaimer.
   * Redistributions in binary form must reproduce the above copyright notice, 
     this list of conditions and the following disclaimer in the documentation 
     and/or other materials provided with the distribution.
   * Neither the name of HL7 nor the names of its contributors may be used to 
     endorse or promote products derived from this software without specific 
     prior written permission.
  
  THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND 
  ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED 
  WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. 
  IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, 
  INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT 
  NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR 
  PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, 
  WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) 
  ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE 
  POSSIBILITY OF SUCH DAMAGE.
  
*/

// Generated on Tue, May 12, 2020 07:26+1000 for FHIR v4.0.1
import java.util.ArrayList;
import java.util.List;

import org.hl7.fhir.exceptions.FHIRException;
import org.hl7.fhir.instance.model.api.IBaseBackboneElement;
import org.hl7.fhir.utilities.Utilities;

import ca.uhn.fhir.model.api.annotation.Block;
import ca.uhn.fhir.model.api.annotation.Child;
import ca.uhn.fhir.model.api.annotation.Description;
import ca.uhn.fhir.model.api.annotation.ResourceDef;
import ca.uhn.fhir.model.api.annotation.SearchParamDefinition;

/**
 * Details and position information for a physical place where services are
 * provided and resources and participants may be stored, found, contained, or
 * accommodated.
 */
@ResourceDef(name = "Location", profile = "http://hl7.org/fhir/StructureDefinition/Location")
public class Location extends DomainResource {

  public enum LocationStatus {
    /**
     * The location is operational.
     */
    ACTIVE,
    /**
     * The location is temporarily closed.
     */
    SUSPENDED,
    /**
     * The location is no longer used.
     */
    INACTIVE,
    /**
     * added to help the parsers with the generic types
     */
    NULL;

    public static LocationStatus fromCode(String codeString) throws FHIRException {
      if (codeString == null || "".equals(codeString))
        return null;
      if ("active".equals(codeString))
        return ACTIVE;
      if ("suspended".equals(codeString))
        return SUSPENDED;
      if ("inactive".equals(codeString))
        return INACTIVE;
      if (Configuration.isAcceptInvalidEnums())
        return null;
      else
        throw new FHIRException("Unknown LocationStatus code '" + codeString + "'");
    }

    public String toCode() {
      switch (this) {
      case ACTIVE:
        return "active";
      case SUSPENDED:
        return "suspended";
      case INACTIVE:
        return "inactive";
      case NULL:
        return null;
      default:
        return "?";
      }
    }

    public String getSystem() {
      switch (this) {
      case ACTIVE:
        return "http://hl7.org/fhir/location-status";
      case SUSPENDED:
        return "http://hl7.org/fhir/location-status";
      case INACTIVE:
        return "http://hl7.org/fhir/location-status";
      case NULL:
        return null;
      default:
        return "?";
      }
    }

    public String getDefinition() {
      switch (this) {
      case ACTIVE:
        return "The location is operational.";
      case SUSPENDED:
        return "The location is temporarily closed.";
      case INACTIVE:
        return "The location is no longer used.";
      case NULL:
        return null;
      default:
        return "?";
      }
    }

    public String getDisplay() {
      switch (this) {
      case ACTIVE:
        return "Active";
      case SUSPENDED:
        return "Suspended";
      case INACTIVE:
        return "Inactive";
      case NULL:
        return null;
      default:
        return "?";
      }
    }
  }

  public static class LocationStatusEnumFactory implements EnumFactory {
    public LocationStatus fromCode(String codeString) throws IllegalArgumentException {
      if (codeString == null || "".equals(codeString))
        if (codeString == null || "".equals(codeString))
          return null;
      if ("active".equals(codeString))
        return LocationStatus.ACTIVE;
      if ("suspended".equals(codeString))
        return LocationStatus.SUSPENDED;
      if ("inactive".equals(codeString))
        return LocationStatus.INACTIVE;
      throw new IllegalArgumentException("Unknown LocationStatus code '" + codeString + "'");
    }

    public Enumeration fromType(PrimitiveType code) throws FHIRException {
      if (code == null)
        return null;
      if (code.isEmpty())
        return new Enumeration(this, LocationStatus.NULL, code);
      String codeString = code.asStringValue();
      if (codeString == null || "".equals(codeString))
        return new Enumeration(this, LocationStatus.NULL, code);
      if ("active".equals(codeString))
        return new Enumeration(this, LocationStatus.ACTIVE, code);
      if ("suspended".equals(codeString))
        return new Enumeration(this, LocationStatus.SUSPENDED, code);
      if ("inactive".equals(codeString))
        return new Enumeration(this, LocationStatus.INACTIVE, code);
      throw new FHIRException("Unknown LocationStatus code '" + codeString + "'");
    }

    public String toCode(LocationStatus code) {
      if (code == LocationStatus.ACTIVE)
        return "active";
      if (code == LocationStatus.SUSPENDED)
        return "suspended";
      if (code == LocationStatus.INACTIVE)
        return "inactive";
      return "?";
    }

    public String toSystem(LocationStatus code) {
      return code.getSystem();
    }
  }

  public enum LocationMode {
    /**
     * The Location resource represents a specific instance of a location (e.g.
     * Operating Theatre 1A).
     */
    INSTANCE,
    /**
     * The Location represents a class of locations (e.g. Any Operating Theatre)
     * although this class of locations could be constrained within a specific
     * boundary (such as organization, or parent location, address etc.).
     */
    KIND,
    /**
     * added to help the parsers with the generic types
     */
    NULL;

    public static LocationMode fromCode(String codeString) throws FHIRException {
      if (codeString == null || "".equals(codeString))
        return null;
      if ("instance".equals(codeString))
        return INSTANCE;
      if ("kind".equals(codeString))
        return KIND;
      if (Configuration.isAcceptInvalidEnums())
        return null;
      else
        throw new FHIRException("Unknown LocationMode code '" + codeString + "'");
    }

    public String toCode() {
      switch (this) {
      case INSTANCE:
        return "instance";
      case KIND:
        return "kind";
      case NULL:
        return null;
      default:
        return "?";
      }
    }

    public String getSystem() {
      switch (this) {
      case INSTANCE:
        return "http://hl7.org/fhir/location-mode";
      case KIND:
        return "http://hl7.org/fhir/location-mode";
      case NULL:
        return null;
      default:
        return "?";
      }
    }

    public String getDefinition() {
      switch (this) {
      case INSTANCE:
        return "The Location resource represents a specific instance of a location (e.g. Operating Theatre 1A).";
      case KIND:
        return "The Location represents a class of locations (e.g. Any Operating Theatre) although this class of locations could be constrained within a specific boundary (such as organization, or parent location, address etc.).";
      case NULL:
        return null;
      default:
        return "?";
      }
    }

    public String getDisplay() {
      switch (this) {
      case INSTANCE:
        return "Instance";
      case KIND:
        return "Kind";
      case NULL:
        return null;
      default:
        return "?";
      }
    }
  }

  public static class LocationModeEnumFactory implements EnumFactory {
    public LocationMode fromCode(String codeString) throws IllegalArgumentException {
      if (codeString == null || "".equals(codeString))
        if (codeString == null || "".equals(codeString))
          return null;
      if ("instance".equals(codeString))
        return LocationMode.INSTANCE;
      if ("kind".equals(codeString))
        return LocationMode.KIND;
      throw new IllegalArgumentException("Unknown LocationMode code '" + codeString + "'");
    }

    public Enumeration fromType(PrimitiveType code) throws FHIRException {
      if (code == null)
        return null;
      if (code.isEmpty())
        return new Enumeration(this, LocationMode.NULL, code);
      String codeString = code.asStringValue();
      if (codeString == null || "".equals(codeString))
        return new Enumeration(this, LocationMode.NULL, code);
      if ("instance".equals(codeString))
        return new Enumeration(this, LocationMode.INSTANCE, code);
      if ("kind".equals(codeString))
        return new Enumeration(this, LocationMode.KIND, code);
      throw new FHIRException("Unknown LocationMode code '" + codeString + "'");
    }

    public String toCode(LocationMode code) {
      if (code == LocationMode.INSTANCE)
        return "instance";
      if (code == LocationMode.KIND)
        return "kind";
      return "?";
    }

    public String toSystem(LocationMode code) {
      return code.getSystem();
    }
  }

  public enum DaysOfWeek {
    /**
     * Monday.
     */
    MON,
    /**
     * Tuesday.
     */
    TUE,
    /**
     * Wednesday.
     */
    WED,
    /**
     * Thursday.
     */
    THU,
    /**
     * Friday.
     */
    FRI,
    /**
     * Saturday.
     */
    SAT,
    /**
     * Sunday.
     */
    SUN,
    /**
     * added to help the parsers with the generic types
     */
    NULL;

    public static DaysOfWeek fromCode(String codeString) throws FHIRException {
      if (codeString == null || "".equals(codeString))
        return null;
      if ("mon".equals(codeString))
        return MON;
      if ("tue".equals(codeString))
        return TUE;
      if ("wed".equals(codeString))
        return WED;
      if ("thu".equals(codeString))
        return THU;
      if ("fri".equals(codeString))
        return FRI;
      if ("sat".equals(codeString))
        return SAT;
      if ("sun".equals(codeString))
        return SUN;
      if (Configuration.isAcceptInvalidEnums())
        return null;
      else
        throw new FHIRException("Unknown DaysOfWeek code '" + codeString + "'");
    }

    public String toCode() {
      switch (this) {
      case MON:
        return "mon";
      case TUE:
        return "tue";
      case WED:
        return "wed";
      case THU:
        return "thu";
      case FRI:
        return "fri";
      case SAT:
        return "sat";
      case SUN:
        return "sun";
      case NULL:
        return null;
      default:
        return "?";
      }
    }

    public String getSystem() {
      switch (this) {
      case MON:
        return "http://hl7.org/fhir/days-of-week";
      case TUE:
        return "http://hl7.org/fhir/days-of-week";
      case WED:
        return "http://hl7.org/fhir/days-of-week";
      case THU:
        return "http://hl7.org/fhir/days-of-week";
      case FRI:
        return "http://hl7.org/fhir/days-of-week";
      case SAT:
        return "http://hl7.org/fhir/days-of-week";
      case SUN:
        return "http://hl7.org/fhir/days-of-week";
      case NULL:
        return null;
      default:
        return "?";
      }
    }

    public String getDefinition() {
      switch (this) {
      case MON:
        return "Monday.";
      case TUE:
        return "Tuesday.";
      case WED:
        return "Wednesday.";
      case THU:
        return "Thursday.";
      case FRI:
        return "Friday.";
      case SAT:
        return "Saturday.";
      case SUN:
        return "Sunday.";
      case NULL:
        return null;
      default:
        return "?";
      }
    }

    public String getDisplay() {
      switch (this) {
      case MON:
        return "Monday";
      case TUE:
        return "Tuesday";
      case WED:
        return "Wednesday";
      case THU:
        return "Thursday";
      case FRI:
        return "Friday";
      case SAT:
        return "Saturday";
      case SUN:
        return "Sunday";
      case NULL:
        return null;
      default:
        return "?";
      }
    }
  }

  public static class DaysOfWeekEnumFactory implements EnumFactory {
    public DaysOfWeek fromCode(String codeString) throws IllegalArgumentException {
      if (codeString == null || "".equals(codeString))
        if (codeString == null || "".equals(codeString))
          return null;
      if ("mon".equals(codeString))
        return DaysOfWeek.MON;
      if ("tue".equals(codeString))
        return DaysOfWeek.TUE;
      if ("wed".equals(codeString))
        return DaysOfWeek.WED;
      if ("thu".equals(codeString))
        return DaysOfWeek.THU;
      if ("fri".equals(codeString))
        return DaysOfWeek.FRI;
      if ("sat".equals(codeString))
        return DaysOfWeek.SAT;
      if ("sun".equals(codeString))
        return DaysOfWeek.SUN;
      throw new IllegalArgumentException("Unknown DaysOfWeek code '" + codeString + "'");
    }

    public Enumeration fromType(PrimitiveType code) throws FHIRException {
      if (code == null)
        return null;
      if (code.isEmpty())
        return new Enumeration(this, DaysOfWeek.NULL, code);
      String codeString = code.asStringValue();
      if (codeString == null || "".equals(codeString))
        return new Enumeration(this, DaysOfWeek.NULL, code);
      if ("mon".equals(codeString))
        return new Enumeration(this, DaysOfWeek.MON, code);
      if ("tue".equals(codeString))
        return new Enumeration(this, DaysOfWeek.TUE, code);
      if ("wed".equals(codeString))
        return new Enumeration(this, DaysOfWeek.WED, code);
      if ("thu".equals(codeString))
        return new Enumeration(this, DaysOfWeek.THU, code);
      if ("fri".equals(codeString))
        return new Enumeration(this, DaysOfWeek.FRI, code);
      if ("sat".equals(codeString))
        return new Enumeration(this, DaysOfWeek.SAT, code);
      if ("sun".equals(codeString))
        return new Enumeration(this, DaysOfWeek.SUN, code);
      throw new FHIRException("Unknown DaysOfWeek code '" + codeString + "'");
    }

    public String toCode(DaysOfWeek code) {
      if (code == DaysOfWeek.MON)
        return "mon";
      if (code == DaysOfWeek.TUE)
        return "tue";
      if (code == DaysOfWeek.WED)
        return "wed";
      if (code == DaysOfWeek.THU)
        return "thu";
      if (code == DaysOfWeek.FRI)
        return "fri";
      if (code == DaysOfWeek.SAT)
        return "sat";
      if (code == DaysOfWeek.SUN)
        return "sun";
      return "?";
    }

    public String toSystem(DaysOfWeek code) {
      return code.getSystem();
    }
  }

  @Block()
  public static class LocationPositionComponent extends BackboneElement implements IBaseBackboneElement {
    /**
     * Longitude. The value domain and the interpretation are the same as for the
     * text of the longitude element in KML (see notes below).
     */
    @Child(name = "longitude", type = {
        DecimalType.class }, order = 1, min = 1, max = 1, modifier = false, summary = false)
    @Description(shortDefinition = "Longitude with WGS84 datum", formalDefinition = "Longitude. The value domain and the interpretation are the same as for the text of the longitude element in KML (see notes below).")
    protected DecimalType longitude;

    /**
     * Latitude. The value domain and the interpretation are the same as for the
     * text of the latitude element in KML (see notes below).
     */
    @Child(name = "latitude", type = {
        DecimalType.class }, order = 2, min = 1, max = 1, modifier = false, summary = false)
    @Description(shortDefinition = "Latitude with WGS84 datum", formalDefinition = "Latitude. The value domain and the interpretation are the same as for the text of the latitude element in KML (see notes below).")
    protected DecimalType latitude;

    /**
     * Altitude. The value domain and the interpretation are the same as for the
     * text of the altitude element in KML (see notes below).
     */
    @Child(name = "altitude", type = {
        DecimalType.class }, order = 3, min = 0, max = 1, modifier = false, summary = false)
    @Description(shortDefinition = "Altitude with WGS84 datum", formalDefinition = "Altitude. The value domain and the interpretation are the same as for the text of the altitude element in KML (see notes below).")
    protected DecimalType altitude;

    private static final long serialVersionUID = -74276134L;

    /**
     * Constructor
     */
    public LocationPositionComponent() {
      super();
    }

    /**
     * Constructor
     */
    public LocationPositionComponent(DecimalType longitude, DecimalType latitude) {
      super();
      this.longitude = longitude;
      this.latitude = latitude;
    }

    /**
     * @return {@link #longitude} (Longitude. The value domain and the
     *         interpretation are the same as for the text of the longitude element
     *         in KML (see notes below).). This is the underlying object with id,
     *         value and extensions. The accessor "getLongitude" gives direct access
     *         to the value
     */
    public DecimalType getLongitudeElement() {
      if (this.longitude == null)
        if (Configuration.errorOnAutoCreate())
          throw new Error("Attempt to auto-create LocationPositionComponent.longitude");
        else if (Configuration.doAutoCreate())
          this.longitude = new DecimalType(); // bb
      return this.longitude;
    }

    public boolean hasLongitudeElement() {
      return this.longitude != null && !this.longitude.isEmpty();
    }

    public boolean hasLongitude() {
      return this.longitude != null && !this.longitude.isEmpty();
    }

    /**
     * @param value {@link #longitude} (Longitude. The value domain and the
     *              interpretation are the same as for the text of the longitude
     *              element in KML (see notes below).). This is the underlying
     *              object with id, value and extensions. The accessor
     *              "getLongitude" gives direct access to the value
     */
    public LocationPositionComponent setLongitudeElement(DecimalType value) {
      this.longitude = value;
      return this;
    }

    /**
     * @return Longitude. The value domain and the interpretation are the same as
     *         for the text of the longitude element in KML (see notes below).
     */
    public BigDecimal getLongitude() {
      return this.longitude == null ? null : this.longitude.getValue();
    }

    /**
     * @param value Longitude. The value domain and the interpretation are the same
     *              as for the text of the longitude element in KML (see notes
     *              below).
     */
    public LocationPositionComponent setLongitude(BigDecimal value) {
      if (this.longitude == null)
        this.longitude = new DecimalType();
      this.longitude.setValue(value);
      return this;
    }

    /**
     * @param value Longitude. The value domain and the interpretation are the same
     *              as for the text of the longitude element in KML (see notes
     *              below).
     */
    public LocationPositionComponent setLongitude(long value) {
      this.longitude = new DecimalType();
      this.longitude.setValue(value);
      return this;
    }

    /**
     * @param value Longitude. The value domain and the interpretation are the same
     *              as for the text of the longitude element in KML (see notes
     *              below).
     */
    public LocationPositionComponent setLongitude(double value) {
      this.longitude = new DecimalType();
      this.longitude.setValue(value);
      return this;
    }

    /**
     * @return {@link #latitude} (Latitude. The value domain and the interpretation
     *         are the same as for the text of the latitude element in KML (see
     *         notes below).). This is the underlying object with id, value and
     *         extensions. The accessor "getLatitude" gives direct access to the
     *         value
     */
    public DecimalType getLatitudeElement() {
      if (this.latitude == null)
        if (Configuration.errorOnAutoCreate())
          throw new Error("Attempt to auto-create LocationPositionComponent.latitude");
        else if (Configuration.doAutoCreate())
          this.latitude = new DecimalType(); // bb
      return this.latitude;
    }

    public boolean hasLatitudeElement() {
      return this.latitude != null && !this.latitude.isEmpty();
    }

    public boolean hasLatitude() {
      return this.latitude != null && !this.latitude.isEmpty();
    }

    /**
     * @param value {@link #latitude} (Latitude. The value domain and the
     *              interpretation are the same as for the text of the latitude
     *              element in KML (see notes below).). This is the underlying
     *              object with id, value and extensions. The accessor "getLatitude"
     *              gives direct access to the value
     */
    public LocationPositionComponent setLatitudeElement(DecimalType value) {
      this.latitude = value;
      return this;
    }

    /**
     * @return Latitude. The value domain and the interpretation are the same as for
     *         the text of the latitude element in KML (see notes below).
     */
    public BigDecimal getLatitude() {
      return this.latitude == null ? null : this.latitude.getValue();
    }

    /**
     * @param value Latitude. The value domain and the interpretation are the same
     *              as for the text of the latitude element in KML (see notes
     *              below).
     */
    public LocationPositionComponent setLatitude(BigDecimal value) {
      if (this.latitude == null)
        this.latitude = new DecimalType();
      this.latitude.setValue(value);
      return this;
    }

    /**
     * @param value Latitude. The value domain and the interpretation are the same
     *              as for the text of the latitude element in KML (see notes
     *              below).
     */
    public LocationPositionComponent setLatitude(long value) {
      this.latitude = new DecimalType();
      this.latitude.setValue(value);
      return this;
    }

    /**
     * @param value Latitude. The value domain and the interpretation are the same
     *              as for the text of the latitude element in KML (see notes
     *              below).
     */
    public LocationPositionComponent setLatitude(double value) {
      this.latitude = new DecimalType();
      this.latitude.setValue(value);
      return this;
    }

    /**
     * @return {@link #altitude} (Altitude. The value domain and the interpretation
     *         are the same as for the text of the altitude element in KML (see
     *         notes below).). This is the underlying object with id, value and
     *         extensions. The accessor "getAltitude" gives direct access to the
     *         value
     */
    public DecimalType getAltitudeElement() {
      if (this.altitude == null)
        if (Configuration.errorOnAutoCreate())
          throw new Error("Attempt to auto-create LocationPositionComponent.altitude");
        else if (Configuration.doAutoCreate())
          this.altitude = new DecimalType(); // bb
      return this.altitude;
    }

    public boolean hasAltitudeElement() {
      return this.altitude != null && !this.altitude.isEmpty();
    }

    public boolean hasAltitude() {
      return this.altitude != null && !this.altitude.isEmpty();
    }

    /**
     * @param value {@link #altitude} (Altitude. The value domain and the
     *              interpretation are the same as for the text of the altitude
     *              element in KML (see notes below).). This is the underlying
     *              object with id, value and extensions. The accessor "getAltitude"
     *              gives direct access to the value
     */
    public LocationPositionComponent setAltitudeElement(DecimalType value) {
      this.altitude = value;
      return this;
    }

    /**
     * @return Altitude. The value domain and the interpretation are the same as for
     *         the text of the altitude element in KML (see notes below).
     */
    public BigDecimal getAltitude() {
      return this.altitude == null ? null : this.altitude.getValue();
    }

    /**
     * @param value Altitude. The value domain and the interpretation are the same
     *              as for the text of the altitude element in KML (see notes
     *              below).
     */
    public LocationPositionComponent setAltitude(BigDecimal value) {
      if (value == null)
        this.altitude = null;
      else {
        if (this.altitude == null)
          this.altitude = new DecimalType();
        this.altitude.setValue(value);
      }
      return this;
    }

    /**
     * @param value Altitude. The value domain and the interpretation are the same
     *              as for the text of the altitude element in KML (see notes
     *              below).
     */
    public LocationPositionComponent setAltitude(long value) {
      this.altitude = new DecimalType();
      this.altitude.setValue(value);
      return this;
    }

    /**
     * @param value Altitude. The value domain and the interpretation are the same
     *              as for the text of the altitude element in KML (see notes
     *              below).
     */
    public LocationPositionComponent setAltitude(double value) {
      this.altitude = new DecimalType();
      this.altitude.setValue(value);
      return this;
    }

    protected void listChildren(List children) {
      super.listChildren(children);
      children.add(new Property("longitude", "decimal",
          "Longitude. The value domain and the interpretation are the same as for the text of the longitude element in KML (see notes below).",
          0, 1, longitude));
      children.add(new Property("latitude", "decimal",
          "Latitude. The value domain and the interpretation are the same as for the text of the latitude element in KML (see notes below).",
          0, 1, latitude));
      children.add(new Property("altitude", "decimal",
          "Altitude. The value domain and the interpretation are the same as for the text of the altitude element in KML (see notes below).",
          0, 1, altitude));
    }

    @Override
    public Property getNamedProperty(int _hash, String _name, boolean _checkValid) throws FHIRException {
      switch (_hash) {
      case 137365935:
        /* longitude */ return new Property("longitude", "decimal",
            "Longitude. The value domain and the interpretation are the same as for the text of the longitude element in KML (see notes below).",
            0, 1, longitude);
      case -1439978388:
        /* latitude */ return new Property("latitude", "decimal",
            "Latitude. The value domain and the interpretation are the same as for the text of the latitude element in KML (see notes below).",
            0, 1, latitude);
      case 2036550306:
        /* altitude */ return new Property("altitude", "decimal",
            "Altitude. The value domain and the interpretation are the same as for the text of the altitude element in KML (see notes below).",
            0, 1, altitude);
      default:
        return super.getNamedProperty(_hash, _name, _checkValid);
      }

    }

    @Override
    public Base[] getProperty(int hash, String name, boolean checkValid) throws FHIRException {
      switch (hash) {
      case 137365935:
        /* longitude */ return this.longitude == null ? new Base[0] : new Base[] { this.longitude }; // DecimalType
      case -1439978388:
        /* latitude */ return this.latitude == null ? new Base[0] : new Base[] { this.latitude }; // DecimalType
      case 2036550306:
        /* altitude */ return this.altitude == null ? new Base[0] : new Base[] { this.altitude }; // DecimalType
      default:
        return super.getProperty(hash, name, checkValid);
      }

    }

    @Override
    public Base setProperty(int hash, String name, Base value) throws FHIRException {
      switch (hash) {
      case 137365935: // longitude
        this.longitude = castToDecimal(value); // DecimalType
        return value;
      case -1439978388: // latitude
        this.latitude = castToDecimal(value); // DecimalType
        return value;
      case 2036550306: // altitude
        this.altitude = castToDecimal(value); // DecimalType
        return value;
      default:
        return super.setProperty(hash, name, value);
      }

    }

    @Override
    public Base setProperty(String name, Base value) throws FHIRException {
      if (name.equals("longitude")) {
        this.longitude = castToDecimal(value); // DecimalType
      } else if (name.equals("latitude")) {
        this.latitude = castToDecimal(value); // DecimalType
      } else if (name.equals("altitude")) {
        this.altitude = castToDecimal(value); // DecimalType
      } else
        return super.setProperty(name, value);
      return value;
    }

  @Override
  public void removeChild(String name, Base value) throws FHIRException {
      if (name.equals("longitude")) {
        this.longitude = null;
      } else if (name.equals("latitude")) {
        this.latitude = null;
      } else if (name.equals("altitude")) {
        this.altitude = null;
      } else
        super.removeChild(name, value);
      
    }

    @Override
    public Base makeProperty(int hash, String name) throws FHIRException {
      switch (hash) {
      case 137365935:
        return getLongitudeElement();
      case -1439978388:
        return getLatitudeElement();
      case 2036550306:
        return getAltitudeElement();
      default:
        return super.makeProperty(hash, name);
      }

    }

    @Override
    public String[] getTypesForProperty(int hash, String name) throws FHIRException {
      switch (hash) {
      case 137365935:
        /* longitude */ return new String[] { "decimal" };
      case -1439978388:
        /* latitude */ return new String[] { "decimal" };
      case 2036550306:
        /* altitude */ return new String[] { "decimal" };
      default:
        return super.getTypesForProperty(hash, name);
      }

    }

    @Override
    public Base addChild(String name) throws FHIRException {
      if (name.equals("longitude")) {
        throw new FHIRException("Cannot call addChild on a singleton property Location.longitude");
      } else if (name.equals("latitude")) {
        throw new FHIRException("Cannot call addChild on a singleton property Location.latitude");
      } else if (name.equals("altitude")) {
        throw new FHIRException("Cannot call addChild on a singleton property Location.altitude");
      } else
        return super.addChild(name);
    }

    public LocationPositionComponent copy() {
      LocationPositionComponent dst = new LocationPositionComponent();
      copyValues(dst);
      return dst;
    }

    public void copyValues(LocationPositionComponent dst) {
      super.copyValues(dst);
      dst.longitude = longitude == null ? null : longitude.copy();
      dst.latitude = latitude == null ? null : latitude.copy();
      dst.altitude = altitude == null ? null : altitude.copy();
    }

    @Override
    public boolean equalsDeep(Base other_) {
      if (!super.equalsDeep(other_))
        return false;
      if (!(other_ instanceof LocationPositionComponent))
        return false;
      LocationPositionComponent o = (LocationPositionComponent) other_;
      return compareDeep(longitude, o.longitude, true) && compareDeep(latitude, o.latitude, true)
          && compareDeep(altitude, o.altitude, true);
    }

    @Override
    public boolean equalsShallow(Base other_) {
      if (!super.equalsShallow(other_))
        return false;
      if (!(other_ instanceof LocationPositionComponent))
        return false;
      LocationPositionComponent o = (LocationPositionComponent) other_;
      return compareValues(longitude, o.longitude, true) && compareValues(latitude, o.latitude, true)
          && compareValues(altitude, o.altitude, true);
    }

    public boolean isEmpty() {
      return super.isEmpty() && ca.uhn.fhir.util.ElementUtil.isEmpty(longitude, latitude, altitude);
    }

    public String fhirType() {
      return "Location.position";

    }

  }

  @Block()
  public static class LocationHoursOfOperationComponent extends BackboneElement implements IBaseBackboneElement {
    /**
     * Indicates which days of the week are available between the start and end
     * Times.
     */
    @Child(name = "daysOfWeek", type = {
        CodeType.class }, order = 1, min = 0, max = Child.MAX_UNLIMITED, modifier = false, summary = false)
    @Description(shortDefinition = "mon | tue | wed | thu | fri | sat | sun", formalDefinition = "Indicates which days of the week are available between the start and end Times.")
    @ca.uhn.fhir.model.api.annotation.Binding(valueSet = "http://hl7.org/fhir/ValueSet/days-of-week")
    protected List> daysOfWeek;

    /**
     * The Location is open all day.
     */
    @Child(name = "allDay", type = {
        BooleanType.class }, order = 2, min = 0, max = 1, modifier = false, summary = false)
    @Description(shortDefinition = "The Location is open all day", formalDefinition = "The Location is open all day.")
    protected BooleanType allDay;

    /**
     * Time that the Location opens.
     */
    @Child(name = "openingTime", type = {
        TimeType.class }, order = 3, min = 0, max = 1, modifier = false, summary = false)
    @Description(shortDefinition = "Time that the Location opens", formalDefinition = "Time that the Location opens.")
    protected TimeType openingTime;

    /**
     * Time that the Location closes.
     */
    @Child(name = "closingTime", type = {
        TimeType.class }, order = 4, min = 0, max = 1, modifier = false, summary = false)
    @Description(shortDefinition = "Time that the Location closes", formalDefinition = "Time that the Location closes.")
    protected TimeType closingTime;

    private static final long serialVersionUID = -932551849L;

    /**
     * Constructor
     */
    public LocationHoursOfOperationComponent() {
      super();
    }

    /**
     * @return {@link #daysOfWeek} (Indicates which days of the week are available
     *         between the start and end Times.)
     */
    public List> getDaysOfWeek() {
      if (this.daysOfWeek == null)
        this.daysOfWeek = new ArrayList>();
      return this.daysOfWeek;
    }

    /**
     * @return Returns a reference to this for easy method chaining
     */
    public LocationHoursOfOperationComponent setDaysOfWeek(List> theDaysOfWeek) {
      this.daysOfWeek = theDaysOfWeek;
      return this;
    }

    public boolean hasDaysOfWeek() {
      if (this.daysOfWeek == null)
        return false;
      for (Enumeration item : this.daysOfWeek)
        if (!item.isEmpty())
          return true;
      return false;
    }

    /**
     * @return {@link #daysOfWeek} (Indicates which days of the week are available
     *         between the start and end Times.)
     */
    public Enumeration addDaysOfWeekElement() {// 2
      Enumeration t = new Enumeration(new DaysOfWeekEnumFactory());
      if (this.daysOfWeek == null)
        this.daysOfWeek = new ArrayList>();
      this.daysOfWeek.add(t);
      return t;
    }

    /**
     * @param value {@link #daysOfWeek} (Indicates which days of the week are
     *              available between the start and end Times.)
     */
    public LocationHoursOfOperationComponent addDaysOfWeek(DaysOfWeek value) { // 1
      Enumeration t = new Enumeration(new DaysOfWeekEnumFactory());
      t.setValue(value);
      if (this.daysOfWeek == null)
        this.daysOfWeek = new ArrayList>();
      this.daysOfWeek.add(t);
      return this;
    }

    /**
     * @param value {@link #daysOfWeek} (Indicates which days of the week are
     *              available between the start and end Times.)
     */
    public boolean hasDaysOfWeek(DaysOfWeek value) {
      if (this.daysOfWeek == null)
        return false;
      for (Enumeration v : this.daysOfWeek)
        if (v.getValue().equals(value)) // code
          return true;
      return false;
    }

    /**
     * @return {@link #allDay} (The Location is open all day.). This is the
     *         underlying object with id, value and extensions. The accessor
     *         "getAllDay" gives direct access to the value
     */
    public BooleanType getAllDayElement() {
      if (this.allDay == null)
        if (Configuration.errorOnAutoCreate())
          throw new Error("Attempt to auto-create LocationHoursOfOperationComponent.allDay");
        else if (Configuration.doAutoCreate())
          this.allDay = new BooleanType(); // bb
      return this.allDay;
    }

    public boolean hasAllDayElement() {
      return this.allDay != null && !this.allDay.isEmpty();
    }

    public boolean hasAllDay() {
      return this.allDay != null && !this.allDay.isEmpty();
    }

    /**
     * @param value {@link #allDay} (The Location is open all day.). This is the
     *              underlying object with id, value and extensions. The accessor
     *              "getAllDay" gives direct access to the value
     */
    public LocationHoursOfOperationComponent setAllDayElement(BooleanType value) {
      this.allDay = value;
      return this;
    }

    /**
     * @return The Location is open all day.
     */
    public boolean getAllDay() {
      return this.allDay == null || this.allDay.isEmpty() ? false : this.allDay.getValue();
    }

    /**
     * @param value The Location is open all day.
     */
    public LocationHoursOfOperationComponent setAllDay(boolean value) {
      if (this.allDay == null)
        this.allDay = new BooleanType();
      this.allDay.setValue(value);
      return this;
    }

    /**
     * @return {@link #openingTime} (Time that the Location opens.). This is the
     *         underlying object with id, value and extensions. The accessor
     *         "getOpeningTime" gives direct access to the value
     */
    public TimeType getOpeningTimeElement() {
      if (this.openingTime == null)
        if (Configuration.errorOnAutoCreate())
          throw new Error("Attempt to auto-create LocationHoursOfOperationComponent.openingTime");
        else if (Configuration.doAutoCreate())
          this.openingTime = new TimeType(); // bb
      return this.openingTime;
    }

    public boolean hasOpeningTimeElement() {
      return this.openingTime != null && !this.openingTime.isEmpty();
    }

    public boolean hasOpeningTime() {
      return this.openingTime != null && !this.openingTime.isEmpty();
    }

    /**
     * @param value {@link #openingTime} (Time that the Location opens.). This is
     *              the underlying object with id, value and extensions. The
     *              accessor "getOpeningTime" gives direct access to the value
     */
    public LocationHoursOfOperationComponent setOpeningTimeElement(TimeType value) {
      this.openingTime = value;
      return this;
    }

    /**
     * @return Time that the Location opens.
     */
    public String getOpeningTime() {
      return this.openingTime == null ? null : this.openingTime.getValue();
    }

    /**
     * @param value Time that the Location opens.
     */
    public LocationHoursOfOperationComponent setOpeningTime(String value) {
      if (value == null)
        this.openingTime = null;
      else {
        if (this.openingTime == null)
          this.openingTime = new TimeType();
        this.openingTime.setValue(value);
      }
      return this;
    }

    /**
     * @return {@link #closingTime} (Time that the Location closes.). This is the
     *         underlying object with id, value and extensions. The accessor
     *         "getClosingTime" gives direct access to the value
     */
    public TimeType getClosingTimeElement() {
      if (this.closingTime == null)
        if (Configuration.errorOnAutoCreate())
          throw new Error("Attempt to auto-create LocationHoursOfOperationComponent.closingTime");
        else if (Configuration.doAutoCreate())
          this.closingTime = new TimeType(); // bb
      return this.closingTime;
    }

    public boolean hasClosingTimeElement() {
      return this.closingTime != null && !this.closingTime.isEmpty();
    }

    public boolean hasClosingTime() {
      return this.closingTime != null && !this.closingTime.isEmpty();
    }

    /**
     * @param value {@link #closingTime} (Time that the Location closes.). This is
     *              the underlying object with id, value and extensions. The
     *              accessor "getClosingTime" gives direct access to the value
     */
    public LocationHoursOfOperationComponent setClosingTimeElement(TimeType value) {
      this.closingTime = value;
      return this;
    }

    /**
     * @return Time that the Location closes.
     */
    public String getClosingTime() {
      return this.closingTime == null ? null : this.closingTime.getValue();
    }

    /**
     * @param value Time that the Location closes.
     */
    public LocationHoursOfOperationComponent setClosingTime(String value) {
      if (value == null)
        this.closingTime = null;
      else {
        if (this.closingTime == null)
          this.closingTime = new TimeType();
        this.closingTime.setValue(value);
      }
      return this;
    }

    protected void listChildren(List children) {
      super.listChildren(children);
      children.add(new Property("daysOfWeek", "code",
          "Indicates which days of the week are available between the start and end Times.", 0,
          java.lang.Integer.MAX_VALUE, daysOfWeek));
      children.add(new Property("allDay", "boolean", "The Location is open all day.", 0, 1, allDay));
      children.add(new Property("openingTime", "time", "Time that the Location opens.", 0, 1, openingTime));
      children.add(new Property("closingTime", "time", "Time that the Location closes.", 0, 1, closingTime));
    }

    @Override
    public Property getNamedProperty(int _hash, String _name, boolean _checkValid) throws FHIRException {
      switch (_hash) {
      case 68050338:
        /* daysOfWeek */ return new Property("daysOfWeek", "code",
            "Indicates which days of the week are available between the start and end Times.", 0,
            java.lang.Integer.MAX_VALUE, daysOfWeek);
      case -1414913477:
        /* allDay */ return new Property("allDay", "boolean", "The Location is open all day.", 0, 1, allDay);
      case 84062277:
        /* openingTime */ return new Property("openingTime", "time", "Time that the Location opens.", 0, 1,
            openingTime);
      case 188137762:
        /* closingTime */ return new Property("closingTime", "time", "Time that the Location closes.", 0, 1,
            closingTime);
      default:
        return super.getNamedProperty(_hash, _name, _checkValid);
      }

    }

    @Override
    public Base[] getProperty(int hash, String name, boolean checkValid) throws FHIRException {
      switch (hash) {
      case 68050338:
        /* daysOfWeek */ return this.daysOfWeek == null ? new Base[0]
            : this.daysOfWeek.toArray(new Base[this.daysOfWeek.size()]); // Enumeration
      case -1414913477:
        /* allDay */ return this.allDay == null ? new Base[0] : new Base[] { this.allDay }; // BooleanType
      case 84062277:
        /* openingTime */ return this.openingTime == null ? new Base[0] : new Base[] { this.openingTime }; // TimeType
      case 188137762:
        /* closingTime */ return this.closingTime == null ? new Base[0] : new Base[] { this.closingTime }; // TimeType
      default:
        return super.getProperty(hash, name, checkValid);
      }

    }

    @Override
    public Base setProperty(int hash, String name, Base value) throws FHIRException {
      switch (hash) {
      case 68050338: // daysOfWeek
        value = new DaysOfWeekEnumFactory().fromType(castToCode(value));
        this.getDaysOfWeek().add((Enumeration) value); // Enumeration
        return value;
      case -1414913477: // allDay
        this.allDay = castToBoolean(value); // BooleanType
        return value;
      case 84062277: // openingTime
        this.openingTime = castToTime(value); // TimeType
        return value;
      case 188137762: // closingTime
        this.closingTime = castToTime(value); // TimeType
        return value;
      default:
        return super.setProperty(hash, name, value);
      }

    }

    @Override
    public Base setProperty(String name, Base value) throws FHIRException {
      if (name.equals("daysOfWeek")) {
        value = new DaysOfWeekEnumFactory().fromType(castToCode(value));
        this.getDaysOfWeek().add((Enumeration) value);
      } else if (name.equals("allDay")) {
        this.allDay = castToBoolean(value); // BooleanType
      } else if (name.equals("openingTime")) {
        this.openingTime = castToTime(value); // TimeType
      } else if (name.equals("closingTime")) {
        this.closingTime = castToTime(value); // TimeType
      } else
        return super.setProperty(name, value);
      return value;
    }

  @Override
  public void removeChild(String name, Base value) throws FHIRException {
      if (name.equals("daysOfWeek")) {
        this.getDaysOfWeek().remove((Enumeration) value);
      } else if (name.equals("allDay")) {
        this.allDay = null;
      } else if (name.equals("openingTime")) {
        this.openingTime = null;
      } else if (name.equals("closingTime")) {
        this.closingTime = null;
      } else
        super.removeChild(name, value);
      
    }

    @Override
    public Base makeProperty(int hash, String name) throws FHIRException {
      switch (hash) {
      case 68050338:
        return addDaysOfWeekElement();
      case -1414913477:
        return getAllDayElement();
      case 84062277:
        return getOpeningTimeElement();
      case 188137762:
        return getClosingTimeElement();
      default:
        return super.makeProperty(hash, name);
      }

    }

    @Override
    public String[] getTypesForProperty(int hash, String name) throws FHIRException {
      switch (hash) {
      case 68050338:
        /* daysOfWeek */ return new String[] { "code" };
      case -1414913477:
        /* allDay */ return new String[] { "boolean" };
      case 84062277:
        /* openingTime */ return new String[] { "time" };
      case 188137762:
        /* closingTime */ return new String[] { "time" };
      default:
        return super.getTypesForProperty(hash, name);
      }

    }

    @Override
    public Base addChild(String name) throws FHIRException {
      if (name.equals("daysOfWeek")) {
        throw new FHIRException("Cannot call addChild on a singleton property Location.daysOfWeek");
      } else if (name.equals("allDay")) {
        throw new FHIRException("Cannot call addChild on a singleton property Location.allDay");
      } else if (name.equals("openingTime")) {
        throw new FHIRException("Cannot call addChild on a singleton property Location.openingTime");
      } else if (name.equals("closingTime")) {
        throw new FHIRException("Cannot call addChild on a singleton property Location.closingTime");
      } else
        return super.addChild(name);
    }

    public LocationHoursOfOperationComponent copy() {
      LocationHoursOfOperationComponent dst = new LocationHoursOfOperationComponent();
      copyValues(dst);
      return dst;
    }

    public void copyValues(LocationHoursOfOperationComponent dst) {
      super.copyValues(dst);
      if (daysOfWeek != null) {
        dst.daysOfWeek = new ArrayList>();
        for (Enumeration i : daysOfWeek)
          dst.daysOfWeek.add(i.copy());
      }
      ;
      dst.allDay = allDay == null ? null : allDay.copy();
      dst.openingTime = openingTime == null ? null : openingTime.copy();
      dst.closingTime = closingTime == null ? null : closingTime.copy();
    }

    @Override
    public boolean equalsDeep(Base other_) {
      if (!super.equalsDeep(other_))
        return false;
      if (!(other_ instanceof LocationHoursOfOperationComponent))
        return false;
      LocationHoursOfOperationComponent o = (LocationHoursOfOperationComponent) other_;
      return compareDeep(daysOfWeek, o.daysOfWeek, true) && compareDeep(allDay, o.allDay, true)
          && compareDeep(openingTime, o.openingTime, true) && compareDeep(closingTime, o.closingTime, true);
    }

    @Override
    public boolean equalsShallow(Base other_) {
      if (!super.equalsShallow(other_))
        return false;
      if (!(other_ instanceof LocationHoursOfOperationComponent))
        return false;
      LocationHoursOfOperationComponent o = (LocationHoursOfOperationComponent) other_;
      return compareValues(daysOfWeek, o.daysOfWeek, true) && compareValues(allDay, o.allDay, true)
          && compareValues(openingTime, o.openingTime, true) && compareValues(closingTime, o.closingTime, true);
    }

    public boolean isEmpty() {
      return super.isEmpty() && ca.uhn.fhir.util.ElementUtil.isEmpty(daysOfWeek, allDay, openingTime, closingTime);
    }

    public String fhirType() {
      return "Location.hoursOfOperation";

    }

  }

  /**
   * Unique code or number identifying the location to its users.
   */
  @Child(name = "identifier", type = {
      Identifier.class }, order = 0, min = 0, max = Child.MAX_UNLIMITED, modifier = false, summary = true)
  @Description(shortDefinition = "Unique code or number identifying the location to its users", formalDefinition = "Unique code or number identifying the location to its users.")
  protected List identifier;

  /**
   * The status property covers the general availability of the resource, not the
   * current value which may be covered by the operationStatus, or by a
   * schedule/slots if they are configured for the location.
   */
  @Child(name = "status", type = { CodeType.class }, order = 1, min = 0, max = 1, modifier = true, summary = true)
  @Description(shortDefinition = "active | suspended | inactive", formalDefinition = "The status property covers the general availability of the resource, not the current value which may be covered by the operationStatus, or by a schedule/slots if they are configured for the location.")
  @ca.uhn.fhir.model.api.annotation.Binding(valueSet = "http://hl7.org/fhir/ValueSet/location-status")
  protected Enumeration status;

  /**
   * The operational status covers operation values most relevant to beds (but can
   * also apply to rooms/units/chairs/etc. such as an isolation unit/dialysis
   * chair). This typically covers concepts such as contamination, housekeeping,
   * and other activities like maintenance.
   */
  @Child(name = "operationalStatus", type = {
      Coding.class }, order = 2, min = 0, max = 1, modifier = false, summary = true)
  @Description(shortDefinition = "The operational status of the location (typically only for a bed/room)", formalDefinition = "The operational status covers operation values most relevant to beds (but can also apply to rooms/units/chairs/etc. such as an isolation unit/dialysis chair). This typically covers concepts such as contamination, housekeeping, and other activities like maintenance.")
  @ca.uhn.fhir.model.api.annotation.Binding(valueSet = "http://terminology.hl7.org/ValueSet/v2-0116")
  protected Coding operationalStatus;

  /**
   * Name of the location as used by humans. Does not need to be unique.
   */
  @Child(name = "name", type = { StringType.class }, order = 3, min = 0, max = 1, modifier = false, summary = true)
  @Description(shortDefinition = "Name of the location as used by humans", formalDefinition = "Name of the location as used by humans. Does not need to be unique.")
  protected StringType name;

  /**
   * A list of alternate names that the location is known as, or was known as, in
   * the past.
   */
  @Child(name = "alias", type = {
      StringType.class }, order = 4, min = 0, max = Child.MAX_UNLIMITED, modifier = false, summary = false)
  @Description(shortDefinition = "A list of alternate names that the location is known as, or was known as, in the past", formalDefinition = "A list of alternate names that the location is known as, or was known as, in the past.")
  protected List alias;

  /**
   * Description of the Location, which helps in finding or referencing the place.
   */
  @Child(name = "description", type = {
      StringType.class }, order = 5, min = 0, max = 1, modifier = false, summary = true)
  @Description(shortDefinition = "Additional details about the location that could be displayed as further information to identify the location beyond its name", formalDefinition = "Description of the Location, which helps in finding or referencing the place.")
  protected StringType description;

  /**
   * Indicates whether a resource instance represents a specific location or a
   * class of locations.
   */
  @Child(name = "mode", type = { CodeType.class }, order = 6, min = 0, max = 1, modifier = false, summary = true)
  @Description(shortDefinition = "instance | kind", formalDefinition = "Indicates whether a resource instance represents a specific location or a class of locations.")
  @ca.uhn.fhir.model.api.annotation.Binding(valueSet = "http://hl7.org/fhir/ValueSet/location-mode")
  protected Enumeration mode;

  /**
   * Indicates the type of function performed at the location.
   */
  @Child(name = "type", type = {
      CodeableConcept.class }, order = 7, min = 0, max = Child.MAX_UNLIMITED, modifier = false, summary = true)
  @Description(shortDefinition = "Type of function performed", formalDefinition = "Indicates the type of function performed at the location.")
  @ca.uhn.fhir.model.api.annotation.Binding(valueSet = "http://terminology.hl7.org/ValueSet/v3-ServiceDeliveryLocationRoleType")
  protected List type;

  /**
   * The contact details of communication devices available at the location. This
   * can include phone numbers, fax numbers, mobile numbers, email addresses and
   * web sites.
   */
  @Child(name = "telecom", type = {
      ContactPoint.class }, order = 8, min = 0, max = Child.MAX_UNLIMITED, modifier = false, summary = false)
  @Description(shortDefinition = "Contact details of the location", formalDefinition = "The contact details of communication devices available at the location. This can include phone numbers, fax numbers, mobile numbers, email addresses and web sites.")
  protected List telecom;

  /**
   * Physical location.
   */
  @Child(name = "address", type = { Address.class }, order = 9, min = 0, max = 1, modifier = false, summary = false)
  @Description(shortDefinition = "Physical location", formalDefinition = "Physical location.")
  protected Address address;

  /**
   * Physical form of the location, e.g. building, room, vehicle, road.
   */
  @Child(name = "physicalType", type = {
      CodeableConcept.class }, order = 10, min = 0, max = 1, modifier = false, summary = true)
  @Description(shortDefinition = "Physical form of the location", formalDefinition = "Physical form of the location, e.g. building, room, vehicle, road.")
  @ca.uhn.fhir.model.api.annotation.Binding(valueSet = "http://hl7.org/fhir/ValueSet/location-physical-type")
  protected CodeableConcept physicalType;

  /**
   * The absolute geographic location of the Location, expressed using the WGS84
   * datum (This is the same co-ordinate system used in KML).
   */
  @Child(name = "position", type = {}, order = 11, min = 0, max = 1, modifier = false, summary = false)
  @Description(shortDefinition = "The absolute geographic location", formalDefinition = "The absolute geographic location of the Location, expressed using the WGS84 datum (This is the same co-ordinate system used in KML).")
  protected LocationPositionComponent position;

  /**
   * The organization responsible for the provisioning and upkeep of the location.
   */
  @Child(name = "managingOrganization", type = {
      Organization.class }, order = 12, min = 0, max = 1, modifier = false, summary = true)
  @Description(shortDefinition = "Organization responsible for provisioning and upkeep", formalDefinition = "The organization responsible for the provisioning and upkeep of the location.")
  protected Reference managingOrganization;

  /**
   * The actual object that is the target of the reference (The organization
   * responsible for the provisioning and upkeep of the location.)
   */
  protected Organization managingOrganizationTarget;

  /**
   * Another Location of which this Location is physically a part of.
   */
  @Child(name = "partOf", type = { Location.class }, order = 13, min = 0, max = 1, modifier = false, summary = false)
  @Description(shortDefinition = "Another Location this one is physically a part of", formalDefinition = "Another Location of which this Location is physically a part of.")
  protected Reference partOf;

  /**
   * The actual object that is the target of the reference (Another Location of
   * which this Location is physically a part of.)
   */
  protected Location partOfTarget;

  /**
   * What days/times during a week is this location usually open.
   */
  @Child(name = "hoursOfOperation", type = {}, order = 14, min = 0, max = Child.MAX_UNLIMITED, modifier = false, summary = false)
  @Description(shortDefinition = "What days/times during a week is this location usually open", formalDefinition = "What days/times during a week is this location usually open.")
  protected List hoursOfOperation;

  /**
   * A description of when the locations opening ours are different to normal,
   * e.g. public holiday availability. Succinctly describing all possible
   * exceptions to normal site availability as detailed in the opening hours
   * Times.
   */
  @Child(name = "availabilityExceptions", type = {
      StringType.class }, order = 15, min = 0, max = 1, modifier = false, summary = false)
  @Description(shortDefinition = "Description of availability exceptions", formalDefinition = "A description of when the locations opening ours are different to normal, e.g. public holiday availability. Succinctly describing all possible exceptions to normal site availability as detailed in the opening hours Times.")
  protected StringType availabilityExceptions;

  /**
   * Technical endpoints providing access to services operated for the location.
   */
  @Child(name = "endpoint", type = {
      Endpoint.class }, order = 16, min = 0, max = Child.MAX_UNLIMITED, modifier = false, summary = false)
  @Description(shortDefinition = "Technical endpoints providing access to services operated for the location", formalDefinition = "Technical endpoints providing access to services operated for the location.")
  protected List endpoint;
  /**
   * The actual objects that are the target of the reference (Technical endpoints
   * providing access to services operated for the location.)
   */
  protected List endpointTarget;

  private static final long serialVersionUID = -2126621333L;

  /**
   * Constructor
   */
  public Location() {
    super();
  }

  /**
   * @return {@link #identifier} (Unique code or number identifying the location
   *         to its users.)
   */
  public List getIdentifier() {
    if (this.identifier == null)
      this.identifier = new ArrayList();
    return this.identifier;
  }

  /**
   * @return Returns a reference to this for easy method chaining
   */
  public Location setIdentifier(List theIdentifier) {
    this.identifier = theIdentifier;
    return this;
  }

  public boolean hasIdentifier() {
    if (this.identifier == null)
      return false;
    for (Identifier item : this.identifier)
      if (!item.isEmpty())
        return true;
    return false;
  }

  public Identifier addIdentifier() { // 3
    Identifier t = new Identifier();
    if (this.identifier == null)
      this.identifier = new ArrayList();
    this.identifier.add(t);
    return t;
  }

  public Location addIdentifier(Identifier t) { // 3
    if (t == null)
      return this;
    if (this.identifier == null)
      this.identifier = new ArrayList();
    this.identifier.add(t);
    return this;
  }

  /**
   * @return The first repetition of repeating field {@link #identifier}, creating
   *         it if it does not already exist
   */
  public Identifier getIdentifierFirstRep() {
    if (getIdentifier().isEmpty()) {
      addIdentifier();
    }
    return getIdentifier().get(0);
  }

  /**
   * @return {@link #status} (The status property covers the general availability
   *         of the resource, not the current value which may be covered by the
   *         operationStatus, or by a schedule/slots if they are configured for
   *         the location.). This is the underlying object with id, value and
   *         extensions. The accessor "getStatus" gives direct access to the value
   */
  public Enumeration getStatusElement() {
    if (this.status == null)
      if (Configuration.errorOnAutoCreate())
        throw new Error("Attempt to auto-create Location.status");
      else if (Configuration.doAutoCreate())
        this.status = new Enumeration(new LocationStatusEnumFactory()); // bb
    return this.status;
  }

  public boolean hasStatusElement() {
    return this.status != null && !this.status.isEmpty();
  }

  public boolean hasStatus() {
    return this.status != null && !this.status.isEmpty();
  }

  /**
   * @param value {@link #status} (The status property covers the general
   *              availability of the resource, not the current value which may be
   *              covered by the operationStatus, or by a schedule/slots if they
   *              are configured for the location.). This is the underlying object
   *              with id, value and extensions. The accessor "getStatus" gives
   *              direct access to the value
   */
  public Location setStatusElement(Enumeration value) {
    this.status = value;
    return this;
  }

  /**
   * @return The status property covers the general availability of the resource,
   *         not the current value which may be covered by the operationStatus, or
   *         by a schedule/slots if they are configured for the location.
   */
  public LocationStatus getStatus() {
    return this.status == null ? null : this.status.getValue();
  }

  /**
   * @param value The status property covers the general availability of the
   *              resource, not the current value which may be covered by the
   *              operationStatus, or by a schedule/slots if they are configured
   *              for the location.
   */
  public Location setStatus(LocationStatus value) {
    if (value == null)
      this.status = null;
    else {
      if (this.status == null)
        this.status = new Enumeration(new LocationStatusEnumFactory());
      this.status.setValue(value);
    }
    return this;
  }

  /**
   * @return {@link #operationalStatus} (The operational status covers operation
   *         values most relevant to beds (but can also apply to
   *         rooms/units/chairs/etc. such as an isolation unit/dialysis chair).
   *         This typically covers concepts such as contamination, housekeeping,
   *         and other activities like maintenance.)
   */
  public Coding getOperationalStatus() {
    if (this.operationalStatus == null)
      if (Configuration.errorOnAutoCreate())
        throw new Error("Attempt to auto-create Location.operationalStatus");
      else if (Configuration.doAutoCreate())
        this.operationalStatus = new Coding(); // cc
    return this.operationalStatus;
  }

  public boolean hasOperationalStatus() {
    return this.operationalStatus != null && !this.operationalStatus.isEmpty();
  }

  /**
   * @param value {@link #operationalStatus} (The operational status covers
   *              operation values most relevant to beds (but can also apply to
   *              rooms/units/chairs/etc. such as an isolation unit/dialysis
   *              chair). This typically covers concepts such as contamination,
   *              housekeeping, and other activities like maintenance.)
   */
  public Location setOperationalStatus(Coding value) {
    this.operationalStatus = value;
    return this;
  }

  /**
   * @return {@link #name} (Name of the location as used by humans. Does not need
   *         to be unique.). This is the underlying object with id, value and
   *         extensions. The accessor "getName" gives direct access to the value
   */
  public StringType getNameElement() {
    if (this.name == null)
      if (Configuration.errorOnAutoCreate())
        throw new Error("Attempt to auto-create Location.name");
      else if (Configuration.doAutoCreate())
        this.name = new StringType(); // bb
    return this.name;
  }

  public boolean hasNameElement() {
    return this.name != null && !this.name.isEmpty();
  }

  public boolean hasName() {
    return this.name != null && !this.name.isEmpty();
  }

  /**
   * @param value {@link #name} (Name of the location as used by humans. Does not
   *              need to be unique.). This is the underlying object with id,
   *              value and extensions. The accessor "getName" gives direct access
   *              to the value
   */
  public Location setNameElement(StringType value) {
    this.name = value;
    return this;
  }

  /**
   * @return Name of the location as used by humans. Does not need to be unique.
   */
  public String getName() {
    return this.name == null ? null : this.name.getValue();
  }

  /**
   * @param value Name of the location as used by humans. Does not need to be
   *              unique.
   */
  public Location setName(String value) {
    if (Utilities.noString(value))
      this.name = null;
    else {
      if (this.name == null)
        this.name = new StringType();
      this.name.setValue(value);
    }
    return this;
  }

  /**
   * @return {@link #alias} (A list of alternate names that the location is known
   *         as, or was known as, in the past.)
   */
  public List getAlias() {
    if (this.alias == null)
      this.alias = new ArrayList();
    return this.alias;
  }

  /**
   * @return Returns a reference to this for easy method chaining
   */
  public Location setAlias(List theAlias) {
    this.alias = theAlias;
    return this;
  }

  public boolean hasAlias() {
    if (this.alias == null)
      return false;
    for (StringType item : this.alias)
      if (!item.isEmpty())
        return true;
    return false;
  }

  /**
   * @return {@link #alias} (A list of alternate names that the location is known
   *         as, or was known as, in the past.)
   */
  public StringType addAliasElement() {// 2
    StringType t = new StringType();
    if (this.alias == null)
      this.alias = new ArrayList();
    this.alias.add(t);
    return t;
  }

  /**
   * @param value {@link #alias} (A list of alternate names that the location is
   *              known as, or was known as, in the past.)
   */
  public Location addAlias(String value) { // 1
    StringType t = new StringType();
    t.setValue(value);
    if (this.alias == null)
      this.alias = new ArrayList();
    this.alias.add(t);
    return this;
  }

  /**
   * @param value {@link #alias} (A list of alternate names that the location is
   *              known as, or was known as, in the past.)
   */
  public boolean hasAlias(String value) {
    if (this.alias == null)
      return false;
    for (StringType v : this.alias)
      if (v.getValue().equals(value)) // string
        return true;
    return false;
  }

  /**
   * @return {@link #description} (Description of the Location, which helps in
   *         finding or referencing the place.). This is the underlying object
   *         with id, value and extensions. The accessor "getDescription" gives
   *         direct access to the value
   */
  public StringType getDescriptionElement() {
    if (this.description == null)
      if (Configuration.errorOnAutoCreate())
        throw new Error("Attempt to auto-create Location.description");
      else if (Configuration.doAutoCreate())
        this.description = new StringType(); // bb
    return this.description;
  }

  public boolean hasDescriptionElement() {
    return this.description != null && !this.description.isEmpty();
  }

  public boolean hasDescription() {
    return this.description != null && !this.description.isEmpty();
  }

  /**
   * @param value {@link #description} (Description of the Location, which helps
   *              in finding or referencing the place.). This is the underlying
   *              object with id, value and extensions. The accessor
   *              "getDescription" gives direct access to the value
   */
  public Location setDescriptionElement(StringType value) {
    this.description = value;
    return this;
  }

  /**
   * @return Description of the Location, which helps in finding or referencing
   *         the place.
   */
  public String getDescription() {
    return this.description == null ? null : this.description.getValue();
  }

  /**
   * @param value Description of the Location, which helps in finding or
   *              referencing the place.
   */
  public Location setDescription(String value) {
    if (Utilities.noString(value))
      this.description = null;
    else {
      if (this.description == null)
        this.description = new StringType();
      this.description.setValue(value);
    }
    return this;
  }

  /**
   * @return {@link #mode} (Indicates whether a resource instance represents a
   *         specific location or a class of locations.). This is the underlying
   *         object with id, value and extensions. The accessor "getMode" gives
   *         direct access to the value
   */
  public Enumeration getModeElement() {
    if (this.mode == null)
      if (Configuration.errorOnAutoCreate())
        throw new Error("Attempt to auto-create Location.mode");
      else if (Configuration.doAutoCreate())
        this.mode = new Enumeration(new LocationModeEnumFactory()); // bb
    return this.mode;
  }

  public boolean hasModeElement() {
    return this.mode != null && !this.mode.isEmpty();
  }

  public boolean hasMode() {
    return this.mode != null && !this.mode.isEmpty();
  }

  /**
   * @param value {@link #mode} (Indicates whether a resource instance represents
   *              a specific location or a class of locations.). This is the
   *              underlying object with id, value and extensions. The accessor
   *              "getMode" gives direct access to the value
   */
  public Location setModeElement(Enumeration value) {
    this.mode = value;
    return this;
  }

  /**
   * @return Indicates whether a resource instance represents a specific location
   *         or a class of locations.
   */
  public LocationMode getMode() {
    return this.mode == null ? null : this.mode.getValue();
  }

  /**
   * @param value Indicates whether a resource instance represents a specific
   *              location or a class of locations.
   */
  public Location setMode(LocationMode value) {
    if (value == null)
      this.mode = null;
    else {
      if (this.mode == null)
        this.mode = new Enumeration(new LocationModeEnumFactory());
      this.mode.setValue(value);
    }
    return this;
  }

  /**
   * @return {@link #type} (Indicates the type of function performed at the
   *         location.)
   */
  public List getType() {
    if (this.type == null)
      this.type = new ArrayList();
    return this.type;
  }

  /**
   * @return Returns a reference to this for easy method chaining
   */
  public Location setType(List theType) {
    this.type = theType;
    return this;
  }

  public boolean hasType() {
    if (this.type == null)
      return false;
    for (CodeableConcept item : this.type)
      if (!item.isEmpty())
        return true;
    return false;
  }

  public CodeableConcept addType() { // 3
    CodeableConcept t = new CodeableConcept();
    if (this.type == null)
      this.type = new ArrayList();
    this.type.add(t);
    return t;
  }

  public Location addType(CodeableConcept t) { // 3
    if (t == null)
      return this;
    if (this.type == null)
      this.type = new ArrayList();
    this.type.add(t);
    return this;
  }

  /**
   * @return The first repetition of repeating field {@link #type}, creating it if
   *         it does not already exist
   */
  public CodeableConcept getTypeFirstRep() {
    if (getType().isEmpty()) {
      addType();
    }
    return getType().get(0);
  }

  /**
   * @return {@link #telecom} (The contact details of communication devices
   *         available at the location. This can include phone numbers, fax
   *         numbers, mobile numbers, email addresses and web sites.)
   */
  public List getTelecom() {
    if (this.telecom == null)
      this.telecom = new ArrayList();
    return this.telecom;
  }

  /**
   * @return Returns a reference to this for easy method chaining
   */
  public Location setTelecom(List theTelecom) {
    this.telecom = theTelecom;
    return this;
  }

  public boolean hasTelecom() {
    if (this.telecom == null)
      return false;
    for (ContactPoint item : this.telecom)
      if (!item.isEmpty())
        return true;
    return false;
  }

  public ContactPoint addTelecom() { // 3
    ContactPoint t = new ContactPoint();
    if (this.telecom == null)
      this.telecom = new ArrayList();
    this.telecom.add(t);
    return t;
  }

  public Location addTelecom(ContactPoint t) { // 3
    if (t == null)
      return this;
    if (this.telecom == null)
      this.telecom = new ArrayList();
    this.telecom.add(t);
    return this;
  }

  /**
   * @return The first repetition of repeating field {@link #telecom}, creating it
   *         if it does not already exist
   */
  public ContactPoint getTelecomFirstRep() {
    if (getTelecom().isEmpty()) {
      addTelecom();
    }
    return getTelecom().get(0);
  }

  /**
   * @return {@link #address} (Physical location.)
   */
  public Address getAddress() {
    if (this.address == null)
      if (Configuration.errorOnAutoCreate())
        throw new Error("Attempt to auto-create Location.address");
      else if (Configuration.doAutoCreate())
        this.address = new Address(); // cc
    return this.address;
  }

  public boolean hasAddress() {
    return this.address != null && !this.address.isEmpty();
  }

  /**
   * @param value {@link #address} (Physical location.)
   */
  public Location setAddress(Address value) {
    this.address = value;
    return this;
  }

  /**
   * @return {@link #physicalType} (Physical form of the location, e.g. building,
   *         room, vehicle, road.)
   */
  public CodeableConcept getPhysicalType() {
    if (this.physicalType == null)
      if (Configuration.errorOnAutoCreate())
        throw new Error("Attempt to auto-create Location.physicalType");
      else if (Configuration.doAutoCreate())
        this.physicalType = new CodeableConcept(); // cc
    return this.physicalType;
  }

  public boolean hasPhysicalType() {
    return this.physicalType != null && !this.physicalType.isEmpty();
  }

  /**
   * @param value {@link #physicalType} (Physical form of the location, e.g.
   *              building, room, vehicle, road.)
   */
  public Location setPhysicalType(CodeableConcept value) {
    this.physicalType = value;
    return this;
  }

  /**
   * @return {@link #position} (The absolute geographic location of the Location,
   *         expressed using the WGS84 datum (This is the same co-ordinate system
   *         used in KML).)
   */
  public LocationPositionComponent getPosition() {
    if (this.position == null)
      if (Configuration.errorOnAutoCreate())
        throw new Error("Attempt to auto-create Location.position");
      else if (Configuration.doAutoCreate())
        this.position = new LocationPositionComponent(); // cc
    return this.position;
  }

  public boolean hasPosition() {
    return this.position != null && !this.position.isEmpty();
  }

  /**
   * @param value {@link #position} (The absolute geographic location of the
   *              Location, expressed using the WGS84 datum (This is the same
   *              co-ordinate system used in KML).)
   */
  public Location setPosition(LocationPositionComponent value) {
    this.position = value;
    return this;
  }

  /**
   * @return {@link #managingOrganization} (The organization responsible for the
   *         provisioning and upkeep of the location.)
   */
  public Reference getManagingOrganization() {
    if (this.managingOrganization == null)
      if (Configuration.errorOnAutoCreate())
        throw new Error("Attempt to auto-create Location.managingOrganization");
      else if (Configuration.doAutoCreate())
        this.managingOrganization = new Reference(); // cc
    return this.managingOrganization;
  }

  public boolean hasManagingOrganization() {
    return this.managingOrganization != null && !this.managingOrganization.isEmpty();
  }

  /**
   * @param value {@link #managingOrganization} (The organization responsible for
   *              the provisioning and upkeep of the location.)
   */
  public Location setManagingOrganization(Reference value) {
    this.managingOrganization = value;
    return this;
  }

  /**
   * @return {@link #managingOrganization} The actual object that is the target of
   *         the reference. The reference library doesn't populate this, but you
   *         can use it to hold the resource if you resolve it. (The organization
   *         responsible for the provisioning and upkeep of the location.)
   */
  public Organization getManagingOrganizationTarget() {
    if (this.managingOrganizationTarget == null)
      if (Configuration.errorOnAutoCreate())
        throw new Error("Attempt to auto-create Location.managingOrganization");
      else if (Configuration.doAutoCreate())
        this.managingOrganizationTarget = new Organization(); // aa
    return this.managingOrganizationTarget;
  }

  /**
   * @param value {@link #managingOrganization} The actual object that is the
   *              target of the reference. The reference library doesn't use
   *              these, but you can use it to hold the resource if you resolve
   *              it. (The organization responsible for the provisioning and
   *              upkeep of the location.)
   */
  public Location setManagingOrganizationTarget(Organization value) {
    this.managingOrganizationTarget = value;
    return this;
  }

  /**
   * @return {@link #partOf} (Another Location of which this Location is
   *         physically a part of.)
   */
  public Reference getPartOf() {
    if (this.partOf == null)
      if (Configuration.errorOnAutoCreate())
        throw new Error("Attempt to auto-create Location.partOf");
      else if (Configuration.doAutoCreate())
        this.partOf = new Reference(); // cc
    return this.partOf;
  }

  public boolean hasPartOf() {
    return this.partOf != null && !this.partOf.isEmpty();
  }

  /**
   * @param value {@link #partOf} (Another Location of which this Location is
   *              physically a part of.)
   */
  public Location setPartOf(Reference value) {
    this.partOf = value;
    return this;
  }

  /**
   * @return {@link #partOf} The actual object that is the target of the
   *         reference. The reference library doesn't populate this, but you can
   *         use it to hold the resource if you resolve it. (Another Location of
   *         which this Location is physically a part of.)
   */
  public Location getPartOfTarget() {
    if (this.partOfTarget == null)
      if (Configuration.errorOnAutoCreate())
        throw new Error("Attempt to auto-create Location.partOf");
      else if (Configuration.doAutoCreate())
        this.partOfTarget = new Location(); // aa
    return this.partOfTarget;
  }

  /**
   * @param value {@link #partOf} The actual object that is the target of the
   *              reference. The reference library doesn't use these, but you can
   *              use it to hold the resource if you resolve it. (Another Location
   *              of which this Location is physically a part of.)
   */
  public Location setPartOfTarget(Location value) {
    this.partOfTarget = value;
    return this;
  }

  /**
   * @return {@link #hoursOfOperation} (What days/times during a week is this
   *         location usually open.)
   */
  public List getHoursOfOperation() {
    if (this.hoursOfOperation == null)
      this.hoursOfOperation = new ArrayList();
    return this.hoursOfOperation;
  }

  /**
   * @return Returns a reference to this for easy method chaining
   */
  public Location setHoursOfOperation(List theHoursOfOperation) {
    this.hoursOfOperation = theHoursOfOperation;
    return this;
  }

  public boolean hasHoursOfOperation() {
    if (this.hoursOfOperation == null)
      return false;
    for (LocationHoursOfOperationComponent item : this.hoursOfOperation)
      if (!item.isEmpty())
        return true;
    return false;
  }

  public LocationHoursOfOperationComponent addHoursOfOperation() { // 3
    LocationHoursOfOperationComponent t = new LocationHoursOfOperationComponent();
    if (this.hoursOfOperation == null)
      this.hoursOfOperation = new ArrayList();
    this.hoursOfOperation.add(t);
    return t;
  }

  public Location addHoursOfOperation(LocationHoursOfOperationComponent t) { // 3
    if (t == null)
      return this;
    if (this.hoursOfOperation == null)
      this.hoursOfOperation = new ArrayList();
    this.hoursOfOperation.add(t);
    return this;
  }

  /**
   * @return The first repetition of repeating field {@link #hoursOfOperation},
   *         creating it if it does not already exist
   */
  public LocationHoursOfOperationComponent getHoursOfOperationFirstRep() {
    if (getHoursOfOperation().isEmpty()) {
      addHoursOfOperation();
    }
    return getHoursOfOperation().get(0);
  }

  /**
   * @return {@link #availabilityExceptions} (A description of when the locations
   *         opening ours are different to normal, e.g. public holiday
   *         availability. Succinctly describing all possible exceptions to normal
   *         site availability as detailed in the opening hours Times.). This is
   *         the underlying object with id, value and extensions. The accessor
   *         "getAvailabilityExceptions" gives direct access to the value
   */
  public StringType getAvailabilityExceptionsElement() {
    if (this.availabilityExceptions == null)
      if (Configuration.errorOnAutoCreate())
        throw new Error("Attempt to auto-create Location.availabilityExceptions");
      else if (Configuration.doAutoCreate())
        this.availabilityExceptions = new StringType(); // bb
    return this.availabilityExceptions;
  }

  public boolean hasAvailabilityExceptionsElement() {
    return this.availabilityExceptions != null && !this.availabilityExceptions.isEmpty();
  }

  public boolean hasAvailabilityExceptions() {
    return this.availabilityExceptions != null && !this.availabilityExceptions.isEmpty();
  }

  /**
   * @param value {@link #availabilityExceptions} (A description of when the
   *              locations opening ours are different to normal, e.g. public
   *              holiday availability. Succinctly describing all possible
   *              exceptions to normal site availability as detailed in the
   *              opening hours Times.). This is the underlying object with id,
   *              value and extensions. The accessor "getAvailabilityExceptions"
   *              gives direct access to the value
   */
  public Location setAvailabilityExceptionsElement(StringType value) {
    this.availabilityExceptions = value;
    return this;
  }

  /**
   * @return A description of when the locations opening ours are different to
   *         normal, e.g. public holiday availability. Succinctly describing all
   *         possible exceptions to normal site availability as detailed in the
   *         opening hours Times.
   */
  public String getAvailabilityExceptions() {
    return this.availabilityExceptions == null ? null : this.availabilityExceptions.getValue();
  }

  /**
   * @param value A description of when the locations opening ours are different
   *              to normal, e.g. public holiday availability. Succinctly
   *              describing all possible exceptions to normal site availability
   *              as detailed in the opening hours Times.
   */
  public Location setAvailabilityExceptions(String value) {
    if (Utilities.noString(value))
      this.availabilityExceptions = null;
    else {
      if (this.availabilityExceptions == null)
        this.availabilityExceptions = new StringType();
      this.availabilityExceptions.setValue(value);
    }
    return this;
  }

  /**
   * @return {@link #endpoint} (Technical endpoints providing access to services
   *         operated for the location.)
   */
  public List getEndpoint() {
    if (this.endpoint == null)
      this.endpoint = new ArrayList();
    return this.endpoint;
  }

  /**
   * @return Returns a reference to this for easy method chaining
   */
  public Location setEndpoint(List theEndpoint) {
    this.endpoint = theEndpoint;
    return this;
  }

  public boolean hasEndpoint() {
    if (this.endpoint == null)
      return false;
    for (Reference item : this.endpoint)
      if (!item.isEmpty())
        return true;
    return false;
  }

  public Reference addEndpoint() { // 3
    Reference t = new Reference();
    if (this.endpoint == null)
      this.endpoint = new ArrayList();
    this.endpoint.add(t);
    return t;
  }

  public Location addEndpoint(Reference t) { // 3
    if (t == null)
      return this;
    if (this.endpoint == null)
      this.endpoint = new ArrayList();
    this.endpoint.add(t);
    return this;
  }

  /**
   * @return The first repetition of repeating field {@link #endpoint}, creating
   *         it if it does not already exist
   */
  public Reference getEndpointFirstRep() {
    if (getEndpoint().isEmpty()) {
      addEndpoint();
    }
    return getEndpoint().get(0);
  }

  /**
   * @deprecated Use Reference#setResource(IBaseResource) instead
   */
  @Deprecated
  public List getEndpointTarget() {
    if (this.endpointTarget == null)
      this.endpointTarget = new ArrayList();
    return this.endpointTarget;
  }

  /**
   * @deprecated Use Reference#setResource(IBaseResource) instead
   */
  @Deprecated
  public Endpoint addEndpointTarget() {
    Endpoint r = new Endpoint();
    if (this.endpointTarget == null)
      this.endpointTarget = new ArrayList();
    this.endpointTarget.add(r);
    return r;
  }

  protected void listChildren(List children) {
    super.listChildren(children);
    children.add(new Property("identifier", "Identifier",
        "Unique code or number identifying the location to its users.", 0, java.lang.Integer.MAX_VALUE, identifier));
    children.add(new Property("status", "code",
        "The status property covers the general availability of the resource, not the current value which may be covered by the operationStatus, or by a schedule/slots if they are configured for the location.",
        0, 1, status));
    children.add(new Property("operationalStatus", "Coding",
        "The operational status covers operation values most relevant to beds (but can also apply to rooms/units/chairs/etc. such as an isolation unit/dialysis chair). This typically covers concepts such as contamination, housekeeping, and other activities like maintenance.",
        0, 1, operationalStatus));
    children.add(new Property("name", "string", "Name of the location as used by humans. Does not need to be unique.",
        0, 1, name));
    children.add(new Property("alias", "string",
        "A list of alternate names that the location is known as, or was known as, in the past.", 0,
        java.lang.Integer.MAX_VALUE, alias));
    children.add(new Property("description", "string",
        "Description of the Location, which helps in finding or referencing the place.", 0, 1, description));
    children.add(new Property("mode", "code",
        "Indicates whether a resource instance represents a specific location or a class of locations.", 0, 1, mode));
    children.add(new Property("type", "CodeableConcept", "Indicates the type of function performed at the location.", 0,
        java.lang.Integer.MAX_VALUE, type));
    children.add(new Property("telecom", "ContactPoint",
        "The contact details of communication devices available at the location. This can include phone numbers, fax numbers, mobile numbers, email addresses and web sites.",
        0, java.lang.Integer.MAX_VALUE, telecom));
    children.add(new Property("address", "Address", "Physical location.", 0, 1, address));
    children.add(new Property("physicalType", "CodeableConcept",
        "Physical form of the location, e.g. building, room, vehicle, road.", 0, 1, physicalType));
    children.add(new Property("position", "",
        "The absolute geographic location of the Location, expressed using the WGS84 datum (This is the same co-ordinate system used in KML).",
        0, 1, position));
    children.add(new Property("managingOrganization", "Reference(Organization)",
        "The organization responsible for the provisioning and upkeep of the location.", 0, 1, managingOrganization));
    children.add(new Property("partOf", "Reference(Location)",
        "Another Location of which this Location is physically a part of.", 0, 1, partOf));
    children.add(new Property("hoursOfOperation", "", "What days/times during a week is this location usually open.", 0,
        java.lang.Integer.MAX_VALUE, hoursOfOperation));
    children.add(new Property("availabilityExceptions", "string",
        "A description of when the locations opening ours are different to normal, e.g. public holiday availability. Succinctly describing all possible exceptions to normal site availability as detailed in the opening hours Times.",
        0, 1, availabilityExceptions));
    children.add(new Property("endpoint", "Reference(Endpoint)",
        "Technical endpoints providing access to services operated for the location.", 0, java.lang.Integer.MAX_VALUE,
        endpoint));
  }

  @Override
  public Property getNamedProperty(int _hash, String _name, boolean _checkValid) throws FHIRException {
    switch (_hash) {
    case -1618432855:
      /* identifier */ return new Property("identifier", "Identifier",
          "Unique code or number identifying the location to its users.", 0, java.lang.Integer.MAX_VALUE, identifier);
    case -892481550:
      /* status */ return new Property("status", "code",
          "The status property covers the general availability of the resource, not the current value which may be covered by the operationStatus, or by a schedule/slots if they are configured for the location.",
          0, 1, status);
    case -2103166364:
      /* operationalStatus */ return new Property("operationalStatus", "Coding",
          "The operational status covers operation values most relevant to beds (but can also apply to rooms/units/chairs/etc. such as an isolation unit/dialysis chair). This typically covers concepts such as contamination, housekeeping, and other activities like maintenance.",
          0, 1, operationalStatus);
    case 3373707:
      /* name */ return new Property("name", "string",
          "Name of the location as used by humans. Does not need to be unique.", 0, 1, name);
    case 92902992:
      /* alias */ return new Property("alias", "string",
          "A list of alternate names that the location is known as, or was known as, in the past.", 0,
          java.lang.Integer.MAX_VALUE, alias);
    case -1724546052:
      /* description */ return new Property("description", "string",
          "Description of the Location, which helps in finding or referencing the place.", 0, 1, description);
    case 3357091:
      /* mode */ return new Property("mode", "code",
          "Indicates whether a resource instance represents a specific location or a class of locations.", 0, 1, mode);
    case 3575610:
      /* type */ return new Property("type", "CodeableConcept",
          "Indicates the type of function performed at the location.", 0, java.lang.Integer.MAX_VALUE, type);
    case -1429363305:
      /* telecom */ return new Property("telecom", "ContactPoint",
          "The contact details of communication devices available at the location. This can include phone numbers, fax numbers, mobile numbers, email addresses and web sites.",
          0, java.lang.Integer.MAX_VALUE, telecom);
    case -1147692044:
      /* address */ return new Property("address", "Address", "Physical location.", 0, 1, address);
    case -1474715471:
      /* physicalType */ return new Property("physicalType", "CodeableConcept",
          "Physical form of the location, e.g. building, room, vehicle, road.", 0, 1, physicalType);
    case 747804969:
      /* position */ return new Property("position", "",
          "The absolute geographic location of the Location, expressed using the WGS84 datum (This is the same co-ordinate system used in KML).",
          0, 1, position);
    case -2058947787:
      /* managingOrganization */ return new Property("managingOrganization", "Reference(Organization)",
          "The organization responsible for the provisioning and upkeep of the location.", 0, 1, managingOrganization);
    case -995410646:
      /* partOf */ return new Property("partOf", "Reference(Location)",
          "Another Location of which this Location is physically a part of.", 0, 1, partOf);
    case -1588872511:
      /* hoursOfOperation */ return new Property("hoursOfOperation", "",
          "What days/times during a week is this location usually open.", 0, java.lang.Integer.MAX_VALUE,
          hoursOfOperation);
    case -1149143617:
      /* availabilityExceptions */ return new Property("availabilityExceptions", "string",
          "A description of when the locations opening ours are different to normal, e.g. public holiday availability. Succinctly describing all possible exceptions to normal site availability as detailed in the opening hours Times.",
          0, 1, availabilityExceptions);
    case 1741102485:
      /* endpoint */ return new Property("endpoint", "Reference(Endpoint)",
          "Technical endpoints providing access to services operated for the location.", 0, java.lang.Integer.MAX_VALUE,
          endpoint);
    default:
      return super.getNamedProperty(_hash, _name, _checkValid);
    }

  }

  @Override
  public Base[] getProperty(int hash, String name, boolean checkValid) throws FHIRException {
    switch (hash) {
    case -1618432855:
      /* identifier */ return this.identifier == null ? new Base[0]
          : this.identifier.toArray(new Base[this.identifier.size()]); // Identifier
    case -892481550:
      /* status */ return this.status == null ? new Base[0] : new Base[] { this.status }; // Enumeration
    case -2103166364:
      /* operationalStatus */ return this.operationalStatus == null ? new Base[0]
          : new Base[] { this.operationalStatus }; // Coding
    case 3373707:
      /* name */ return this.name == null ? new Base[0] : new Base[] { this.name }; // StringType
    case 92902992:
      /* alias */ return this.alias == null ? new Base[0] : this.alias.toArray(new Base[this.alias.size()]); // StringType
    case -1724546052:
      /* description */ return this.description == null ? new Base[0] : new Base[] { this.description }; // StringType
    case 3357091:
      /* mode */ return this.mode == null ? new Base[0] : new Base[] { this.mode }; // Enumeration
    case 3575610:
      /* type */ return this.type == null ? new Base[0] : this.type.toArray(new Base[this.type.size()]); // CodeableConcept
    case -1429363305:
      /* telecom */ return this.telecom == null ? new Base[0] : this.telecom.toArray(new Base[this.telecom.size()]); // ContactPoint
    case -1147692044:
      /* address */ return this.address == null ? new Base[0] : new Base[] { this.address }; // Address
    case -1474715471:
      /* physicalType */ return this.physicalType == null ? new Base[0] : new Base[] { this.physicalType }; // CodeableConcept
    case 747804969:
      /* position */ return this.position == null ? new Base[0] : new Base[] { this.position }; // LocationPositionComponent
    case -2058947787:
      /* managingOrganization */ return this.managingOrganization == null ? new Base[0]
          : new Base[] { this.managingOrganization }; // Reference
    case -995410646:
      /* partOf */ return this.partOf == null ? new Base[0] : new Base[] { this.partOf }; // Reference
    case -1588872511:
      /* hoursOfOperation */ return this.hoursOfOperation == null ? new Base[0]
          : this.hoursOfOperation.toArray(new Base[this.hoursOfOperation.size()]); // LocationHoursOfOperationComponent
    case -1149143617:
      /* availabilityExceptions */ return this.availabilityExceptions == null ? new Base[0]
          : new Base[] { this.availabilityExceptions }; // StringType
    case 1741102485:
      /* endpoint */ return this.endpoint == null ? new Base[0] : this.endpoint.toArray(new Base[this.endpoint.size()]); // Reference
    default:
      return super.getProperty(hash, name, checkValid);
    }

  }

  @Override
  public Base setProperty(int hash, String name, Base value) throws FHIRException {
    switch (hash) {
    case -1618432855: // identifier
      this.getIdentifier().add(castToIdentifier(value)); // Identifier
      return value;
    case -892481550: // status
      value = new LocationStatusEnumFactory().fromType(castToCode(value));
      this.status = (Enumeration) value; // Enumeration
      return value;
    case -2103166364: // operationalStatus
      this.operationalStatus = castToCoding(value); // Coding
      return value;
    case 3373707: // name
      this.name = castToString(value); // StringType
      return value;
    case 92902992: // alias
      this.getAlias().add(castToString(value)); // StringType
      return value;
    case -1724546052: // description
      this.description = castToString(value); // StringType
      return value;
    case 3357091: // mode
      value = new LocationModeEnumFactory().fromType(castToCode(value));
      this.mode = (Enumeration) value; // Enumeration
      return value;
    case 3575610: // type
      this.getType().add(castToCodeableConcept(value)); // CodeableConcept
      return value;
    case -1429363305: // telecom
      this.getTelecom().add(castToContactPoint(value)); // ContactPoint
      return value;
    case -1147692044: // address
      this.address = castToAddress(value); // Address
      return value;
    case -1474715471: // physicalType
      this.physicalType = castToCodeableConcept(value); // CodeableConcept
      return value;
    case 747804969: // position
      this.position = (LocationPositionComponent) value; // LocationPositionComponent
      return value;
    case -2058947787: // managingOrganization
      this.managingOrganization = castToReference(value); // Reference
      return value;
    case -995410646: // partOf
      this.partOf = castToReference(value); // Reference
      return value;
    case -1588872511: // hoursOfOperation
      this.getHoursOfOperation().add((LocationHoursOfOperationComponent) value); // LocationHoursOfOperationComponent
      return value;
    case -1149143617: // availabilityExceptions
      this.availabilityExceptions = castToString(value); // StringType
      return value;
    case 1741102485: // endpoint
      this.getEndpoint().add(castToReference(value)); // Reference
      return value;
    default:
      return super.setProperty(hash, name, value);
    }

  }

  @Override
  public Base setProperty(String name, Base value) throws FHIRException {
    if (name.equals("identifier")) {
      this.getIdentifier().add(castToIdentifier(value));
    } else if (name.equals("status")) {
      value = new LocationStatusEnumFactory().fromType(castToCode(value));
      this.status = (Enumeration) value; // Enumeration
    } else if (name.equals("operationalStatus")) {
      this.operationalStatus = castToCoding(value); // Coding
    } else if (name.equals("name")) {
      this.name = castToString(value); // StringType
    } else if (name.equals("alias")) {
      this.getAlias().add(castToString(value));
    } else if (name.equals("description")) {
      this.description = castToString(value); // StringType
    } else if (name.equals("mode")) {
      value = new LocationModeEnumFactory().fromType(castToCode(value));
      this.mode = (Enumeration) value; // Enumeration
    } else if (name.equals("type")) {
      this.getType().add(castToCodeableConcept(value));
    } else if (name.equals("telecom")) {
      this.getTelecom().add(castToContactPoint(value));
    } else if (name.equals("address")) {
      this.address = castToAddress(value); // Address
    } else if (name.equals("physicalType")) {
      this.physicalType = castToCodeableConcept(value); // CodeableConcept
    } else if (name.equals("position")) {
      this.position = (LocationPositionComponent) value; // LocationPositionComponent
    } else if (name.equals("managingOrganization")) {
      this.managingOrganization = castToReference(value); // Reference
    } else if (name.equals("partOf")) {
      this.partOf = castToReference(value); // Reference
    } else if (name.equals("hoursOfOperation")) {
      this.getHoursOfOperation().add((LocationHoursOfOperationComponent) value);
    } else if (name.equals("availabilityExceptions")) {
      this.availabilityExceptions = castToString(value); // StringType
    } else if (name.equals("endpoint")) {
      this.getEndpoint().add(castToReference(value));
    } else
      return super.setProperty(name, value);
    return value;
  }

  @Override
  public void removeChild(String name, Base value) throws FHIRException {
    if (name.equals("identifier")) {
      this.getIdentifier().remove(castToIdentifier(value));
    } else if (name.equals("status")) {
      this.status = null;
    } else if (name.equals("operationalStatus")) {
      this.operationalStatus = null;
    } else if (name.equals("name")) {
      this.name = null;
    } else if (name.equals("alias")) {
      this.getAlias().remove(castToString(value));
    } else if (name.equals("description")) {
      this.description = null;
    } else if (name.equals("mode")) {
      this.mode = null;
    } else if (name.equals("type")) {
      this.getType().remove(castToCodeableConcept(value));
    } else if (name.equals("telecom")) {
      this.getTelecom().remove(castToContactPoint(value));
    } else if (name.equals("address")) {
      this.address = null;
    } else if (name.equals("physicalType")) {
      this.physicalType = null;
    } else if (name.equals("position")) {
      this.position = (LocationPositionComponent) value; // LocationPositionComponent
    } else if (name.equals("managingOrganization")) {
      this.managingOrganization = null;
    } else if (name.equals("partOf")) {
      this.partOf = null;
    } else if (name.equals("hoursOfOperation")) {
      this.getHoursOfOperation().remove((LocationHoursOfOperationComponent) value);
    } else if (name.equals("availabilityExceptions")) {
      this.availabilityExceptions = null;
    } else if (name.equals("endpoint")) {
      this.getEndpoint().remove(castToReference(value));
    } else
      super.removeChild(name, value);
    
  }

  @Override
  public Base makeProperty(int hash, String name) throws FHIRException {
    switch (hash) {
    case -1618432855:
      return addIdentifier();
    case -892481550:
      return getStatusElement();
    case -2103166364:
      return getOperationalStatus();
    case 3373707:
      return getNameElement();
    case 92902992:
      return addAliasElement();
    case -1724546052:
      return getDescriptionElement();
    case 3357091:
      return getModeElement();
    case 3575610:
      return addType();
    case -1429363305:
      return addTelecom();
    case -1147692044:
      return getAddress();
    case -1474715471:
      return getPhysicalType();
    case 747804969:
      return getPosition();
    case -2058947787:
      return getManagingOrganization();
    case -995410646:
      return getPartOf();
    case -1588872511:
      return addHoursOfOperation();
    case -1149143617:
      return getAvailabilityExceptionsElement();
    case 1741102485:
      return addEndpoint();
    default:
      return super.makeProperty(hash, name);
    }

  }

  @Override
  public String[] getTypesForProperty(int hash, String name) throws FHIRException {
    switch (hash) {
    case -1618432855:
      /* identifier */ return new String[] { "Identifier" };
    case -892481550:
      /* status */ return new String[] { "code" };
    case -2103166364:
      /* operationalStatus */ return new String[] { "Coding" };
    case 3373707:
      /* name */ return new String[] { "string" };
    case 92902992:
      /* alias */ return new String[] { "string" };
    case -1724546052:
      /* description */ return new String[] { "string" };
    case 3357091:
      /* mode */ return new String[] { "code" };
    case 3575610:
      /* type */ return new String[] { "CodeableConcept" };
    case -1429363305:
      /* telecom */ return new String[] { "ContactPoint" };
    case -1147692044:
      /* address */ return new String[] { "Address" };
    case -1474715471:
      /* physicalType */ return new String[] { "CodeableConcept" };
    case 747804969:
      /* position */ return new String[] {};
    case -2058947787:
      /* managingOrganization */ return new String[] { "Reference" };
    case -995410646:
      /* partOf */ return new String[] { "Reference" };
    case -1588872511:
      /* hoursOfOperation */ return new String[] {};
    case -1149143617:
      /* availabilityExceptions */ return new String[] { "string" };
    case 1741102485:
      /* endpoint */ return new String[] { "Reference" };
    default:
      return super.getTypesForProperty(hash, name);
    }

  }

  @Override
  public Base addChild(String name) throws FHIRException {
    if (name.equals("identifier")) {
      return addIdentifier();
    } else if (name.equals("status")) {
      throw new FHIRException("Cannot call addChild on a singleton property Location.status");
    } else if (name.equals("operationalStatus")) {
      this.operationalStatus = new Coding();
      return this.operationalStatus;
    } else if (name.equals("name")) {
      throw new FHIRException("Cannot call addChild on a singleton property Location.name");
    } else if (name.equals("alias")) {
      throw new FHIRException("Cannot call addChild on a singleton property Location.alias");
    } else if (name.equals("description")) {
      throw new FHIRException("Cannot call addChild on a singleton property Location.description");
    } else if (name.equals("mode")) {
      throw new FHIRException("Cannot call addChild on a singleton property Location.mode");
    } else if (name.equals("type")) {
      return addType();
    } else if (name.equals("telecom")) {
      return addTelecom();
    } else if (name.equals("address")) {
      this.address = new Address();
      return this.address;
    } else if (name.equals("physicalType")) {
      this.physicalType = new CodeableConcept();
      return this.physicalType;
    } else if (name.equals("position")) {
      this.position = new LocationPositionComponent();
      return this.position;
    } else if (name.equals("managingOrganization")) {
      this.managingOrganization = new Reference();
      return this.managingOrganization;
    } else if (name.equals("partOf")) {
      this.partOf = new Reference();
      return this.partOf;
    } else if (name.equals("hoursOfOperation")) {
      return addHoursOfOperation();
    } else if (name.equals("availabilityExceptions")) {
      throw new FHIRException("Cannot call addChild on a singleton property Location.availabilityExceptions");
    } else if (name.equals("endpoint")) {
      return addEndpoint();
    } else
      return super.addChild(name);
  }

  public String fhirType() {
    return "Location";

  }

  public Location copy() {
    Location dst = new Location();
    copyValues(dst);
    return dst;
  }

  public void copyValues(Location dst) {
    super.copyValues(dst);
    if (identifier != null) {
      dst.identifier = new ArrayList();
      for (Identifier i : identifier)
        dst.identifier.add(i.copy());
    }
    ;
    dst.status = status == null ? null : status.copy();
    dst.operationalStatus = operationalStatus == null ? null : operationalStatus.copy();
    dst.name = name == null ? null : name.copy();
    if (alias != null) {
      dst.alias = new ArrayList();
      for (StringType i : alias)
        dst.alias.add(i.copy());
    }
    ;
    dst.description = description == null ? null : description.copy();
    dst.mode = mode == null ? null : mode.copy();
    if (type != null) {
      dst.type = new ArrayList();
      for (CodeableConcept i : type)
        dst.type.add(i.copy());
    }
    ;
    if (telecom != null) {
      dst.telecom = new ArrayList();
      for (ContactPoint i : telecom)
        dst.telecom.add(i.copy());
    }
    ;
    dst.address = address == null ? null : address.copy();
    dst.physicalType = physicalType == null ? null : physicalType.copy();
    dst.position = position == null ? null : position.copy();
    dst.managingOrganization = managingOrganization == null ? null : managingOrganization.copy();
    dst.partOf = partOf == null ? null : partOf.copy();
    if (hoursOfOperation != null) {
      dst.hoursOfOperation = new ArrayList();
      for (LocationHoursOfOperationComponent i : hoursOfOperation)
        dst.hoursOfOperation.add(i.copy());
    }
    ;
    dst.availabilityExceptions = availabilityExceptions == null ? null : availabilityExceptions.copy();
    if (endpoint != null) {
      dst.endpoint = new ArrayList();
      for (Reference i : endpoint)
        dst.endpoint.add(i.copy());
    }
    ;
  }

  protected Location typedCopy() {
    return copy();
  }

  @Override
  public boolean equalsDeep(Base other_) {
    if (!super.equalsDeep(other_))
      return false;
    if (!(other_ instanceof Location))
      return false;
    Location o = (Location) other_;
    return compareDeep(identifier, o.identifier, true) && compareDeep(status, o.status, true)
        && compareDeep(operationalStatus, o.operationalStatus, true) && compareDeep(name, o.name, true)
        && compareDeep(alias, o.alias, true) && compareDeep(description, o.description, true)
        && compareDeep(mode, o.mode, true) && compareDeep(type, o.type, true) && compareDeep(telecom, o.telecom, true)
        && compareDeep(address, o.address, true) && compareDeep(physicalType, o.physicalType, true)
        && compareDeep(position, o.position, true) && compareDeep(managingOrganization, o.managingOrganization, true)
        && compareDeep(partOf, o.partOf, true) && compareDeep(hoursOfOperation, o.hoursOfOperation, true)
        && compareDeep(availabilityExceptions, o.availabilityExceptions, true)
        && compareDeep(endpoint, o.endpoint, true);
  }

  @Override
  public boolean equalsShallow(Base other_) {
    if (!super.equalsShallow(other_))
      return false;
    if (!(other_ instanceof Location))
      return false;
    Location o = (Location) other_;
    return compareValues(status, o.status, true) && compareValues(name, o.name, true)
        && compareValues(alias, o.alias, true) && compareValues(description, o.description, true)
        && compareValues(mode, o.mode, true) && compareValues(availabilityExceptions, o.availabilityExceptions, true);
  }

  public boolean isEmpty() {
    return super.isEmpty() && ca.uhn.fhir.util.ElementUtil.isEmpty(identifier, status, operationalStatus, name, alias,
        description, mode, type, telecom, address, physicalType, position, managingOrganization, partOf,
        hoursOfOperation, availabilityExceptions, endpoint);
  }

  @Override
  public ResourceType getResourceType() {
    return ResourceType.Location;
  }

  /**
   * Search parameter: identifier
   * 

* Description: An identifier for the location
* Type: token
* Path: Location.identifier
*

*/ @SearchParamDefinition(name = "identifier", path = "Location.identifier", description = "An identifier for the location", type = "token") public static final String SP_IDENTIFIER = "identifier"; /** * Fluent Client search parameter constant for identifier *

* Description: An identifier for the location
* Type: token
* Path: Location.identifier
*

*/ public static final ca.uhn.fhir.rest.gclient.TokenClientParam IDENTIFIER = new ca.uhn.fhir.rest.gclient.TokenClientParam( SP_IDENTIFIER); /** * Search parameter: partof *

* Description: A location of which this location is a part
* Type: reference
* Path: Location.partOf
*

*/ @SearchParamDefinition(name = "partof", path = "Location.partOf", description = "A location of which this location is a part", type = "reference", target = { Location.class }) public static final String SP_PARTOF = "partof"; /** * Fluent Client search parameter constant for partof *

* Description: A location of which this location is a part
* Type: reference
* Path: Location.partOf
*

*/ public static final ca.uhn.fhir.rest.gclient.ReferenceClientParam PARTOF = new ca.uhn.fhir.rest.gclient.ReferenceClientParam( SP_PARTOF); /** * Constant for fluent queries to be used to add include statements. Specifies * the path value of "Location:partof". */ public static final ca.uhn.fhir.model.api.Include INCLUDE_PARTOF = new ca.uhn.fhir.model.api.Include( "Location:partof").toLocked(); /** * Search parameter: address *

* Description: A (part of the) address of the location
* Type: string
* Path: Location.address
*

*/ @SearchParamDefinition(name = "address", path = "Location.address", description = "A (part of the) address of the location", type = "string") public static final String SP_ADDRESS = "address"; /** * Fluent Client search parameter constant for address *

* Description: A (part of the) address of the location
* Type: string
* Path: Location.address
*

*/ public static final ca.uhn.fhir.rest.gclient.StringClientParam ADDRESS = new ca.uhn.fhir.rest.gclient.StringClientParam( SP_ADDRESS); /** * Search parameter: address-state *

* Description: A state specified in an address
* Type: string
* Path: Location.address.state
*

*/ @SearchParamDefinition(name = "address-state", path = "Location.address.state", description = "A state specified in an address", type = "string") public static final String SP_ADDRESS_STATE = "address-state"; /** * Fluent Client search parameter constant for address-state *

* Description: A state specified in an address
* Type: string
* Path: Location.address.state
*

*/ public static final ca.uhn.fhir.rest.gclient.StringClientParam ADDRESS_STATE = new ca.uhn.fhir.rest.gclient.StringClientParam( SP_ADDRESS_STATE); /** * Search parameter: operational-status *

* Description: Searches for locations (typically bed/room) that have an * operational status (e.g. contaminated, housekeeping)
* Type: token
* Path: Location.operationalStatus
*

*/ @SearchParamDefinition(name = "operational-status", path = "Location.operationalStatus", description = "Searches for locations (typically bed/room) that have an operational status (e.g. contaminated, housekeeping)", type = "token") public static final String SP_OPERATIONAL_STATUS = "operational-status"; /** * Fluent Client search parameter constant for operational-status *

* Description: Searches for locations (typically bed/room) that have an * operational status (e.g. contaminated, housekeeping)
* Type: token
* Path: Location.operationalStatus
*

*/ public static final ca.uhn.fhir.rest.gclient.TokenClientParam OPERATIONAL_STATUS = new ca.uhn.fhir.rest.gclient.TokenClientParam( SP_OPERATIONAL_STATUS); /** * Search parameter: type *

* Description: A code for the type of location
* Type: token
* Path: Location.type
*

*/ @SearchParamDefinition(name = "type", path = "Location.type", description = "A code for the type of location", type = "token") public static final String SP_TYPE = "type"; /** * Fluent Client search parameter constant for type *

* Description: A code for the type of location
* Type: token
* Path: Location.type
*

*/ public static final ca.uhn.fhir.rest.gclient.TokenClientParam TYPE = new ca.uhn.fhir.rest.gclient.TokenClientParam( SP_TYPE); /** * Search parameter: address-postalcode *

* Description: A postal code specified in an address
* Type: string
* Path: Location.address.postalCode
*

*/ @SearchParamDefinition(name = "address-postalcode", path = "Location.address.postalCode", description = "A postal code specified in an address", type = "string") public static final String SP_ADDRESS_POSTALCODE = "address-postalcode"; /** * Fluent Client search parameter constant for address-postalcode *

* Description: A postal code specified in an address
* Type: string
* Path: Location.address.postalCode
*

*/ public static final ca.uhn.fhir.rest.gclient.StringClientParam ADDRESS_POSTALCODE = new ca.uhn.fhir.rest.gclient.StringClientParam( SP_ADDRESS_POSTALCODE); /** * Search parameter: address-country *

* Description: A country specified in an address
* Type: string
* Path: Location.address.country
*

*/ @SearchParamDefinition(name = "address-country", path = "Location.address.country", description = "A country specified in an address", type = "string") public static final String SP_ADDRESS_COUNTRY = "address-country"; /** * Fluent Client search parameter constant for address-country *

* Description: A country specified in an address
* Type: string
* Path: Location.address.country
*

*/ public static final ca.uhn.fhir.rest.gclient.StringClientParam ADDRESS_COUNTRY = new ca.uhn.fhir.rest.gclient.StringClientParam( SP_ADDRESS_COUNTRY); /** * Search parameter: endpoint *

* Description: Technical endpoints providing access to services operated for * the location
* Type: reference
* Path: Location.endpoint
*

*/ @SearchParamDefinition(name = "endpoint", path = "Location.endpoint", description = "Technical endpoints providing access to services operated for the location", type = "reference", target = { Endpoint.class }) public static final String SP_ENDPOINT = "endpoint"; /** * Fluent Client search parameter constant for endpoint *

* Description: Technical endpoints providing access to services operated for * the location
* Type: reference
* Path: Location.endpoint
*

*/ public static final ca.uhn.fhir.rest.gclient.ReferenceClientParam ENDPOINT = new ca.uhn.fhir.rest.gclient.ReferenceClientParam( SP_ENDPOINT); /** * Constant for fluent queries to be used to add include statements. Specifies * the path value of "Location:endpoint". */ public static final ca.uhn.fhir.model.api.Include INCLUDE_ENDPOINT = new ca.uhn.fhir.model.api.Include( "Location:endpoint").toLocked(); /** * Search parameter: organization *

* Description: Searches for locations that are managed by the provided * organization
* Type: reference
* Path: Location.managingOrganization
*

*/ @SearchParamDefinition(name = "organization", path = "Location.managingOrganization", description = "Searches for locations that are managed by the provided organization", type = "reference", target = { Organization.class }) public static final String SP_ORGANIZATION = "organization"; /** * Fluent Client search parameter constant for organization *

* Description: Searches for locations that are managed by the provided * organization
* Type: reference
* Path: Location.managingOrganization
*

*/ public static final ca.uhn.fhir.rest.gclient.ReferenceClientParam ORGANIZATION = new ca.uhn.fhir.rest.gclient.ReferenceClientParam( SP_ORGANIZATION); /** * Constant for fluent queries to be used to add include statements. Specifies * the path value of "Location:organization". */ public static final ca.uhn.fhir.model.api.Include INCLUDE_ORGANIZATION = new ca.uhn.fhir.model.api.Include( "Location:organization").toLocked(); /** * Search parameter: name *

* Description: A portion of the location's name or alias
* Type: string
* Path: Location.name, Location.alias
*

*/ @SearchParamDefinition(name = "name", path = "Location.name | Location.alias", description = "A portion of the location's name or alias", type = "string") public static final String SP_NAME = "name"; /** * Fluent Client search parameter constant for name *

* Description: A portion of the location's name or alias
* Type: string
* Path: Location.name, Location.alias
*

*/ public static final ca.uhn.fhir.rest.gclient.StringClientParam NAME = new ca.uhn.fhir.rest.gclient.StringClientParam( SP_NAME); /** * Search parameter: address-use *

* Description: A use code specified in an address
* Type: token
* Path: Location.address.use
*

*/ @SearchParamDefinition(name = "address-use", path = "Location.address.use", description = "A use code specified in an address", type = "token") public static final String SP_ADDRESS_USE = "address-use"; /** * Fluent Client search parameter constant for address-use *

* Description: A use code specified in an address
* Type: token
* Path: Location.address.use
*

*/ public static final ca.uhn.fhir.rest.gclient.TokenClientParam ADDRESS_USE = new ca.uhn.fhir.rest.gclient.TokenClientParam( SP_ADDRESS_USE); /** * Search parameter: near *

* Description: Search for locations where the location.position is near to, * or within a specified distance of, the provided coordinates expressed as * [latitude]|[longitude]|[distance]|[units] (using the WGS84 datum, see notes). * If the units are omitted, then kms should be assumed. If the distance is * omitted, then the server can use its own discretion as to what distances * should be considered near (and units are irrelevant) * * Servers may search using various techniques that might have differing * accuracies, depending on implementation efficiency. * * Requires the near-distance parameter to be provided also
* Type: special
* Path: Location.position
*

*/ @SearchParamDefinition(name = "near", path = "Location.position", description = "Search for locations where the location.position is near to, or within a specified distance of, the provided coordinates expressed as [latitude]|[longitude]|[distance]|[units] (using the WGS84 datum, see notes).\nIf the units are omitted, then kms should be assumed. If the distance is omitted, then the server can use its own discretion as to what distances should be considered near (and units are irrelevant)\n\nServers may search using various techniques that might have differing accuracies, depending on implementation efficiency.\n\nRequires the near-distance parameter to be provided also", type = "special") public static final String SP_NEAR = "near"; /** * Fluent Client search parameter constant for near *

* Description: Search for locations where the location.position is near to, * or within a specified distance of, the provided coordinates expressed as * [latitude]|[longitude]|[distance]|[units] (using the WGS84 datum, see notes). * If the units are omitted, then kms should be assumed. If the distance is * omitted, then the server can use its own discretion as to what distances * should be considered near (and units are irrelevant) * * Servers may search using various techniques that might have differing * accuracies, depending on implementation efficiency. * * Requires the near-distance parameter to be provided also
* Type: special
* Path: Location.position
*

*/ public static final ca.uhn.fhir.rest.gclient.SpecialClientParam NEAR = new ca.uhn.fhir.rest.gclient.SpecialClientParam( SP_NEAR); /** * Search parameter: address-city *

* Description: A city specified in an address
* Type: string
* Path: Location.address.city
*

*/ @SearchParamDefinition(name = "address-city", path = "Location.address.city", description = "A city specified in an address", type = "string") public static final String SP_ADDRESS_CITY = "address-city"; /** * Fluent Client search parameter constant for address-city *

* Description: A city specified in an address
* Type: string
* Path: Location.address.city
*

*/ public static final ca.uhn.fhir.rest.gclient.StringClientParam ADDRESS_CITY = new ca.uhn.fhir.rest.gclient.StringClientParam( SP_ADDRESS_CITY); /** * Search parameter: status *

* Description: Searches for locations with a specific kind of status
* Type: token
* Path: Location.status
*

*/ @SearchParamDefinition(name = "status", path = "Location.status", description = "Searches for locations with a specific kind of status", type = "token") public static final String SP_STATUS = "status"; /** * Fluent Client search parameter constant for status *

* Description: Searches for locations with a specific kind of status
* Type: token
* Path: Location.status
*

*/ public static final ca.uhn.fhir.rest.gclient.TokenClientParam STATUS = new ca.uhn.fhir.rest.gclient.TokenClientParam( SP_STATUS); }




© 2015 - 2024 Weber Informatics LLC | Privacy Policy