aboutsummaryrefslogtreecommitdiff
path: root/src/platform/macos.rs
diff options
context:
space:
mode:
authorAmir M. Saeid <amir@glgdgt.com>2025-06-29 21:53:17 +0100
committerGitHub <noreply@github.com>2025-06-29 21:53:17 +0100
commit5da6e6d7e3c3c206ffd38825b848e6d5fd8ffd81 (patch)
tree8fab02477ee4797b3bb772c7f9719cbe22691a95 /src/platform/macos.rs
parent86ae6e4ff18477f0d598367fba09f940b7b62cd8 (diff)
parent7a9375a3b2cccbbc0fd9373c1cd1101082b68499 (diff)
Merge pull request #6 from amir/add-macos-supportHEADmaster
Add macOS support
Diffstat (limited to 'src/platform/macos.rs')
-rw-r--r--src/platform/macos.rs44
1 files changed, 44 insertions, 0 deletions
diff --git a/src/platform/macos.rs b/src/platform/macos.rs
new file mode 100644
index 0000000..0292250
--- /dev/null
+++ b/src/platform/macos.rs
@@ -0,0 +1,44 @@
+use core_graphics::display::CGDisplay;
+
+pub fn set_temp(temp: u32) {
+ use std::os::raw::c_int;
+
+ let ratio: f64 = (temp % 500) as f64 / 500f64;
+ let gamma = crate::avg(temp, ratio);
+
+ let main_display = CGDisplay::main();
+
+ extern "C" {
+ fn CGSetDisplayTransferByTable(
+ display: u32,
+ table_size: u32,
+ red_table: *const f32,
+ green_table: *const f32,
+ blue_table: *const f32,
+ ) -> c_int;
+ fn CGDisplayGammaTableCapacity(display: u32) -> u32;
+ }
+
+ let table_size = unsafe { CGDisplayGammaTableCapacity(main_display.id) } as usize;
+
+ let mut red_table = vec![0.0; table_size];
+ let mut green_table = vec![0.0; table_size];
+ let mut blue_table = vec![0.0; table_size];
+
+ for i in 0..table_size {
+ let value = (i as f32) / (table_size as f32 - 1.0);
+ red_table[i] = (value * gamma.red as f32).min(1.0);
+ green_table[i] = (value * gamma.green as f32).min(1.0);
+ blue_table[i] = (value * gamma.blue as f32).min(1.0);
+ }
+
+ unsafe {
+ CGSetDisplayTransferByTable(
+ main_display.id,
+ table_size as u32,
+ red_table.as_ptr(),
+ green_table.as_ptr(),
+ blue_table.as_ptr(),
+ );
+ }
+}