org.sonar.python.tree.OrPatternImpl Maven / Gradle / Ivy
The newest version!
/*
* SonarQube Python Plugin
* Copyright (C) 2011-2024 SonarSource SA
* mailto:info AT sonarsource DOT com
*
* This program is free software; you can redistribute it and/or
* modify it under the terms of the Sonar Source-Available License Version 1, as published by SonarSource SA.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
* See the Sonar Source-Available License for more details.
*
* You should have received a copy of the Sonar Source-Available License
* along with this program; if not, see https://sonarsource.com/license/ssal/
*/
package org.sonar.python.tree;
import java.util.ArrayList;
import java.util.List;
import org.sonar.plugins.python.api.tree.OrPattern;
import org.sonar.plugins.python.api.tree.Pattern;
import org.sonar.plugins.python.api.tree.Token;
import org.sonar.plugins.python.api.tree.Tree;
import org.sonar.plugins.python.api.tree.TreeVisitor;
public class OrPatternImpl extends PyTree implements OrPattern {
private final List patterns;
private final List separators;
public OrPatternImpl(List patterns, List separators) {
this.patterns = patterns;
this.separators = separators;
}
@Override
public List patterns() {
return patterns;
}
@Override
public List separators() {
return separators;
}
@Override
public void accept(TreeVisitor visitor) {
visitor.visitOrPattern(this);
}
@Override
public Kind getKind() {
return Tree.Kind.OR_PATTERN;
}
@Override
List computeChildren() {
List children = new ArrayList<>();
int i = 0;
for (Pattern element : patterns) {
children.add(element);
if (i < separators.size()) {
children.add(separators.get(i));
}
i++;
}
return children;
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy