# # spec file for package python-bowler # # Copyright (c) 2025 SUSE LLC # # All modifications and additions to the file contributed by third parties # remain the property of their copyright owners, unless otherwise agreed # upon. The license for this file, and modifications and additions to the # file, is the same license as for the pristine package itself (unless the # license for the pristine package is not an Open Source License, in which # case the license is the MIT License). An "Open Source License" is a # license that conforms to the Open Source Definition (Version 1.9) # published by the Open Source Initiative. # Please submit bugfixes or comments via https://bugs.opensuse.org/ # Name: python-bowler Version: 0.9.0 Release: 0 Summary: Safe code refactoring for modern Python projects License: MIT Group: Development/Languages/Python URL: https://github.com/facebookincubator/bowler Source: https://files.pythonhosted.org/packages/source/b/bowler/bowler-%{version}.tar.gz BuildRequires: %{python_module attrs} BuildRequires: %{python_module base >= 3.6} BuildRequires: %{python_module click} BuildRequires: %{python_module fissix} BuildRequires: %{python_module moreorless} BuildRequires: %{python_module pip} BuildRequires: %{python_module setuptools >= 38.6.0} BuildRequires: %{python_module volatile} BuildRequires: %{python_module wheel} BuildRequires: fdupes BuildRequires: python-rpm-macros Requires: python-attrs Requires: python-click Requires: python-fissix Requires: python-moreorless Requires: python-volatile Requires(post): alts Requires(postun): alts BuildArch: noarch %python_subpackages %description Bowler is a refactoring tool for manipulating Python at the syntax tree level. It enables safe, large scale code modifications while guaranteeing that the resulting code compiles and runs. It provides both a simple command line interface and a fluent API in Python for generating complex code modifications in code. Bowler uses a "fluent" `Query` API to build refactoring scripts through a series of selectors, filters, and modifiers. Many simple modifications are already possible using the existing API, but you can also provide custom selectors, filters, and modifiers as needed to build more complex or custom refactorings. See the [Query Reference](https://pybowler.io/docs/api-query) for more details. %prep %setup -q -n bowler-%{version} %build %pyproject_wheel %install %pyproject_install %python_clone -a %{buildroot}%{_bindir}/bowler %python_expand %fdupes %{buildroot}%{$python_sitelib} %check %python_exec -m bowler.tests %post %python_install_alternative bowler %postun %python_uninstall_alternative bowler %files %{python_files} %doc README.md %license LICENSE %{python_sitelib}/bowler %{python_sitelib}/bowler-%{version}*-info %python_alternative %{_bindir}/bowler %changelog