commit 812dc29756dfab69f1e66fb65bd2eb79ce581af4 Author: tigro Date: Mon Jan 15 22:53:07 2024 +0300 import rust-termion-2.0.3-1.el9 diff --git a/.rust-termion.metadata b/.rust-termion.metadata new file mode 100644 index 0000000..e69de29 diff --git a/SOURCES/0001-Update-numtoa.patch b/SOURCES/0001-Update-numtoa.patch new file mode 100644 index 0000000..d542d80 --- /dev/null +++ b/SOURCES/0001-Update-numtoa.patch @@ -0,0 +1,104 @@ +From d80ab4617f79f68b85cc1d113250ad3d791a66d5 Mon Sep 17 00:00:00 2001 +From: =?UTF-8?q?Jonathan=20Schleu=C3=9Fer?= +Date: Sat, 29 Dec 2018 17:15:18 +0100 +Subject: [PATCH] Update numtoa + +This now allows byte slices with lengths different than 20, so +specific lengths based on the biggest possible value for each +number can be used. +--- + src/color.rs | 8 ++++---- + src/cursor.rs | 10 +++++----- + 2 files changed, 9 insertions(+), 9 deletions(-) + +diff --git a/src/color.rs b/src/color.rs +index 6c543b69561f..6c0055b5e9e3 100644 +--- a/src/color.rs ++++ b/src/color.rs +@@ -125,14 +125,14 @@ impl AnsiValue { + impl AnsiValue { + /// Returns the ANSI sequence as a string. + pub fn fg_string(self) -> String { +- let mut x = [0u8; 20]; ++ let mut x = [0u8; 3]; + let x = self.0.numtoa_str(10, &mut x); + [csi!("38;5;"), x, "m"].concat() + } + + /// Returns the ANSI sequence as a string. + pub fn bg_string(self) -> String { +- let mut x = [0u8; 20]; ++ let mut x = [0u8; 3]; + let x = self.0.numtoa_str(10, &mut x); + [csi!("48;5;"), x, "m"].concat() + } +@@ -157,7 +157,7 @@ pub struct Rgb(pub u8, pub u8, pub u8); + impl Rgb { + /// Returns the ANSI sequence as a string. + pub fn fg_string(self) -> String { +- let (mut x, mut y, mut z) = ([0u8; 20], [0u8; 20], [0u8; 20]); ++ let (mut x, mut y, mut z) = ([0u8; 3], [0u8; 3], [0u8; 3]); + let (x, y, z) = ( + self.0.numtoa_str(10, &mut x), + self.1.numtoa_str(10, &mut y), +@@ -169,7 +169,7 @@ impl Rgb { + + /// Returns the ANSI sequence as a string. + pub fn bg_string(self) -> String { +- let (mut x, mut y, mut z) = ([0u8; 20], [0u8; 20], [0u8; 20]); ++ let (mut x, mut y, mut z) = ([0u8; 3], [0u8; 3], [0u8; 3]); + let (x, y, z) = ( + self.0.numtoa_str(10, &mut x), + self.1.numtoa_str(10, &mut y), +diff --git a/src/cursor.rs b/src/cursor.rs +index bbc039406746..8596c3f47fab 100644 +--- a/src/cursor.rs ++++ b/src/cursor.rs +@@ -36,7 +36,7 @@ pub struct Goto(pub u16, pub u16); + + impl From for String { + fn from(this: Goto) -> String { +- let (mut x, mut y) = ([0u8; 20], [0u8; 20]); ++ let (mut x, mut y) = ([0u8; 5], [0u8; 5]); + ["\x1B[", this.1.numtoa_str(10, &mut x), ";", this.0.numtoa_str(10, &mut y), "H"].concat() + } + } +@@ -60,7 +60,7 @@ pub struct Left(pub u16); + + impl From for String { + fn from(this: Left) -> String { +- let mut buf = [0u8; 20]; ++ let mut buf = [0u8; 5]; + ["\x1B[", this.0.numtoa_str(10, &mut buf), "D"].concat() + } + } +@@ -77,7 +77,7 @@ pub struct Right(pub u16); + + impl From for String { + fn from(this: Right) -> String { +- let mut buf = [0u8; 20]; ++ let mut buf = [0u8; 5]; + ["\x1B[", this.0.numtoa_str(10, &mut buf), "C"].concat() + } + } +@@ -94,7 +94,7 @@ pub struct Up(pub u16); + + impl From for String { + fn from(this: Up) -> String { +- let mut buf = [0u8; 20]; ++ let mut buf = [0u8; 5]; + ["\x1B[", this.0.numtoa_str(10, &mut buf), "A"].concat() + } + } +@@ -111,7 +111,7 @@ pub struct Down(pub u16); + + impl From for String { + fn from(this: Down) -> String { +- let mut buf = [0u8; 20]; ++ let mut buf = [0u8; 5]; + ["\x1B[", this.0.numtoa_str(10, &mut buf), "B"].concat() + } + } +-- +2.21.0 + diff --git a/SOURCES/termion-2.0.3.crate b/SOURCES/termion-2.0.3.crate new file mode 100644 index 0000000..71de1f2 Binary files /dev/null and b/SOURCES/termion-2.0.3.crate differ diff --git a/SOURCES/termion-fix-metadata-auto.diff b/SOURCES/termion-fix-metadata-auto.diff new file mode 100644 index 0000000..d2ffa25 --- /dev/null +++ b/SOURCES/termion-fix-metadata-auto.diff @@ -0,0 +1,11 @@ +--- termion-2.0.3/Cargo.toml 1970-01-01T00:00:01+00:00 ++++ termion-2.0.3/Cargo.toml 2023-11-09T23:49:33.845288+00:00 +@@ -49,8 +49,3 @@ + [target."cfg(not(target_os = \"redox\"))".dependencies.libc] + version = "0.2" + +-[target."cfg(target_os = \"redox\")".dependencies.libredox] +-version = "0.0.2" +- +-[target."cfg(target_os = \"redox\")".dependencies.redox_termios] +-version = "0.1.3" diff --git a/SOURCES/termion-fix-metadata.diff b/SOURCES/termion-fix-metadata.diff new file mode 100644 index 0000000..b508847 --- /dev/null +++ b/SOURCES/termion-fix-metadata.diff @@ -0,0 +1,12 @@ +--- termion-2.0.3/Cargo.toml 1970-01-01T00:00:01+00:00 ++++ termion-2.0.3/Cargo.toml 2023-11-09T23:49:39.132308+00:00 +@@ -38,8 +38,7 @@ + repository = "https://gitlab.redox-os.org/redox-os/termion" + + [dependencies.numtoa] +-version = "0.1" +-features = ["std"] ++version = "0.2.3" + + [dependencies.serde] + version = "1.0" diff --git a/SPECS/rust-termion.spec b/SPECS/rust-termion.spec new file mode 100644 index 0000000..e4b92fd --- /dev/null +++ b/SPECS/rust-termion.spec @@ -0,0 +1,172 @@ +## START: Set by rpmautospec +## (rpmautospec version 0.3.5) +## RPMAUTOSPEC: autorelease, autochangelog +%define autorelease(e:s:pb:n) %{?-p:0.}%{lua: + release_number = 1; + base_release_number = tonumber(rpm.expand("%{?-b*}%{!?-b:1}")); + print(release_number + base_release_number - 1); +}%{?-e:.%{-e*}}%{?-s:.%{-s*}}%{!?-n:%{?dist}} +## END: Set by rpmautospec + +# Generated by rust2rpm 25 +# * tests can only be run on a real TTY +%bcond_with check +%global debug_package %{nil} + +%global crate termion + +Name: rust-termion +Version: 2.0.3 +Release: %autorelease +Summary: Bindless library for manipulating terminals + +License: MIT +URL: https://crates.io/crates/termion +Source: %{crates_source} +# Automatically generated patch to strip dependencies and normalize metadata +Patch: termion-fix-metadata-auto.diff +# Manually created patch for downstream crate metadata changes +# * bump numtoa from 0.1 to 0.2.3 +Patch: termion-fix-metadata.diff +# * port to numtoa 0.2: +# https://gitlab.redox-os.org/redox-os/termion/merge_requests/153 +Patch: 0001-Update-numtoa.patch + +BuildRequires: cargo-rpm-macros >= 24 + +%global _description %{expand: +A bindless library for manipulating terminals.} + +%description %{_description} + +%package devel +Summary: %{summary} +BuildArch: noarch + +%description devel %{_description} + +This package contains library source intended for building other packages which +use the "%{crate}" crate. + +%files devel +%license %{crate_instdir}/LICENSE +%doc %{crate_instdir}/README.md +%{crate_instdir}/ + +%package -n %{name}+default-devel +Summary: %{summary} +BuildArch: noarch + +%description -n %{name}+default-devel %{_description} + +This package contains library source intended for building other packages which +use the "default" feature of the "%{crate}" crate. + +%files -n %{name}+default-devel +%ghost %{crate_instdir}/Cargo.toml + +%package -n %{name}+serde-devel +Summary: %{summary} +BuildArch: noarch + +%description -n %{name}+serde-devel %{_description} + +This package contains library source intended for building other packages which +use the "serde" feature of the "%{crate}" crate. + +%files -n %{name}+serde-devel +%ghost %{crate_instdir}/Cargo.toml + +%prep +%autosetup -n %{crate}-%{version} -p1 +%cargo_prep + +%generate_buildrequires +%cargo_generate_buildrequires + +%build +%cargo_build + +%install +%cargo_install + +%if %{with check} +%check +%cargo_test +%endif + +%changelog +* Mon Jan 15 2024 Arkady L. Shane - 2.0.3-1 +- Rebuilt for MSVSphere 9.3 + +* Thu Nov 09 2023 Fabio Valentini - 2.0.3-1 +- Update to version 2.0.3; Fixes RHBZ#2247936 + +* Fri Jul 21 2023 Fedora Release Engineering - 2.0.1-2 +- Rebuilt for https://fedoraproject.org/wiki/Fedora_39_Mass_Rebuild + +* Mon May 22 2023 Michel Alexandre Salim - 2.0.1-1 +- Update to 2.0.1 + +* Thu May 18 2023 Fabio Valentini - 1.5.6-7 +- Regenerate with rust2rpm v24 + +* Sat Jan 21 2023 Fedora Release Engineering - 1.5.6-5 +- Rebuilt for https://fedoraproject.org/wiki/Fedora_38_Mass_Rebuild + +* Sat Jul 23 2022 Fedora Release Engineering - 1.5.6-4 +- Rebuilt for https://fedoraproject.org/wiki/Fedora_37_Mass_Rebuild + +* Fri Jan 21 2022 Fedora Release Engineering - 1.5.6-3 +- Rebuilt for https://fedoraproject.org/wiki/Fedora_36_Mass_Rebuild + +* Fri Jul 23 2021 Fedora Release Engineering - 1.5.6-2 +- Rebuilt for https://fedoraproject.org/wiki/Fedora_35_Mass_Rebuild + +* Fri Mar 26 2021 Fabio Valentini - 1.5.6-1 +- Update to version 1.5.6. +- Fixes RHBZ#1920668 + +* Wed Jan 27 2021 Fedora Release Engineering - 1.5.5-5 +- Rebuilt for https://fedoraproject.org/wiki/Fedora_34_Mass_Rebuild + +* Sat Aug 01 2020 Fedora Release Engineering - 1.5.5-4 +- Second attempt - Rebuilt for + https://fedoraproject.org/wiki/Fedora_33_Mass_Rebuild + +* Wed Jul 29 2020 Fedora Release Engineering - 1.5.5-3 +- Rebuilt for https://fedoraproject.org/wiki/Fedora_33_Mass_Rebuild + +* Thu Jan 30 2020 Fedora Release Engineering - 1.5.5-2 +- Rebuilt for https://fedoraproject.org/wiki/Fedora_32_Mass_Rebuild + +* Mon Jan 27 2020 Josh Stone - 1.5.5-1 +- Update to 1.5.5 + +* Mon Dec 02 08:20:34 CET 2019 Igor Gnatenko - 1.5.4-1 +- Update to 1.5.4 + +* Fri Jul 26 2019 Fedora Release Engineering - 1.5.3-2 +- Rebuilt for https://fedoraproject.org/wiki/Fedora_31_Mass_Rebuild + +* Tue Jun 18 23:45:53 CEST 2019 Igor Gnatenko - 1.5.3-1 +- Update to 1.5.3 + +* Mon Jun 03 2019 Josh Stone - 1.5.2-1 +- Update to 1.5.2 + +* Sat Feb 02 2019 Fedora Release Engineering - 1.5.1-5 +- Rebuilt for https://fedoraproject.org/wiki/Fedora_30_Mass_Rebuild + +* Sat Jul 14 2018 Fedora Release Engineering - 1.5.1-4 +- Rebuilt for https://fedoraproject.org/wiki/Fedora_29_Mass_Rebuild + +* Fri Feb 09 2018 Fedora Release Engineering - 1.5.1-3 +- Rebuilt for https://fedoraproject.org/wiki/Fedora_28_Mass_Rebuild + +* Mon Jan 08 2018 Igor Gnatenko - 1.5.1-2 +- Rebuild for rust-packaging v5 + +* Sun Nov 19 2017 Igor Gnatenko - 1.5.1-1 +- Initial package +