Compare commits

...

9 Commits

Author SHA1 Message Date
Fedora Release Engineering 230ce1209c Rebuilt for https://fedoraproject.org/wiki/Fedora_41_Mass_Rebuild
6 months ago
Fabio Valentini 6833eaa04c
Backport upstream patch to fix compiler errors with Rust 1.77+
7 months ago
Fedora Release Engineering c9c46b9b31 Rebuilt for https://fedoraproject.org/wiki/Fedora_40_Mass_Rebuild
12 months ago
Fabio Valentini 2a9142840b
Update to version 0.1.16; Fixes RHBZ#2245738
1 year ago
Fedora Release Engineering 9e51181a41 Rebuilt for https://fedoraproject.org/wiki/Fedora_39_Mass_Rebuild
2 years ago
Fabio Valentini ab7f3d5f50
Update to version 0.1.15; Fixes RHBZ#2137490
2 years ago
Fedora Release Engineering 4f50c0ce8c Rebuilt for https://fedoraproject.org/wiki/Fedora_38_Mass_Rebuild
2 years ago
Fedora Release Engineering cf1008332f Rebuilt for https://fedoraproject.org/wiki/Fedora_37_Mass_Rebuild
3 years ago
Fedora Release Engineering 861751c51e - Rebuilt for https://fedoraproject.org/wiki/Fedora_36_Mass_Rebuild
3 years ago

2
.gitignore vendored

@ -3,3 +3,5 @@
/const-random-macro-0.1.10.crate /const-random-macro-0.1.10.crate
/const-random-macro-0.1.11.crate /const-random-macro-0.1.11.crate
/const-random-macro-0.1.13.crate /const-random-macro-0.1.13.crate
/const-random-macro-0.1.15.crate
/const-random-macro-0.1.16.crate

@ -1,3 +0,0 @@
# rust-const-random-macro
The rust-const-random-macro package

