All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.openrewrite.yaml.AppendToSequence Maven / Gradle / Ivy

There is a newer version: 8.40.3
Show newest version
/*
 * Copyright 2023 the original author or authors.
 * 

* Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at *

* https://www.apache.org/licenses/LICENSE-2.0 *

* Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ package org.openrewrite.yaml; import lombok.EqualsAndHashCode; import lombok.Value; import org.jspecify.annotations.Nullable; import org.openrewrite.ExecutionContext; import org.openrewrite.Option; import org.openrewrite.Recipe; import org.openrewrite.TreeVisitor; import java.util.List; @Value @EqualsAndHashCode(callSuper = false) public class AppendToSequence extends Recipe { @Option(displayName = "Sequence path", description = "A [JsonPath](https://docs.openrewrite.org/reference/jsonpath-and-jsonpathmatcher-reference) expression to locate a YAML sequence.", example = "$.universe.planets") String sequencePath; @Option(displayName = "New value", description = "The new value to be appended to the sequence.", example = "earth") String value; @Option(displayName = "Optional: match existing sequence values", description = "If specified, the item will only be appended if the existing sequence matches these values.", example = "existingValue1", required = false) @Nullable List existingSequenceValues; @Option(displayName = "Optional: match existing sequence values in any order", description = "If specified in combination with the above parameter, the item will only be appended if the existing sequence has the specified values in any order.", example = "true", required = false) @Nullable Boolean matchExistingSequenceValuesInAnyOrder; @Override public String getDisplayName() { return "Append to sequence"; } @Override public String getInstanceName() { return String.format("Append %s to sequence `%s`", value, sequencePath); } @Override public String getDescription() { return "Append item to YAML sequence."; } @Override public TreeVisitor getVisitor() { JsonPathMatcher matcher = new JsonPathMatcher(sequencePath); return new AppendToSequenceVisitor(matcher, value, existingSequenceValues, Boolean.TRUE.equals(matchExistingSequenceValuesInAnyOrder)); } }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy