View Javadoc
1   /*
2    *    Copyright 2016-2026 the original author or authors.
3    *
4    *    Licensed under the Apache License, Version 2.0 (the "License");
5    *    you may not use this file except in compliance with the License.
6    *    You may obtain a copy of the License at
7    *
8    *       https://www.apache.org/licenses/LICENSE-2.0
9    *
10   *    Unless required by applicable law or agreed to in writing, software
11   *    distributed under the License is distributed on an "AS IS" BASIS,
12   *    WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13   *    See the License for the specific language governing permissions and
14   *    limitations under the License.
15   */
16  package org.mybatis.dynamic.sql;
17  
18  import java.util.ArrayList;
19  import java.util.Collections;
20  import java.util.List;
21  import java.util.Objects;
22  
23  import org.jspecify.annotations.Nullable;
24  
25  /**
26   * This class represents a criteria group with either an AND or an OR connector.
27   * This class is intentionally NOT derived from SqlCriterion because we only want it to be
28   * available where an AND or an OR condition is appropriate.
29   *
30   * @author Jeff Butler
31   *
32   * @since 1.4.0
33   */
34  public class AndOrCriteriaGroup {
35      private final String connector;
36      private final SqlCriterion initialCriterion;
37      private final List<AndOrCriteriaGroup> subCriteria;
38  
39      private AndOrCriteriaGroup(Builder builder) {
40          connector = Objects.requireNonNull(builder.connector);
41          initialCriterion = Objects.requireNonNull(builder.initialCriterion);
42          subCriteria = builder.subCriteria;
43      }
44  
45      public String connector() {
46          return connector;
47      }
48  
49      public SqlCriterion initialCriterion() {
50          return initialCriterion;
51      }
52  
53      public List<AndOrCriteriaGroup> subCriteria() {
54          return Collections.unmodifiableList(subCriteria);
55      }
56  
57      public static class Builder {
58          private @Nullable String connector;
59          private @Nullable SqlCriterion initialCriterion;
60          private final List<AndOrCriteriaGroup> subCriteria = new ArrayList<>();
61  
62          public Builder withConnector(String connector) {
63              this.connector = connector;
64              return this;
65          }
66  
67          public Builder withInitialCriterion(SqlCriterion initialCriterion) {
68              this.initialCriterion = initialCriterion;
69              return this;
70          }
71  
72          public Builder withSubCriteria(List<AndOrCriteriaGroup> subCriteria) {
73              this.subCriteria.addAll(subCriteria);
74              return this;
75          }
76  
77          public AndOrCriteriaGroup build() {
78              return new AndOrCriteriaGroup(this);
79          }
80      }
81  }