@ -0,0 +1,168 @@
diff --git a/src/lib.rs b/src/lib.rs
index f656956..7320283 100644
--- a/src/lib.rs
+++ b/src/lib.rs
@@ -1,11 +1,9 @@
-#[allow(unused_extern_crates)]
extern crate proc_macro;
use proc_macro::*;
use std::iter::once;
mod span;
-use crate::span::{gen_random_bytes, gen_random};
-
+use crate::span::{gen_random, gen_random_bytes};
/// Create a TokenStream of an identifier out of a string
fn ident(ident: &str) -> TokenStream {
@@ -14,44 +12,89 @@ fn ident(ident: &str) -> TokenStream {
#[proc_macro]
pub fn const_random(input: TokenStream) -> TokenStream {
- match &input.to_string()[..] {
- "u8" => TokenTree::from(Literal::u8_suffixed(gen_random())).into(),
- "u16" => TokenTree::from(Literal::u16_suffixed(gen_random())).into(),
- "u32" => TokenTree::from(Literal::u32_suffixed(gen_random())).into(),
- "u64" => TokenTree::from(Literal::u64_suffixed(gen_random())).into(),
- "u128" => TokenTree::from(Literal::u128_suffixed(gen_random())).into(),
- "i8" => TokenTree::from(Literal::i8_suffixed(gen_random())).into(),
- "i16" => TokenTree::from(Literal::i16_suffixed(gen_random())).into(),
- "i32" => TokenTree::from(Literal::i32_suffixed(gen_random())).into(),
- "i64" => TokenTree::from(Literal::i64_suffixed(gen_random())).into(),
- "i128" => TokenTree::from(Literal::i128_suffixed(gen_random())).into(),
- "usize" => {
- let value: TokenStream = TokenTree::from(Literal::u128_suffixed(gen_random())).into();
- let type_cast: TokenStream = [value, ident("as"), ident("usize")]
- .iter()
- .cloned()
- .collect();
- TokenTree::from(Group::new(Delimiter::Parenthesis, type_cast)).into()
+ let mut iter = input.into_iter();
+ let Some(tt) = iter.next() else {
+ panic!("missing type arg");
+ };
+
+ let result = match &tt {
+ TokenTree::Ident(id) => {
+ let s = id.to_string();
+ match s.as_str() {
+ "u8" => TokenTree::from(Literal::u8_suffixed(gen_random())).into(),
+ "u16" => TokenTree::from(Literal::u16_suffixed(gen_random())).into(),
+ "u32" => TokenTree::from(Literal::u32_suffixed(gen_random())).into(),
+ "u64" => TokenTree::from(Literal::u64_suffixed(gen_random())).into(),
+ "u128" => TokenTree::from(Literal::u128_suffixed(gen_random())).into(),
+ "i8" => TokenTree::from(Literal::i8_suffixed(gen_random())).into(),
+ "i16" => TokenTree::from(Literal::i16_suffixed(gen_random())).into(),
+ "i32" => TokenTree::from(Literal::i32_suffixed(gen_random())).into(),
+ "i64" => TokenTree::from(Literal::i64_suffixed(gen_random())).into(),
+ "i128" => TokenTree::from(Literal::i128_suffixed(gen_random())).into(),
+ "usize" => {
+ // Note: usize does not implement `Random` and follow the pattern above. If it
+ // did, when cross-compiling from a 32-bit host to a 64-bit target,
+ // `usize::random()` would produce a 32-bit random usize which would then be
+ // turned into a suffixed literal (e.g. `0x1234_5678usize`). On the 64-bit
+ // target that literal would always have the upper 32 bits as zero, which would
+ // be bad. Instead we produce code that will generate a 128-bit integer literal
+ // (on the host) and then truncate it to usize (on the target).
+ let value: TokenStream =
+ TokenTree::from(Literal::u128_suffixed(gen_random())).into();
+ let type_cast: TokenStream = [value, ident("as"), ident("usize")]
+ .iter()
+ .cloned()
+ .collect();
+ TokenTree::from(Group::new(Delimiter::Parenthesis, type_cast)).into()
+ }
+ "isize" => {
+ // The same reasoning as `usize` applies for `isize`.
+ let value: TokenStream =
+ TokenTree::from(Literal::i128_suffixed(gen_random())).into();
+ let type_cast: TokenStream = [value, ident("as"), ident("isize")]
+ .iter()
+ .cloned()
+ .collect();
+ TokenTree::from(Group::new(Delimiter::Parenthesis, type_cast)).into()
+ }
+ _ => panic!("invalid integer type arg: `{}`", s),
+ }
}
- "isize" => {
- let value: TokenStream = TokenTree::from(Literal::i128_suffixed(gen_random())).into();
- let type_cast: TokenStream = [value, ident("as"), ident("isize")]
- .iter()
- .cloned()
- .collect();
- TokenTree::from(Group::new(Delimiter::Parenthesis, type_cast)).into()
+ TokenTree::Group(group) if group.delimiter() == Delimiter::Bracket => {
+ let mut iter = group.stream().into_iter();
+ match (&iter.next(), &iter.next(), &iter.next(), &iter.next()) {
+ (
+ Some(TokenTree::Ident(ident)),
+ Some(TokenTree::Punct(punct)),
+ Some(TokenTree::Literal(literal)),
+ None,
+ ) if ident.to_string().as_str() == "u8" && punct.as_char() == ';' => {
+ let Ok(len) = literal.to_string().parse() else {
+ panic!("invalid array length: `{}`", literal);
+ };
+ let mut random_bytes = vec![0; len];
+ gen_random_bytes(&mut random_bytes);
+ let array_parts: TokenStream = random_bytes
+ .into_iter()
+ .flat_map(|byte| {
+ let val = TokenTree::from(Literal::u8_suffixed(byte));
+ let comma = TokenTree::from(Punct::new(',', Spacing::Alone));
+ once(val).chain(once(comma))
+ })
+ .collect();
+ TokenTree::from(Group::new(Delimiter::Bracket, array_parts)).into()
+ }
+ _ => panic!("invalid array type arg: `{}`", tt),
+ }
}
- byte_array if byte_array.starts_with("[u8 ; ") && byte_array.ends_with(']')=> {
- let len = byte_array[6..byte_array.len()-1].parse().unwrap();
- let mut random_bytes = vec![0; len];
- gen_random_bytes(&mut random_bytes);
- let array_parts: TokenStream = random_bytes.into_iter().flat_map(|byte| {
- let val = TokenTree::from(Literal::u8_suffixed(byte));
- let comma = TokenTree::from(Punct::new(',', Spacing::Alone));
- once(val).chain(once(comma))
- }).collect();
- TokenTree::from(Group::new(Delimiter::Bracket, array_parts)).into()
+ _ => {
+ panic!("invalid type arg: `{}`", tt);
}
- _ => panic!("Invalid type"),
- }
+ };
+
+ if let Some(tt) = iter.next() {
+ panic!("invalid trailing token tree: `{}`", tt);
+ };
+
+ result
}
diff --git a/src/span.rs b/src/span.rs
index ab72bb0..e9bda8d 100644
--- a/src/span.rs
+++ b/src/span.rs
@@ -2,16 +2,15 @@ use proc_macro::Span;
use std::option_env;
use once_cell::race::OnceBox;
-use tiny_keccak::{Xof, Hasher, Shake};
-
+use tiny_keccak::{Hasher, Shake, Xof};
static SEED: OnceBox<Vec<u8>> = OnceBox::new();
fn get_seed() -> &'static [u8] {
&SEED.get_or_init(|| {
if let Some(value) = option_env!("CONST_RANDOM_SEED") {
- Box::new(value.as_bytes().to_vec())
- } else {
+ Box::new(value.as_bytes().to_vec())
+ } else {
let mut value = [0u8; 32];
getrandom::getrandom(&mut value).unwrap();
Box::new(value.to_vec())

@ -1,25 +1,23 @@
# Generated by rust2rpm 19 # Generated by rust2rpm 25
%bcond_without check %bcond_without check
%global debug_package %{nil} %global debug_package %{nil}
%global crate const-random-macro %global crate const-random-macro
Name: rust-%{crate} Name: rust-const-random-macro
Version: 0.1.13 Version: 0.1.16
Release: %autorelease Release: %autorelease
Summary: Provides the procedural macro used by const-random Summary: Procedural macro used by const-random
# Upstream license specification: MIT OR Apache-2.0 License: MIT OR Apache-2.0
License: MIT or ASL 2.0
URL: https://crates.io/crates/const-random-macro URL: https://crates.io/crates/const-random-macro
Source: %{crates_source} Source: %{crates_source}
ExclusiveArch: %{rust_arches} # * backported upstream patch to fix compiler errors with Rust 1.77+:
%if %{__cargo_skip_build} # https://github.com/tkaitchuck/constrandom/pull/33
BuildArch: noarch Patch: backport-compilation-fix-with-rust-1.77+.patch
%endif
BuildRequires: rust-packaging BuildRequires: cargo-rpm-macros >= 24
%global _description %{expand: %global _description %{expand:
Provides the procedural macro used by const-random.} Provides the procedural macro used by const-random.}
@ -33,11 +31,12 @@ BuildArch: noarch
%description devel %{_description} %description devel %{_description}
This package contains library source intended for building other packages which This package contains library source intended for building other packages which
use "%{crate}" crate. use the "%{crate}" crate.
%files devel %files devel
%license LICENSE-APACHE LICENSE-MIT %license %{crate_instdir}/LICENSE-APACHE
%{cargo_registry}/%{crate}-%{version_no_tilde}/ %license %{crate_instdir}/LICENSE-MIT
%{crate_instdir}/
%package -n %{name}+default-devel %package -n %{name}+default-devel
Summary: %{summary} Summary: %{summary}
@ -46,13 +45,13 @@ BuildArch: noarch
%description -n %{name}+default-devel %{_description} %description -n %{name}+default-devel %{_description}
This package contains library source intended for building other packages which This package contains library source intended for building other packages which
use "the default" feature of the "%{crate}" crate. use the "default" feature of the "%{crate}" crate.
%files -n %{name}+default-devel %files -n %{name}+default-devel
%ghost %{cargo_registry}/%{crate}-%{version_no_tilde}/Cargo.toml %ghost %{crate_instdir}/Cargo.toml
%prep %prep
%autosetup -n %{crate}-%{version_no_tilde} -p1 %autosetup -n %{crate}-%{version} -p1
%cargo_prep %cargo_prep
%generate_buildrequires %generate_buildrequires

@ -1 +1 @@
SHA512 (const-random-macro-0.1.13.crate) = 9c89b9a6164b58ed83cd888ae996a769d1d705a966fa1551f5024924638b7ac193cc6192dda84a34eebd1a66a2e26af1085aeed2afcd0f167a910e868df868b1 SHA512 (const-random-macro-0.1.16.crate) = 8478bc65b0845e765a69e09fe4152e89f3e3970d2d92e4b32bb0abb7b918c725f325d4b19a45d2a462905bedf837b3a23f31b1ed9dc8655ca502de72616b074d

Loading…
Cancel
Save