From 64e841a9df965819726c1b8729d483a1519a0b9f Mon Sep 17 00:00:00 2001 From: Andy Ragusa Date: Wed, 22 May 2024 14:54:08 -0700 Subject: [PATCH] Added check for empty data --- libclamav_rust/src/alz.rs | 4 +++- libclamav_rust/src/scanners.rs | 6 +++--- 2 files changed, 6 insertions(+), 4 deletions(-) diff --git a/libclamav_rust/src/alz.rs b/libclamav_rust/src/alz.rs index 56674fb9c6..fef676a0db 100644 --- a/libclamav_rust/src/alz.rs +++ b/libclamav_rust/src/alz.rs @@ -358,7 +358,9 @@ impl AlzLocalFileHeader { data: buffer.to_vec(), }; - files.push(extracted_file); + if 0 != extracted_file.data.len() { + files.push(extracted_file); + } } fn extract_file_nocomp( diff --git a/libclamav_rust/src/scanners.rs b/libclamav_rust/src/scanners.rs index aa4c7d133f..2b47667bcd 100644 --- a/libclamav_rust/src/scanners.rs +++ b/libclamav_rust/src/scanners.rs @@ -49,8 +49,8 @@ pub fn magic_scan(ctx: *mut cli_ctx, buf: &[u8], name: Option) -> cl_err let ptr = buf.as_ptr(); let len = buf.len(); - if 0 == len{ - return cl_error_t_CL_SUCCESS ; + if 0 == len { + return cl_error_t_CL_SUCCESS; } match &name { @@ -79,7 +79,7 @@ pub fn magic_scan(ctx: *mut cli_ctx, buf: &[u8], name: Option) -> cl_err } // Okay now safe to drop the name CString. - if !name_ptr.is_null(){ + if !name_ptr.is_null() { let _ = unsafe { CString::from_raw(name_ptr) }; }