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}