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

org.openrewrite.sql.ChangeFunctionName Maven / Gradle / Ivy

/*
 * Copyright 2024 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.sql; import lombok.EqualsAndHashCode; import lombok.Value; import net.sf.jsqlparser.expression.Function; import org.openrewrite.*; import org.openrewrite.internal.StringUtils; import org.openrewrite.internal.lang.Nullable; import org.openrewrite.sql.internal.ChangeTrackingExpressionDeParser; import org.openrewrite.sql.table.DatabaseFunctions; import org.openrewrite.sql.table.DatabaseQueries; import org.openrewrite.sql.trait.SqlQuery; @Value @EqualsAndHashCode(callSuper = false) public class ChangeFunctionName extends Recipe { transient DatabaseQueries databaseQueries = new DatabaseQueries(this); transient DatabaseFunctions databaseFunctions = new DatabaseFunctions(this); @Option(displayName = "Old function name", description = "The name of the function to find, case insensitive.", example = "NVL") String oldFunctionName; @Option(displayName = "New function name", description = "The new name to use. This will match the casing of " + "the original method when a replacement is made.", example = "COALESCE") String newFunctionName; @Override public String getDisplayName() { return "Change a SQL function name"; } @Override public String getDescription() { return "When migrating between dialects, often one name can be substituted for another. " + "For example, Oracle's NVL function can be replaced with Postgres COALESCE."; } @Override public TreeVisitor getVisitor() { return new TreeVisitor() { @Override public @Nullable Tree preVisit(Tree tree, ExecutionContext ctx) { return SqlQuery.viewOf(getCursor()) .map(q -> q.mapSql(new ChangeTrackingExpressionDeParser() { @Override public void visit(Function function) { if (StringUtils.matchesGlob(function.getName(), oldFunctionName)) { databaseQueries.insertRow(ctx, new DatabaseQueries.Row( getCursor().firstEnclosingOrThrow(SourceFile.class).getSourcePath().toString(), q.getSql() )); databaseFunctions.insertRow(ctx, new DatabaseFunctions.Row( getCursor().firstEnclosingOrThrow(SourceFile.class).getSourcePath().toString(), function.getName().toLowerCase(), q.getSql() )); trackChange(() -> { function.setName(newFunctionName); super.visit(function); }); } else { super.visit(function); } } })) .orSuccess(super.preVisit(tree, ctx)); } }; } }





© 2015 - 2024 Weber Informatics LLC | Privacy Policy