Merge pull request #278 from adumbidiot/fix-issue-277

Convert bindgen `rustified_enum` to `newtype_enum`
This commit is contained in:
LongYinan 2020-11-03 14:12:55 +08:00 committed by GitHub
commit 8b98744b9a
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
7 changed files with 98 additions and 81 deletions

View file

@ -1,3 +1,5 @@
use std::convert::TryFrom;
use std::convert::TryInto;
use std::mem; use std::mem;
use std::ops::Deref; use std::ops::Deref;
use std::os::raw::c_void; use std::os::raw::c_void;
@ -5,7 +7,7 @@ use std::ptr;
use super::{Value, ValueType}; use super::{Value, ValueType};
use crate::error::check_status; use crate::error::check_status;
use crate::{sys, JsUnknown, NapiValue, Ref, Result}; use crate::{sys, Error, JsUnknown, NapiValue, Ref, Result, Status};
#[repr(transparent)] #[repr(transparent)]
#[derive(Debug)] #[derive(Debug)]
@ -59,22 +61,25 @@ pub enum TypedArrayType {
BigUint64, BigUint64,
} }
impl From<sys::napi_typedarray_type> for TypedArrayType { impl TryFrom<sys::napi_typedarray_type> for TypedArrayType {
fn from(value: sys::napi_typedarray_type) -> Self { type Error = Error;
fn try_from(value: sys::napi_typedarray_type) -> Result<Self> {
match value { match value {
sys::napi_typedarray_type::napi_int8_array => Self::Int8, sys::napi_typedarray_type::napi_int8_array => Ok(Self::Int8),
sys::napi_typedarray_type::napi_uint8_array => Self::Uint8, sys::napi_typedarray_type::napi_uint8_array => Ok(Self::Uint8),
sys::napi_typedarray_type::napi_uint8_clamped_array => Self::Uint8Clamped, sys::napi_typedarray_type::napi_uint8_clamped_array => Ok(Self::Uint8Clamped),
sys::napi_typedarray_type::napi_int16_array => Self::Int16, sys::napi_typedarray_type::napi_int16_array => Ok(Self::Int16),
sys::napi_typedarray_type::napi_uint16_array => Self::Uint16, sys::napi_typedarray_type::napi_uint16_array => Ok(Self::Uint16),
sys::napi_typedarray_type::napi_int32_array => Self::Int32, sys::napi_typedarray_type::napi_int32_array => Ok(Self::Int32),
sys::napi_typedarray_type::napi_uint32_array => Self::Uint32, sys::napi_typedarray_type::napi_uint32_array => Ok(Self::Uint32),
sys::napi_typedarray_type::napi_float32_array => Self::Float32, sys::napi_typedarray_type::napi_float32_array => Ok(Self::Float32),
sys::napi_typedarray_type::napi_float64_array => Self::Float64, sys::napi_typedarray_type::napi_float64_array => Ok(Self::Float64),
#[cfg(napi6)] #[cfg(napi6)]
sys::napi_typedarray_type::napi_bigint64_array => Self::BigInt64, sys::napi_typedarray_type::napi_bigint64_array => Ok(Self::BigInt64),
#[cfg(napi6)] #[cfg(napi6)]
sys::napi_typedarray_type::napi_biguint64_array => Self::BigUint64, sys::napi_typedarray_type::napi_biguint64_array => Ok(Self::BigUint64),
_ => Err(Error::from_status(Status::Unknown)),
} }
} }
} }
@ -234,7 +239,7 @@ impl JsTypedArray {
data, data,
length: len, length: len,
byte_offset, byte_offset,
typedarray_type: typedarray_type.into(), typedarray_type: typedarray_type.try_into()?,
arraybuffer: JsArrayBuffer::from_raw_unchecked(self.0.env, arraybuffer_value), arraybuffer: JsArrayBuffer::from_raw_unchecked(self.0.env, arraybuffer_value),
}) })
} }

