diff --git a/Cargo.toml b/Cargo.toml
index bd26079..ddabfae 100644
--- a/Cargo.toml
+++ b/Cargo.toml
@@ -28,6 +28,8 @@ napi = []
native_buffer = []
## Enables bindings to `native_window`
native_window = []
+## Enables bindings to `native_vsync`
+vsync = []
## Enables bindings to `native_xcomponent`
xcomponent = []
## Enables all components listed above. Orthogonal to `api-XX` features.
@@ -37,7 +39,8 @@ all-components = [
"napi",
"native_buffer",
"native_window",
- "xcomponent"]
+ "xcomponent",
+ "vsync"]
#! ### OpenHarmony API level
#! This crate by default exposes bindings for API-level 10.
diff --git a/Readme.md b/Readme.md
index 9e2accf..a466092 100644
--- a/Readme.md
+++ b/Readme.md
@@ -25,6 +25,8 @@ Please also check the following:
- Be sure to guard the new component behind a cargo feature and document the feature in Cargo.toml.
- If you did not generate the bindings with API-level 10, specify which API-level you generated the bindings with
and guard the generated module behind the corresponding api-level feature flag.
+- Installing `bindgen`: We use a version of bindgen that has not been released yet to crates.io.
+ You can install the latest version by running `cargo install --git https://github.com/rust-lang/rust-bindgen.git bindgen-cli --branch main --features prettyplease`
## License
diff --git a/scripts/generate_bindings.sh b/scripts/generate_bindings.sh
index b5847fb..6cf2396 100755
--- a/scripts/generate_bindings.sh
+++ b/scripts/generate_bindings.sh
@@ -6,7 +6,13 @@ ROOT_DIR=$( cd -- "$( dirname -- "${BASH_SOURCE[0]}" )"/.. &> /dev/null && pwd )
if ! command -v bindgen
then
- echo "Error: bindgen not found"
+ echo "Error: bindgen not found. Please install it."
+ exit 1
+fi
+
+if ! command -v jq
+then
+ echo "Error: jq not found. Please install it."
exit 1
fi
@@ -117,6 +123,16 @@ bindgen "${BASE_BINDGEN_ARGS[@]}" \
-- \
"${BASE_CLANG_ARGS[@]}"
+bindgen "${BASE_BINDGEN_ARGS[@]}" \
+ --default-enum-style=newtype \
+ --no-derive-copy \
+ --no-derive-debug \
+ --allowlist-file ".*/native_vsync\.h" \
+ --output "${ROOT_DIR}/src/vsync/vsync_api${OHOS_API_VERSION}.rs" \
+ "${OHOS_SYSROOT_DIR}/usr/include/native_vsync/native_vsync.h" \
+ -- \
+ "${BASE_CLANG_ARGS[@]}"
+
# API-10
DRAWING_NOCOPY_STRUCTS=(OH_Drawing_Canvas OH_Drawing_Pen OH_Drawing_Brush OH_Drawing_Path OH_Drawing_Bitmap)
DRAWING_NOCOPY_STRUCTS+=(OH_Drawing_FontCollection OH_Drawing_Typography OH_Drawing_TextStyle OH_Drawing_TypographyStyle)
diff --git a/src/lib.rs b/src/lib.rs
index 938c12d..1f0c534 100644
--- a/src/lib.rs
+++ b/src/lib.rs
@@ -26,12 +26,19 @@ pub mod hilog;
#[cfg(feature = "napi")]
#[cfg_attr(docsrs, doc(cfg(feature = "napi")))]
pub mod napi;
+
#[cfg(feature = "native_buffer")]
#[cfg_attr(docsrs, doc(cfg(feature = "native_buffer")))]
pub mod native_buffer;
+
#[cfg(feature = "native_window")]
#[cfg_attr(docsrs, doc(cfg(feature = "native_window")))]
pub mod native_window;
+
+#[cfg(feature = "vsync")]
+#[cfg_attr(docsrs, doc(cfg(feature = "vsync")))]
+pub mod vsync;
+
#[cfg(feature = "xcomponent")]
#[cfg_attr(docsrs, doc(cfg(feature = "xcomponent")))]
pub mod xcomponent;
diff --git a/src/vsync.rs b/src/vsync.rs
new file mode 100644
index 0000000..5909683
--- /dev/null
+++ b/src/vsync.rs
@@ -0,0 +1,7 @@
+//! Bindings to the native vsync APIs
+
+#[link(name = "native_vsync")]
+extern "C" {}
+
+mod vsync_api10;
+pub use vsync_api10::*;
diff --git a/src/vsync/vsync_api10.rs b/src/vsync/vsync_api10.rs
new file mode 100644
index 0000000..890e46f
--- /dev/null
+++ b/src/vsync/vsync_api10.rs
@@ -0,0 +1,62 @@
+/* automatically generated by rust-bindgen 0.69.4 */
+
+#![allow(non_upper_case_globals)]
+#![allow(non_camel_case_types)]
+#![allow(non_snake_case)]
+
+#[repr(C)]
+pub struct OH_NativeVSync {
+ _unused: [u8; 0],
+}
+pub type OH_NativeVSync_FrameCallback = ::core::option::Option<
+ unsafe extern "C" fn(timestamp: ::core::ffi::c_longlong, data: *mut ::core::ffi::c_void),
+>;
+extern "C" {
+ /** @brief Creates a NativeVsync instance.\n
+ A new NativeVsync instance is created each time this function is called.
+
+ @syscap SystemCapability.Graphic.Graphic2D.NativeVsync
+ @param name Indicates the vsync connection name.
+ @param length Indicates the name's length.
+ @return Returns the pointer to the NativeVsync instance created.
+ @since 9
+ @version 1.0*/
+ pub fn OH_NativeVSync_Create(
+ name: *const ::core::ffi::c_char,
+ length: ::core::ffi::c_uint,
+ ) -> *mut OH_NativeVSync;
+ /** @brief Delete the NativeVsync instance.
+
+ @syscap SystemCapability.Graphic.Graphic2D.NativeVsync
+ @param window Indicates the pointer to a NativeVsync instance.
+ @return Returns int32_t, return value == 0, success, otherwise, failed.
+ @since 9
+ @version 1.0*/
+ pub fn OH_NativeVSync_Destroy(nativeVsync: *mut OH_NativeVSync);
+ /** @brief Request next vsync with callback.
+
+ @syscap SystemCapability.Graphic.Graphic2D.NativeVsync
+ @param nativeVsync Indicates the pointer to a NativeVsync.
+ @param callback Indicates the OH_NativeVSync_FrameCallback which will be called when next vsync coming.
+ @param data Indicates data whick will be used in callback.
+ @return Returns int32_t, return value == 0, success, otherwise, failed.
+ @since 9
+ @version 1.0*/
+ pub fn OH_NativeVSync_RequestFrame(
+ nativeVsync: *mut OH_NativeVSync,
+ callback: OH_NativeVSync_FrameCallback,
+ data: *mut ::core::ffi::c_void,
+ ) -> ::core::ffi::c_int;
+ /** @brief Get vsync period.
+
+ @syscap SystemCapability.Graphic.Graphic2D.NativeVsync
+ @param nativeVsync Indicates the pointer to a NativeVsync.
+ @param period Indicates the vsync period.
+ @return Returns int32_t, return value == 0, success, otherwise, failed.
+ @since 10
+ @version 1.0*/
+ pub fn OH_NativeVSync_GetPeriod(
+ nativeVsync: *mut OH_NativeVSync,
+ period: *mut ::core::ffi::c_longlong,
+ ) -> ::core::ffi::c_int;
+}
diff --git a/src/vsync/vsync_api11.rs b/src/vsync/vsync_api11.rs
new file mode 100644
index 0000000..890e46f
--- /dev/null
+++ b/src/vsync/vsync_api11.rs
@@ -0,0 +1,62 @@
+/* automatically generated by rust-bindgen 0.69.4 */
+
+#![allow(non_upper_case_globals)]
+#![allow(non_camel_case_types)]
+#![allow(non_snake_case)]
+
+#[repr(C)]
+pub struct OH_NativeVSync {
+ _unused: [u8; 0],
+}
+pub type OH_NativeVSync_FrameCallback = ::core::option::Option<
+ unsafe extern "C" fn(timestamp: ::core::ffi::c_longlong, data: *mut ::core::ffi::c_void),
+>;
+extern "C" {
+ /** @brief Creates a NativeVsync instance.\n
+ A new NativeVsync instance is created each time this function is called.
+
+ @syscap SystemCapability.Graphic.Graphic2D.NativeVsync
+ @param name Indicates the vsync connection name.
+ @param length Indicates the name's length.
+ @return Returns the pointer to the NativeVsync instance created.
+ @since 9
+ @version 1.0*/
+ pub fn OH_NativeVSync_Create(
+ name: *const ::core::ffi::c_char,
+ length: ::core::ffi::c_uint,
+ ) -> *mut OH_NativeVSync;
+ /** @brief Delete the NativeVsync instance.
+
+ @syscap SystemCapability.Graphic.Graphic2D.NativeVsync
+ @param window Indicates the pointer to a NativeVsync instance.
+ @return Returns int32_t, return value == 0, success, otherwise, failed.
+ @since 9
+ @version 1.0*/
+ pub fn OH_NativeVSync_Destroy(nativeVsync: *mut OH_NativeVSync);
+ /** @brief Request next vsync with callback.
+
+ @syscap SystemCapability.Graphic.Graphic2D.NativeVsync
+ @param nativeVsync Indicates the pointer to a NativeVsync.
+ @param callback Indicates the OH_NativeVSync_FrameCallback which will be called when next vsync coming.
+ @param data Indicates data whick will be used in callback.
+ @return Returns int32_t, return value == 0, success, otherwise, failed.
+ @since 9
+ @version 1.0*/
+ pub fn OH_NativeVSync_RequestFrame(
+ nativeVsync: *mut OH_NativeVSync,
+ callback: OH_NativeVSync_FrameCallback,
+ data: *mut ::core::ffi::c_void,
+ ) -> ::core::ffi::c_int;
+ /** @brief Get vsync period.
+
+ @syscap SystemCapability.Graphic.Graphic2D.NativeVsync
+ @param nativeVsync Indicates the pointer to a NativeVsync.
+ @param period Indicates the vsync period.
+ @return Returns int32_t, return value == 0, success, otherwise, failed.
+ @since 10
+ @version 1.0*/
+ pub fn OH_NativeVSync_GetPeriod(
+ nativeVsync: *mut OH_NativeVSync,
+ period: *mut ::core::ffi::c_longlong,
+ ) -> ::core::ffi::c_int;
+}
diff --git a/src/vsync/vsync_api12.rs b/src/vsync/vsync_api12.rs
new file mode 100644
index 0000000..890e46f
--- /dev/null
+++ b/src/vsync/vsync_api12.rs
@@ -0,0 +1,62 @@
+/* automatically generated by rust-bindgen 0.69.4 */
+
+#![allow(non_upper_case_globals)]
+#![allow(non_camel_case_types)]
+#![allow(non_snake_case)]
+
+#[repr(C)]
+pub struct OH_NativeVSync {
+ _unused: [u8; 0],
+}
+pub type OH_NativeVSync_FrameCallback = ::core::option::Option<
+ unsafe extern "C" fn(timestamp: ::core::ffi::c_longlong, data: *mut ::core::ffi::c_void),
+>;
+extern "C" {
+ /** @brief Creates a NativeVsync instance.\n
+ A new NativeVsync instance is created each time this function is called.
+
+ @syscap SystemCapability.Graphic.Graphic2D.NativeVsync
+ @param name Indicates the vsync connection name.
+ @param length Indicates the name's length.
+ @return Returns the pointer to the NativeVsync instance created.
+ @since 9
+ @version 1.0*/
+ pub fn OH_NativeVSync_Create(
+ name: *const ::core::ffi::c_char,
+ length: ::core::ffi::c_uint,
+ ) -> *mut OH_NativeVSync;
+ /** @brief Delete the NativeVsync instance.
+
+ @syscap SystemCapability.Graphic.Graphic2D.NativeVsync
+ @param window Indicates the pointer to a NativeVsync instance.
+ @return Returns int32_t, return value == 0, success, otherwise, failed.
+ @since 9
+ @version 1.0*/
+ pub fn OH_NativeVSync_Destroy(nativeVsync: *mut OH_NativeVSync);
+ /** @brief Request next vsync with callback.
+
+ @syscap SystemCapability.Graphic.Graphic2D.NativeVsync
+ @param nativeVsync Indicates the pointer to a NativeVsync.
+ @param callback Indicates the OH_NativeVSync_FrameCallback which will be called when next vsync coming.
+ @param data Indicates data whick will be used in callback.
+ @return Returns int32_t, return value == 0, success, otherwise, failed.
+ @since 9
+ @version 1.0*/
+ pub fn OH_NativeVSync_RequestFrame(
+ nativeVsync: *mut OH_NativeVSync,
+ callback: OH_NativeVSync_FrameCallback,
+ data: *mut ::core::ffi::c_void,
+ ) -> ::core::ffi::c_int;
+ /** @brief Get vsync period.
+
+ @syscap SystemCapability.Graphic.Graphic2D.NativeVsync
+ @param nativeVsync Indicates the pointer to a NativeVsync.
+ @param period Indicates the vsync period.
+ @return Returns int32_t, return value == 0, success, otherwise, failed.
+ @since 10
+ @version 1.0*/
+ pub fn OH_NativeVSync_GetPeriod(
+ nativeVsync: *mut OH_NativeVSync,
+ period: *mut ::core::ffi::c_longlong,
+ ) -> ::core::ffi::c_int;
+}