From 7625e7cf608f6cb1914f8046fd531a3e21746a38 Mon Sep 17 00:00:00 2001 From: Inflation <2375962+inflation@users.noreply.github.com> Date: Tue, 22 Oct 2024 16:11:49 +0800 Subject: [PATCH] fix: update extern "C" to extern "C-unwind" in multiple files --- jpegxl-sys/src/color/cms.rs | 2 +- jpegxl-sys/src/color/cms_interface.rs | 11 ++++++----- jpegxl-sys/src/decode.rs | 2 +- jpegxl-sys/src/encoder/encode.rs | 2 +- jpegxl-sys/src/encoder/stats.rs | 2 +- jpegxl-sys/src/metadata/compressed_icc.rs | 2 +- jpegxl-sys/src/metadata/gain_map.rs | 2 +- 7 files changed, 12 insertions(+), 11 deletions(-) diff --git a/jpegxl-sys/src/color/cms.rs b/jpegxl-sys/src/color/cms.rs index f7ee801..866afbe 100644 --- a/jpegxl-sys/src/color/cms.rs +++ b/jpegxl-sys/src/color/cms.rs @@ -19,6 +19,6 @@ along with jpegxl-sys. If not, see . use super::cms_interface::JxlCmsInterface; -extern "C" { +extern "C-unwind" { pub fn JxlGetDefaultCms() -> *const JxlCmsInterface; } diff --git a/jpegxl-sys/src/color/cms_interface.rs b/jpegxl-sys/src/color/cms_interface.rs index 36c4fbc..f74b36c 100644 --- a/jpegxl-sys/src/color/cms_interface.rs +++ b/jpegxl-sys/src/color/cms_interface.rs @@ -28,7 +28,7 @@ use crate::common::types::JxlBool; use super::color_encoding::JxlColorEncoding; -pub type JpegXlCmsSetFieldsFromIccFunc = extern "C" fn( +pub type JpegXlCmsSetFieldsFromIccFunc = extern "C-unwind" fn( user_data: *mut c_void, icc_data: *const u8, icc_size: usize, @@ -51,7 +51,7 @@ pub struct JxlColorProfile { pub num_channels: usize, } -pub type JpegXlCmsInitFunc = extern "C" fn( +pub type JpegXlCmsInitFunc = extern "C-unwind" fn( init_data: *mut c_void, num_threads: usize, pixels_per_thread: usize, @@ -60,9 +60,10 @@ pub type JpegXlCmsInitFunc = extern "C" fn( intensity_target: f32, ) -> *mut c_void; -pub type JpegXlCmsGetBufferFunc = extern "C" fn(user_data: *mut c_void, thread: usize) -> *mut f32; +pub type JpegXlCmsGetBufferFunc = + extern "C-unwind" fn(user_data: *mut c_void, thread: usize) -> *mut f32; -pub type JpegXlCmsRunFunc = extern "C" fn( +pub type JpegXlCmsRunFunc = extern "C-unwind" fn( user_data: *mut c_void, thread: usize, input_buffer: *const f32, @@ -70,7 +71,7 @@ pub type JpegXlCmsRunFunc = extern "C" fn( num_pixels: usize, ) -> JxlBool; -pub type JpegXlCmsDestroyFun = extern "C" fn(user_data: *mut c_void); +pub type JpegXlCmsDestroyFun = extern "C-unwind" fn(user_data: *mut c_void); #[repr(C)] #[derive(Debug, Clone)] diff --git a/jpegxl-sys/src/decode.rs b/jpegxl-sys/src/decode.rs index 31d031c..e9b3d5b 100644 --- a/jpegxl-sys/src/decode.rs +++ b/jpegxl-sys/src/decode.rs @@ -360,7 +360,7 @@ pub type JxlImageOutRunCallback = extern "C" fn( /// - `run_opaque`: user data returned by the [`init`](JxlImageOutInitCallback) callback. pub type JxlImageOutDestroyCallback = extern "C" fn(run_opaque: *mut c_void); -extern "C" { +extern "C-unwind" { /// Decoder library version. /// /// # Returns diff --git a/jpegxl-sys/src/encoder/encode.rs b/jpegxl-sys/src/encoder/encode.rs index e862f23..8171227 100644 --- a/jpegxl-sys/src/encoder/encode.rs +++ b/jpegxl-sys/src/encoder/encode.rs @@ -565,7 +565,7 @@ pub type JxlDebugImageCallback = extern "C-unwind" fn( pixels: *const u16, ); -extern "C" { +extern "C-unwind" { /// Encoder library version. /// /// # Returns diff --git a/jpegxl-sys/src/encoder/stats.rs b/jpegxl-sys/src/encoder/stats.rs index 4ee94dc..fa1bc97 100644 --- a/jpegxl-sys/src/encoder/stats.rs +++ b/jpegxl-sys/src/encoder/stats.rs @@ -29,7 +29,7 @@ pub struct JxlEncoderStats { _unused: [u8; 0], } -extern "C" { +extern "C-unwind" { /// Creates an instance of [`JxlEncoderStats`] and initializes it. /// /// # Returns diff --git a/jpegxl-sys/src/metadata/compressed_icc.rs b/jpegxl-sys/src/metadata/compressed_icc.rs index aaa4cb9..9c398ec 100644 --- a/jpegxl-sys/src/metadata/compressed_icc.rs +++ b/jpegxl-sys/src/metadata/compressed_icc.rs @@ -19,7 +19,7 @@ along with jpegxl-sys. If not, see . use crate::common::{memory_manager, types::JxlBool}; -extern "C" { +extern "C-unwind" { /// Allocates a buffer using the memory manager, fills it with a compressed /// representation of an ICC profile, returns the result through `output_buffer` /// and indicates its size through `output_size`. diff --git a/jpegxl-sys/src/metadata/gain_map.rs b/jpegxl-sys/src/metadata/gain_map.rs index df728f0..88a2ea0 100644 --- a/jpegxl-sys/src/metadata/gain_map.rs +++ b/jpegxl-sys/src/metadata/gain_map.rs @@ -60,7 +60,7 @@ pub struct JxlGainMapBundle { pub gain_map: *const u8, } -extern "C" { +extern "C-unwind" { /// Calculates the total size required to serialize the gain map bundle into a /// binary buffer. This function accounts for all the necessary space to /// serialize fields such as gain map metadata, color encoding, compressed ICC