001package ca.uhn.fhir.model.primitive;
002
003/*
004 * #%L
005 * HAPI FHIR - Core Library
006 * %%
007 * Copyright (C) 2014 - 2021 Smile CDR, Inc.
008 * %%
009 * Licensed under the Apache License, Version 2.0 (the "License");
010 * you may not use this file except in compliance with the License.
011 * You may obtain a copy of the License at
012 *
013 *      http://www.apache.org/licenses/LICENSE-2.0
014 *
015 * Unless required by applicable law or agreed to in writing, software
016 * distributed under the License is distributed on an "AS IS" BASIS,
017 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
018 * See the License for the specific language governing permissions and
019 * limitations under the License.
020 * #L%
021 */
022
023import ca.uhn.fhir.model.api.IQueryParameterType;
024import ca.uhn.fhir.model.api.annotation.DatatypeDef;
025import ca.uhn.fhir.model.api.annotation.SimpleSetter;
026
027/**
028 * Represents a Time datatype, per the FHIR specification. A time is a specification of hours and minutes (and optionally milliseconds), with NO date and NO timezone information attached. It is
029 * expressed as a string in the form <code>HH:mm:ss[.SSSS]</code>
030 * 
031 * <p>
032 * This datatype is not valid in FHIR DSTU1
033 * </p>
034 * 
035 * @since FHIR DSTU 2 / HAPI 0.8
036 * 
037 *        TODO: have a way of preventing this from being used in DSTU1 resources
038 *        TODO: validate time?
039 */
040@DatatypeDef(name = "time")
041public class TimeDt extends StringDt implements IQueryParameterType {
042
043        /**
044         * Create a new String
045         */
046        public TimeDt() {
047                super();
048        }
049
050        /**
051         * Create a new String
052         */
053        @SimpleSetter
054        public TimeDt(@SimpleSetter.Parameter(name = "theString") String theValue) {
055                this();
056                setValue(theValue);
057        }
058
059}