# # spec file # # Copyright (c) 2023 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: byte-buddy Version: 1.14.10 Release: 0 Summary: Runtime code generation for the Java virtual machine License: Apache-2.0 Group: Development/Libraries/Java URL: https://bytebuddy.net/ Source0: https://github.com/raphw/%{name}/archive/refs/tags/%{name}-%{version}.tar.gz BuildRequires: fdupes BuildRequires: jurand BuildRequires: maven-local BuildRequires: mvn(codes.rafael.modulemaker:modulemaker-maven-plugin) BuildRequires: mvn(com.google.code.findbugs:jsr305) BuildRequires: mvn(net.java.dev.jna:jna) BuildRequires: mvn(net.java.dev.jna:jna-platform) BuildRequires: mvn(org.apache.felix:maven-bundle-plugin) BuildRequires: mvn(org.apache.maven.plugin-tools:maven-plugin-annotations) BuildRequires: mvn(org.apache.maven.plugins:maven-plugin-plugin) BuildRequires: mvn(org.apache.maven.plugins:maven-shade-plugin) BuildRequires: mvn(org.apache.maven:maven-core) BuildRequires: mvn(org.apache.maven:maven-plugin-api) BuildRequires: mvn(org.eclipse.aether:aether-api) BuildRequires: mvn(org.eclipse.aether:aether-util) BuildRequires: mvn(org.ow2.asm:asm) BuildRequires: mvn(org.ow2.asm:asm-commons) BuildRequires: mvn(org.sonatype.plexus:plexus-build-api) Conflicts: %{name}-bootstrap Obsoletes: %{name}-bootstrap BuildArch: noarch %description Byte Buddy is a code generation and manipulation library for creating and modifying Java classes during the runtime of a Java application and without the help of a compiler. Other than the code generation utilities that ship with the Java Class Library, Byte Buddy allows the creation of arbitrary classes and is not limited to implementing interfaces for the creation of runtime proxies. Furthermore, Byte Buddy offers a convenient API for changing classes either manually, using a Java agent or during a build. %if %{without bootstrap} %package javadoc Summary: API documentation for %{name} Group: Documentation/HTML %description javadoc API documentation for %{name}. %endif %prep %setup -q -n %{name}-%{name}-%{version} # Don't ship android or benchmark modules %pom_disable_module byte-buddy-android %pom_disable_module byte-buddy-android-test %pom_disable_module byte-buddy-benchmark # Don't ship gradle plugin %pom_disable_module byte-buddy-gradle-plugin # Remove check plugins unneeded by RPM builds %pom_remove_plugin :jacoco-maven-plugin %pom_remove_plugin :license-maven-plugin %pom_remove_plugin :pitest-maven %pom_remove_plugin :coveralls-maven-plugin %pom_remove_plugin :spotbugs-maven-plugin %pom_remove_plugin :jitwatch-jarscan-maven-plugin %pom_remove_plugin :maven-release-plugin %pom_remove_plugin :nexus-staging-maven-plugin # Avoid circural dependency %pom_remove_plugin :byte-buddy-maven-plugin byte-buddy-dep # Not interested in shading sources (causes NPE on old versions of shade plugin) %pom_xpath_set "pom:createSourcesJar" "false" byte-buddy # Drop build dep on findbugs annotations, used only by the above check plugins %pom_remove_dep -r :findbugs-annotations %{java_remove_annotations} byte-buddy-agent byte-buddy-dep byte-buddy-maven-plugin -n SuppressFBWarnings %{mvn_package} :byte-buddy-parent __noinstall %build %{mvn_build} -f \ %if %{with bootstrap} -j \ %endif -- \ -Dproject.build.outputTimestamp=$(date -u -d @${SOURCE_DATE_EPOCH:-$(date +%%s)} +%%Y-%%m-%%dT%%H:%%M:%%SZ) \ -Dsource=8 %install %mvn_install %if %{without bootstrap} %fdupes -s %{buildroot}%{_javadocdir} %endif %files -f .mfiles %license LICENSE NOTICE %doc {README,release-notes}.md %if %{without bootstrap} %files javadoc -f .mfiles-javadoc %license LICENSE NOTICE %endif %changelog