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.util;
021
022import ca.uhn.fhir.context.BaseRuntimeChildDefinition;
023import ca.uhn.fhir.context.BaseRuntimeElementDefinition;
024import org.hl7.fhir.instance.model.api.IBase;
025import org.hl7.fhir.instance.model.api.IBaseExtension;
026
027import java.util.List;
028
029/**
030 * THIS API IS EXPERIMENTAL IN HAPI FHIR - USE WITH CAUTION AS THE PUBLISHED API MAY
031 * CHANGE
032 *
033 * @see FhirTerser#visit(IBase, IModelVisitor2)
034 */
035public interface IModelVisitor2 {
036
037        /**
038         * @param theElement               The element being visited
039         * @param theContainingElementPath The elements in the path leading up to the actual element being accepted. The first element in this path will be the outer resource being visited, and the last element will be the saem object as the object passed as <code>theElement</code>
040         */
041        boolean acceptElement(
042                        IBase theElement,
043                        List<IBase> theContainingElementPath,
044                        List<BaseRuntimeChildDefinition> theChildDefinitionPath,
045                        List<BaseRuntimeElementDefinition<?>> theElementDefinitionPath);
046
047        /**
048         *
049         */
050        default boolean acceptUndeclaredExtension(
051                        IBaseExtension<?, ?> theNextExt,
052                        List<IBase> theContainingElementPath,
053                        List<BaseRuntimeChildDefinition> theChildDefinitionPath,
054                        List<BaseRuntimeElementDefinition<?>> theElementDefinitionPath) {
055                return true;
056        }
057}