View file

@ -78,7 +78,7 @@ pub(crate) fn type_of(env: sys::napi_env, raw_value: sys::napi_value) -> Result<
unsafe { unsafe {
let mut value_type = sys::napi_valuetype::napi_undefined; let mut value_type = sys::napi_valuetype::napi_undefined;
check_status(sys::napi_typeof(env, raw_value, &mut value_type))?; check_status(sys::napi_typeof(env, raw_value, &mut value_type))?;
Ok(ValueType::from(value_type)) ValueType::try_from(value_type)
} }
} }

View file

@ -1,5 +1,7 @@
use super::Value; use super::Value;
use crate::sys; use crate::sys;
use crate::{Error, Result, Status};
use std::convert::TryFrom;
#[repr(transparent)] #[repr(transparent)]
#[derive(Debug)] #[derive(Debug)]
@ -12,11 +14,14 @@ pub enum KeyCollectionMode {
} }
#[cfg(napi6)] #[cfg(napi6)]
impl From<sys::napi_key_collection_mode> for KeyCollectionMode { impl TryFrom<sys::napi_key_collection_mode> for KeyCollectionMode {
fn from(value: sys::napi_key_collection_mode) -> Self { type Error = Error;
fn try_from(value: sys::napi_key_collection_mode) -> Result<Self> {
match value { match value {
sys::napi_key_collection_mode::napi_key_include_prototypes => Self::IncludePrototypes, sys::napi_key_collection_mode::napi_key_include_prototypes => Ok(Self::IncludePrototypes),
sys::napi_key_collection_mode::napi_key_own_only => Self::OwnOnly, sys::napi_key_collection_mode::napi_key_own_only => Ok(Self::OwnOnly),
_ => Err(Error::from_status(Status::Unknown)),
} }
} }
} }
@ -44,15 +49,18 @@ pub enum KeyFilter {
} }
#[cfg(napi6)] #[cfg(napi6)]
impl From<sys::napi_key_filter> for KeyFilter { impl TryFrom<sys::napi_key_filter> for KeyFilter {
fn from(value: sys::napi_key_filter) -> Self { type Error = Error;
fn try_from(value: sys::napi_key_filter) -> Result<Self> {
match value { match value {
sys::napi_key_filter::napi_key_all_properties => Self::AllProperties, sys::napi_key_filter::napi_key_all_properties => Ok(Self::AllProperties),
sys::napi_key_filter::napi_key_writable => Self::Writable, sys::napi_key_filter::napi_key_writable => Ok(Self::Writable),
sys::napi_key_filter::napi_key_enumerable => Self::Enumerable, sys::napi_key_filter::napi_key_enumerable => Ok(Self::Enumerable),
sys::napi_key_filter::napi_key_configurable => Self::Configurable, sys::napi_key_filter::napi_key_configurable => Ok(Self::Configurable),
sys::napi_key_filter::napi_key_skip_strings => Self::SkipStrings, sys::napi_key_filter::napi_key_skip_strings => Ok(Self::SkipStrings),
sys::napi_key_filter::napi_key_skip_symbols => Self::SkipSymbols, sys::napi_key_filter::napi_key_skip_symbols => Ok(Self::SkipSymbols),
_ => Err(Error::from_status(Status::Unknown)),
} }
} }
} }
@ -78,11 +86,14 @@ pub enum KeyConversion {
} }
#[cfg(napi6)] #[cfg(napi6)]
impl From<sys::napi_key_conversion> for KeyConversion { impl TryFrom<sys::napi_key_conversion> for KeyConversion {
fn from(value: sys::napi_key_conversion) -> Self { type Error = Error;
fn try_from(value: sys::napi_key_conversion) -> Result<Self> {
match value { match value {
sys::napi_key_conversion::napi_key_keep_numbers => Self::KeepNumbers, sys::napi_key_conversion::napi_key_keep_numbers => Ok(Self::KeepNumbers),
sys::napi_key_conversion::napi_key_numbers_to_strings => Self::NumbersToStrings, sys::napi_key_conversion::napi_key_numbers_to_strings => Ok(Self::NumbersToStrings),
_ => Err(Error::from_status(Status::Unknown)),
} }
} }
} }

