cef_dll_sys/
lib.rs

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
//! # cef-dll-sys
//!
//! Generated bindings for the prebuilt [Chromium Embedded Framework](https://github.com/chromiumembedded/cef)
//! C API on any supported platform.

#[allow(
    non_snake_case,
    non_camel_case_types,
    non_upper_case_globals,
    dead_code,
    clippy::all
)]
mod bindings;
pub use bindings::*;

#[cfg(target_os = "windows")]
impl Default for HWND {
    fn default() -> Self {
        Self(std::ptr::null_mut())
    }
}

#[cfg(target_os = "windows")]
impl Default for HINSTANCE {
    fn default() -> Self {
        Self(std::ptr::null_mut())
    }
}

#[cfg(target_os = "macos")]
pub const FRAMEWORK_PATH: &str =
    "Chromium Embedded Framework.framework/Chromium Embedded Framework";

use std::{
    env::{
        self,
        consts::{ARCH, OS},
    },
    fs,
    path::PathBuf,
};

pub fn get_cef_dir() -> Option<PathBuf> {
    let cef_path_env = env::var("FLATPAK")
        .map(|_| String::from("/usr/lib"))
        .or_else(|_| env::var("CEF_PATH"));

    match cef_path_env {
        Ok(cef_path) => {
            // Allow overriding the CEF path with environment variables.
            PathBuf::from(cef_path).canonicalize().ok()
        }
        Err(_) => {
            let out_dir = PathBuf::from(env::var("OUT_DIR").ok()?);
            let cef_dir = format!("cef_{OS}_{ARCH}");
            let cef_dir = out_dir.join(&cef_dir).canonicalize().ok()?;
            fs::exists(&cef_dir).ok()?.then_some(cef_dir)
        }
    }
}

#[cfg(test)]
mod test {
    use super::*;

    #[test]
    fn test_cef_dir() {
        let _ = get_cef_dir().expect("CEF not found");
    }

    #[test]
    fn test_init() {
        use std::ptr::*;

        unsafe {
            #[cfg(target_os = "macos")]
            {
                use std::os::unix::ffi::OsStrExt;

                let cef_dir = get_cef_dir().expect("CEF not found");
                let framework_dir = cef_dir
                    .join(FRAMEWORK_PATH)
                    .canonicalize()
                    .expect("failed to get framework path");
                let framework_dir = std::ffi::CString::new(framework_dir.as_os_str().as_bytes())
                    .expect("invalid path");

                assert_eq!(cef_load_library(framework_dir.as_ptr().cast()), 1);
            }

            assert_eq!(cef_initialize(null(), null(), null_mut(), null_mut()), 0);
        };
    }
}