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