From cfc6d589dae523e0859969d9d052609e320a17da Mon Sep 17 00:00:00 2001 From: Folkert de Vries Date: Wed, 6 Nov 2024 16:53:33 +0100 Subject: [PATCH 1/4] cleanup the assert logic --- bzlib.rs | 63 ++------------------------------ c2rust-lib.rs | 99 ++++++++++++++++++++++++++++++++++++++++++++++----- 2 files changed, 92 insertions(+), 70 deletions(-) diff --git a/bzlib.rs b/bzlib.rs index 3a2ef6b01..55db18907 100644 --- a/bzlib.rs +++ b/bzlib.rs @@ -1,13 +1,12 @@ use core::ffi::{c_char, c_int, c_uint, c_void, CStr}; use libc::FILE; -use libc::{ - exit, fclose, fdopen, ferror, fflush, fgetc, fopen, fread, free, fwrite, malloc, ungetc, -}; +use libc::{fclose, fdopen, ferror, fflush, fgetc, fopen, fread, free, fwrite, malloc, ungetc}; use crate::compress::BZ2_compressBlock; use crate::crctable::BZ2_CRC32TABLE; use crate::decompress::{self, BZ2_decompress}; +use crate::libbzip2_rs_sys_version; extern "C" { static stdin: *mut FILE; @@ -75,12 +74,6 @@ macro_rules! prefix { }; } -macro_rules! libbzip2_rs_sys_version { - () => { - concat!("1.1.0-libbzip2-rs-sys-", env!("CARGO_PKG_VERSION")) - }; -} - const LIBBZIP2_RS_SYS_VERSION: &str = concat!(libbzip2_rs_sys_version!(), "\0"); /// The version of the zlib library. @@ -489,58 +482,6 @@ pub struct bzFile { pub initialisedOk: bool, } -pub fn BZ2_bz__AssertH__fail(errcode: libc::c_int) { - eprint!( - concat!( - "\n", - "\n", - "bzip2/libbzip2: internal error number {}.\n", - "This is a bug in bzip2/libbzip2, {}.\n", - "Please report it at: https://gitlab.com/bzip2/bzip2/-/issues\n", - "If this happened when you were using some program which uses\n", - "libbzip2 as a component, you should also report this bug to\n", - "the author(s) of that program.\n", - "Please make an effort to report this bug;\n", - "timely and accurate bug reports eventually lead to higher\n", - "quality software. Thanks.\n", - "\n" - ), - errcode, - libbzip2_rs_sys_version!(), - ); - if errcode == 1007 as libc::c_int { - eprint!(concat!( - "\n", - "*** A special note about internal error number 1007 ***\n", - "\n", - "Experience suggests that a common cause of i.e. 1007\n", - "is unreliable memory or other hardware. The 1007 assertion\n", - "just happens to cross-check the results of huge numbers of\n", - "memory reads/writes, and so acts (unintendedly) as a stress\n", - "test of your memory system.\n", - "\n", - "I suggest the following: try compressing the file again,\n", - "possibly monitoring progress in detail with the -vv flag.\n", - "\n", - "* If the error cannot be reproduced, and/or happens at different\n", - " points in compression, you may have a flaky memory system.\n", - " Try a memory-test program. I have used Memtest86\n", - " (www.memtest86.com). At the time of writing it is free (GPLd).\n", - " Memtest86 tests memory much more thorougly than your BIOSs\n", - " power-on test, and may find failures that the BIOS doesn't.\n", - "\n", - "* If the error can be repeatably reproduced, this is a bug in\n", - " bzip2, and I would very much like to hear about it. Please\n", - " let me know, and, ideally, save a copy of the file causing the\n", - " problem -- without which I will be unable to investigate it.\n", - "\n" - )); - } - unsafe { - exit(3 as libc::c_int); - } -} - const _C_INT_SIZE: () = assert!(core::mem::size_of::() == 4); const _C_SHORT_SIZE: () = assert!(core::mem::size_of::() == 2); const _C_CHAR_SIZE: () = assert!(core::mem::size_of::() == 1); diff --git a/c2rust-lib.rs b/c2rust-lib.rs index 495274979..7f9340eac 100644 --- a/c2rust-lib.rs +++ b/c2rust-lib.rs @@ -17,15 +17,6 @@ mod decompress; mod huffman; mod randtable; -#[macro_export] -macro_rules! assert_h { - ($condition:expr, $errcode:expr) => {{ - if !$condition { - $crate::bzlib::BZ2_bz__AssertH__fail($errcode); - } - }}; -} - pub(crate) use bzlib::{Action, ReturnCode}; pub const BZ_OK: c_int = ReturnCode::BZ_OK as c_int; @@ -66,3 +57,93 @@ pub use bzlib::{ BZ2_bzclose, BZ2_bzdopen, BZ2_bzerror, BZ2_bzflush, BZ2_bzlibVersion, BZ2_bzopen, BZ2_bzread, BZ2_bzwrite, }; + +// --- version number logic + +macro_rules! libbzip2_rs_sys_version { + () => { + concat!("1.1.0-libbzip2-rs-sys-", env!("CARGO_PKG_VERSION")) + }; +} + +pub(crate) use libbzip2_rs_sys_version; + +// --- assert failure logic + +macro_rules! assert_h { + ($condition:expr, $errcode:expr) => {{ + if !$condition { + eprint!("{}", $crate::AssertFail($errcode)); + std::process::exit(3); + } + }}; +} + +pub(crate) use assert_h; + +pub(crate) struct AssertFail(i32); + +impl core::fmt::Display for AssertFail { + fn fmt(&self, f: &mut std::fmt::Formatter<'_>) -> std::fmt::Result { + f.write_fmt(format_args!( + concat!( + "\n", + "\n", + "bzip2/libbzip2: internal error number {}.\n", + "This is a bug in bzip2/libbzip2, {}.\n", + "Please report it at: https://gitlab.com/bzip2/bzip2/-/issues\n", + "If this happened when you were using some program which uses\n", + "libbzip2 as a component, you should also report this bug to\n", + "the author(s) of that program.\n", + "Please make an effort to report this bug;\n", + "timely and accurate bug reports eventually lead to higher\n", + "quality software. Thanks.\n", + "\n" + ), + self.0, + libbzip2_rs_sys_version!(), + ))?; + + if self.0 == 1007 { + f.write_fmt(format_args!(concat!( + "\n", + "*** A special note about internal error number 1007 ***\n", + "\n", + "Experience suggests that a common cause of i.e. 1007\n", + "is unreliable memory or other hardware. The 1007 assertion\n", + "just happens to cross-check the results of huge numbers of\n", + "memory reads/writes, and so acts (unintendedly) as a stress\n", + "test of your memory system.\n", + "\n", + "I suggest the following: try compressing the file again,\n", + "possibly monitoring progress in detail with the -vv flag.\n", + "\n", + "* If the error cannot be reproduced, and/or happens at different\n", + " points in compression, you may have a flaky memory system.\n", + " Try a memory-test program. I have used Memtest86\n", + " (www.memtest86.com). At the time of writing it is free (GPLd).\n", + " Memtest86 tests memory much more thorougly than your BIOSs\n", + " power-on test, and may find failures that the BIOS doesn't.\n", + "\n", + "* If the error can be repeatably reproduced, this is a bug in\n", + " bzip2, and I would very much like to hear about it. Please\n", + " let me know, and, ideally, save a copy of the file causing the\n", + " problem -- without which I will be unable to investigate it.\n", + "\n" + )))?; + } + + Ok(()) + } +} + +#[cfg(test)] +mod test { + use super::*; + + #[test] + fn print_assert_fail_coverage() { + use core::fmt::Write; + write!(&mut String::new(), "{}", AssertFail(1007)).unwrap(); + } +} From b04fa6ec08d6f5c6e2cf4913c181bd52fa51f1ae Mon Sep 17 00:00:00 2001 From: Folkert de Vries Date: Fri, 8 Nov 2024 14:11:27 +0100 Subject: [PATCH 2/4] `assert_h`: refer to our repo --- c2rust-lib.rs | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/c2rust-lib.rs b/c2rust-lib.rs index 7f9340eac..c130c089a 100644 --- a/c2rust-lib.rs +++ b/c2rust-lib.rs @@ -91,7 +91,7 @@ impl core::fmt::Display for AssertFail { "\n", "bzip2/libbzip2: internal error number {}.\n", "This is a bug in bzip2/libbzip2, {}.\n", - "Please report it at: https://gitlab.com/bzip2/bzip2/-/issues\n", + "Please report it at: https://github.com/trifectatechfoundation/libbzip2-rs/issues\n", "If this happened when you were using some program which uses\n", "libbzip2 as a component, you should also report this bug to\n", "the author(s) of that program.\n", From 76da3c806f51172846bd18889f396cb53679b53f Mon Sep 17 00:00:00 2001 From: Folkert de Vries Date: Fri, 8 Nov 2024 14:11:41 +0100 Subject: [PATCH 3/4] `assert_h`: use the `write!` macro --- c2rust-lib.rs | 60 +++++++++++++++++++++++++++------------------------ 1 file changed, 32 insertions(+), 28 deletions(-) diff --git a/c2rust-lib.rs b/c2rust-lib.rs index c130c089a..c05579692 100644 --- a/c2rust-lib.rs +++ b/c2rust-lib.rs @@ -85,7 +85,8 @@ pub(crate) struct AssertFail(i32); impl core::fmt::Display for AssertFail { fn fmt(&self, f: &mut std::fmt::Formatter<'_>) -> std::fmt::Result { - f.write_fmt(format_args!( + write!( + f, concat!( "\n", "\n", @@ -102,35 +103,38 @@ impl core::fmt::Display for AssertFail { ), self.0, libbzip2_rs_sys_version!(), - ))?; + )?; if self.0 == 1007 { - f.write_fmt(format_args!(concat!( - "\n", - "*** A special note about internal error number 1007 ***\n", - "\n", - "Experience suggests that a common cause of i.e. 1007\n", - "is unreliable memory or other hardware. The 1007 assertion\n", - "just happens to cross-check the results of huge numbers of\n", - "memory reads/writes, and so acts (unintendedly) as a stress\n", - "test of your memory system.\n", - "\n", - "I suggest the following: try compressing the file again,\n", - "possibly monitoring progress in detail with the -vv flag.\n", - "\n", - "* If the error cannot be reproduced, and/or happens at different\n", - " points in compression, you may have a flaky memory system.\n", - " Try a memory-test program. I have used Memtest86\n", - " (www.memtest86.com). At the time of writing it is free (GPLd).\n", - " Memtest86 tests memory much more thorougly than your BIOSs\n", - " power-on test, and may find failures that the BIOS doesn't.\n", - "\n", - "* If the error can be repeatably reproduced, this is a bug in\n", - " bzip2, and I would very much like to hear about it. Please\n", - " let me know, and, ideally, save a copy of the file causing the\n", - " problem -- without which I will be unable to investigate it.\n", - "\n" - )))?; + write!( + f, + concat!( + "\n", + "*** A special note about internal error number 1007 ***\n", + "\n", + "Experience suggests that a common cause of i.e. 1007\n", + "is unreliable memory or other hardware. The 1007 assertion\n", + "just happens to cross-check the results of huge numbers of\n", + "memory reads/writes, and so acts (unintendedly) as a stress\n", + "test of your memory system.\n", + "\n", + "I suggest the following: try compressing the file again,\n", + "possibly monitoring progress in detail with the -vv flag.\n", + "\n", + "* If the error cannot be reproduced, and/or happens at different\n", + " points in compression, you may have a flaky memory system.\n", + " Try a memory-test program. I have used Memtest86\n", + " (www.memtest86.com). At the time of writing it is free (GPLd).\n", + " Memtest86 tests memory much more thorougly than your BIOSs\n", + " power-on test, and may find failures that the BIOS doesn't.\n", + "\n", + "* If the error can be repeatably reproduced, this is a bug in\n", + " bzip2, and I would very much like to hear about it. Please\n", + " let me know, and, ideally, save a copy of the file causing the\n", + " problem -- without which I will be unable to investigate it.\n", + "\n" + ) + )?; } Ok(()) From c68b53c01ce79d5cb689106662e2953fcd51b4a3 Mon Sep 17 00:00:00 2001 From: Folkert de Vries Date: Fri, 8 Nov 2024 14:13:53 +0100 Subject: [PATCH 4/4] `assert_h`: refer to `libbzip2-rs` instead of `libbzip2` --- c2rust-lib.rs | 6 +++--- 1 file changed, 3 insertions(+), 3 deletions(-) diff --git a/c2rust-lib.rs b/c2rust-lib.rs index c05579692..e80278d66 100644 --- a/c2rust-lib.rs +++ b/c2rust-lib.rs @@ -90,11 +90,11 @@ impl core::fmt::Display for AssertFail { concat!( "\n", "\n", - "bzip2/libbzip2: internal error number {}.\n", - "This is a bug in bzip2/libbzip2, {}.\n", + "libbzip2-rs: internal error number {}.\n", + "This is a bug in libbzip2-rs, {}.\n", "Please report it at: https://github.com/trifectatechfoundation/libbzip2-rs/issues\n", "If this happened when you were using some program which uses\n", - "libbzip2 as a component, you should also report this bug to\n", + "libbzip2-rs as a component, you should also report this bug to\n", "the author(s) of that program.\n", "Please make an effort to report this bug;\n", "timely and accurate bug reports eventually lead to higher\n",