plugins/spark_upgrade/update_calendar_interval.py (50 lines of code) (raw):

# Copyright (c) 2023 Uber Technologies, Inc. # <p>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 # <p>http://www.apache.org/licenses/LICENSE-2.0 # <p>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. from typing import Any, List, Dict from execute_piranha import ExecutePiranha from polyglot_piranha import ( Filter, OutgoingEdges, Rule, ) class UpdateCalendarInterval(ExecutePiranha): def __init__(self, paths_to_codebase: List[str]): super().__init__( paths_to_codebase=paths_to_codebase, substitutions={"calendarInterval": "CalendarInterval"}, language="scala", ) def step_name(self) -> str: return "Update CalendarInterval.:[x]" def get_rules(self) -> List[Rule]: update_CalendarInterval = Rule( name="update_CalendarInterval", query="cs CalendarInterval.:[x]", replace_node="*", replace="DateTimeConstants.@x", holes={"calendarInterval"}, ) add_import_DateTimeConstants = Rule( name="add_import_DateTimeConstants", query="(package_clause) @package_clause", replace_node="package_clause", replace="@package_clause\nimport org.apache.spark.sql.catalyst.util.DateTimeConstants", filters={ Filter( enclosing_node="(compilation_unit) @cu", not_contains=[ "cs import org.apache.spark.sql.catalyst.util.DateTimeConstants" ], ) }, is_seed_rule=False, ) return [update_CalendarInterval, add_import_DateTimeConstants] def get_edges(self) -> List[OutgoingEdges]: return [ OutgoingEdges( "update_CalendarInterval", to=["add_import_DateTimeConstants"], scope="File", ) ] def summaries_to_custom_dict(self, _) -> Dict[str, Any]: return {}