View file

@ -13,11 +13,11 @@ pub struct Property<'env> {
#[repr(u32)] #[repr(u32)]
#[derive(Debug, Copy, Clone, PartialEq, Eq, Hash)] #[derive(Debug, Copy, Clone, PartialEq, Eq, Hash)]
pub enum PropertyAttributes { pub enum PropertyAttributes {
Default = sys::napi_property_attributes::napi_default as _, Default = sys::napi_property_attributes::napi_default.0 as _,
Writable = sys::napi_property_attributes::napi_writable as _, Writable = sys::napi_property_attributes::napi_writable.0 as _,
Enumerable = sys::napi_property_attributes::napi_enumerable as _, Enumerable = sys::napi_property_attributes::napi_enumerable.0 as _,
Configurable = sys::napi_property_attributes::napi_configurable as _, Configurable = sys::napi_property_attributes::napi_configurable.0 as _,
Static = sys::napi_property_attributes::napi_static as _, Static = sys::napi_property_attributes::napi_static.0 as _,
} }
impl From<PropertyAttributes> for sys::napi_property_attributes { impl From<PropertyAttributes> for sys::napi_property_attributes {

View file

@ -1,3 +1,4 @@
use std::convert::TryFrom;
use std::convert::TryInto; use std::convert::TryInto;
use crate::{sys, Error, Result, Status}; use crate::{sys, Error, Result, Status};
@ -22,39 +23,40 @@ impl TryInto<sys::napi_valuetype> for ValueType {
type Error = Error; type Error = Error;
fn try_into(self) -> Result<sys::napi_valuetype> { fn try_into(self) -> Result<sys::napi_valuetype> {
use sys::napi_valuetype::*;
match self { match self {
ValueType::Unknown => Err(Error::from_status(Status::Unknown)), ValueType::Unknown => Err(Error::from_status(Status::Unknown)),
#[cfg(napi6)] #[cfg(napi6)]
ValueType::Bigint => Ok(napi_bigint), ValueType::Bigint => Ok(sys::napi_valuetype::napi_bigint),
ValueType::Boolean => Ok(napi_boolean), ValueType::Boolean => Ok(sys::napi_valuetype::napi_boolean),
ValueType::External => Ok(napi_external), ValueType::External => Ok(sys::napi_valuetype::napi_external),
ValueType::Function => Ok(napi_function), ValueType::Function => Ok(sys::napi_valuetype::napi_function),
ValueType::Null => Ok(napi_null), ValueType::Null => Ok(sys::napi_valuetype::napi_null),
ValueType::Number => Ok(napi_number), ValueType::Number => Ok(sys::napi_valuetype::napi_number),
ValueType::Object => Ok(napi_object), ValueType::Object => Ok(sys::napi_valuetype::napi_object),
ValueType::String => Ok(napi_string), ValueType::String => Ok(sys::napi_valuetype::napi_string),
ValueType::Symbol => Ok(napi_symbol), ValueType::Symbol => Ok(sys::napi_valuetype::napi_symbol),
ValueType::Undefined => Ok(napi_undefined), ValueType::Undefined => Ok(sys::napi_valuetype::napi_undefined),
} }
} }
} }
impl From<sys::napi_valuetype> for ValueType { impl TryFrom<sys::napi_valuetype> for ValueType {
fn from(value: sys::napi_valuetype) -> Self { type Error = Error;
use sys::napi_valuetype::*;
fn try_from(value: sys::napi_valuetype) -> Result<Self> {
match value { match value {
#[cfg(napi6)] #[cfg(napi6)]
napi_bigint => ValueType::Bigint, sys::napi_valuetype::napi_bigint => Ok(ValueType::Bigint),
napi_boolean => ValueType::Boolean, sys::napi_valuetype::napi_boolean => Ok(ValueType::Boolean),
napi_external => ValueType::External, sys::napi_valuetype::napi_external => Ok(ValueType::External),
napi_function => ValueType::Function, sys::napi_valuetype::napi_function => Ok(ValueType::Function),
napi_null => ValueType::Null, sys::napi_valuetype::napi_null => Ok(ValueType::Null),
napi_number => ValueType::Number, sys::napi_valuetype::napi_number => Ok(ValueType::Number),
napi_object => ValueType::Object, sys::napi_valuetype::napi_object => Ok(ValueType::Object),
napi_string => ValueType::String, sys::napi_valuetype::napi_string => Ok(ValueType::String),
napi_symbol => ValueType::Symbol, sys::napi_valuetype::napi_symbol => Ok(ValueType::Symbol),
napi_undefined => ValueType::Undefined, sys::napi_valuetype::napi_undefined => Ok(ValueType::Undefined),
_ => Err(Error::from_status(Status::Unknown)),
} }
} }
} }

View file

@ -28,31 +28,30 @@ pub enum Status {
impl From<napi_status> for Status { impl From<napi_status> for Status {
fn from(code: napi_status) -> Self { fn from(code: napi_status) -> Self {
use self::napi_status::*;
use Status::*; use Status::*;
match code { match code {
napi_ok => Ok, napi_status::napi_ok => Ok,
napi_invalid_arg => InvalidArg, napi_status::napi_invalid_arg => InvalidArg,
napi_object_expected => ObjectExpected, napi_status::napi_object_expected => ObjectExpected,
napi_string_expected => StringExpected, napi_status::napi_string_expected => StringExpected,
napi_name_expected => NameExpected, napi_status::napi_name_expected => NameExpected,
napi_function_expected => FunctionExpected, napi_status::napi_function_expected => FunctionExpected,
napi_number_expected => NumberExpected, napi_status::napi_number_expected => NumberExpected,
napi_boolean_expected => BooleanExpected, napi_status::napi_boolean_expected => BooleanExpected,
napi_array_expected => ArrayExpected, napi_status::napi_array_expected => ArrayExpected,
napi_generic_failure => GenericFailure, napi_status::napi_generic_failure => GenericFailure,
napi_pending_exception => PendingException, napi_status::napi_pending_exception => PendingException,
napi_cancelled => Cancelled, napi_status::napi_cancelled => Cancelled,
napi_escape_called_twice => EscapeCalledTwice, napi_status::napi_escape_called_twice => EscapeCalledTwice,
napi_handle_scope_mismatch => HandleScopeMismatch, napi_status::napi_handle_scope_mismatch => HandleScopeMismatch,
napi_callback_scope_mismatch => CallbackScopeMismatch, napi_status::napi_callback_scope_mismatch => CallbackScopeMismatch,
#[cfg(napi4)] #[cfg(napi4)]
napi_queue_full => QueueFull, napi_status::napi_queue_full => QueueFull,
#[cfg(napi4)] #[cfg(napi4)]
napi_closing => Closing, napi_status::napi_closing => Closing,
#[cfg(napi6)] #[cfg(napi6)]
napi_bigint_expected => BigintExpected, napi_status::napi_bigint_expected => BigintExpected,
_ => Unknown, _ => Unknown,
} }
} }

View file

@ -62,7 +62,7 @@ fn main() {
} }
bindgen_builder bindgen_builder
.rustified_enum("(napi_|uv_).+") .newtype_enum("(napi_|uv_).+")
.whitelist_function("(napi_|uv_|extras_).+") .whitelist_function("(napi_|uv_|extras_).+")
.whitelist_type("(napi_|uv_|extras_).+") .whitelist_type("(napi_|uv_|extras_).+")
.generate() .generate()