001/*
002 * #%L
003 * HAPI FHIR - Core Library
004 * %%
005 * Copyright (C) 2014 - 2025 Smile CDR, Inc.
006 * %%
007 * Licensed under the Apache License, Version 2.0 (the "License");
008 * you may not use this file except in compliance with the License.
009 * You may obtain a copy of the License at
010 *
011 *      http://www.apache.org/licenses/LICENSE-2.0
012 *
013 * Unless required by applicable law or agreed to in writing, software
014 * distributed under the License is distributed on an "AS IS" BASIS,
015 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
016 * See the License for the specific language governing permissions and
017 * limitations under the License.
018 * #L%
019 */
020package ca.uhn.fhir.rest.param;
021
022import ca.uhn.fhir.model.api.IQueryParameterType;
023import ca.uhn.fhir.util.CoverageIgnore;
024
025public class CompositeOrListParam<A extends IQueryParameterType, B extends IQueryParameterType>
026                extends BaseOrListParam<CompositeOrListParam<?, ?>, CompositeParam<A, B>> {
027
028        private Class<A> myLeftType;
029        private Class<B> myRightType;
030
031        public CompositeOrListParam(Class<A> theLeftType, Class<B> theRightType) {
032                super();
033                myLeftType = theLeftType;
034                myRightType = theRightType;
035        }
036
037        public Class<A> getLeftType() {
038                return myLeftType;
039        }
040
041        public Class<B> getRightType() {
042                return myRightType;
043        }
044
045        @CoverageIgnore
046        @Override
047        CompositeParam<A, B> newInstance() {
048                return new CompositeParam<A, B>(myLeftType, myRightType);
049        }
050
051        @CoverageIgnore
052        @Override
053        public CompositeOrListParam<A, B> addOr(CompositeParam<A, B> theParameter) {
054                add(theParameter);
055                return this;
056        }
057}