From 66ff37d9ff24ee6b478c5850d08df8d673eaf594 Mon Sep 17 00:00:00 2001 From: LongYinan Date: Fri, 28 May 2021 10:34:42 +0800 Subject: [PATCH] fix(napi): JsString* leak in from_js_value --- napi/src/js_values/string/mod.rs | 11 ++--------- napi/src/js_values/string/utf16.rs | 8 +++----- napi/src/js_values/string/utf8.rs | 15 +++------------ 3 files changed, 8 insertions(+), 26 deletions(-) diff --git a/napi/src/js_values/string/mod.rs b/napi/src/js_values/string/mod.rs index 25a00362..7e3dde8c 100644 --- a/napi/src/js_values/string/mod.rs +++ b/napi/src/js_values/string/mod.rs @@ -58,13 +58,9 @@ impl JsString { ) })?; - mem::forget(result); - Ok(JsStringUtf8 { inner: self, - buf: mem::ManuallyDrop::new(unsafe { - Vec::from_raw_parts(buf_ptr, written_char_count, written_char_count) - }), + buf: result, }) } @@ -83,13 +79,10 @@ impl JsString { &mut written_char_count, ) })?; - mem::forget(result); Ok(JsStringUtf16 { inner: self, - buf: mem::ManuallyDrop::new(unsafe { - Vec::from_raw_parts(buf_ptr, written_char_count, written_char_count) - }), + buf: result, }) } diff --git a/napi/src/js_values/string/utf16.rs b/napi/src/js_values/string/utf16.rs index a61d997a..78a6202d 100644 --- a/napi/src/js_values/string/utf16.rs +++ b/napi/src/js_values/string/utf16.rs @@ -1,12 +1,11 @@ -use std::mem; +use std::convert::TryFrom; use std::ops::Deref; -use std::{convert::TryFrom, mem::ManuallyDrop}; use crate::{Error, JsString, Result, Status}; pub struct JsStringUtf16 { pub(crate) inner: JsString, - pub(crate) buf: mem::ManuallyDrop>, + pub(crate) buf: Vec, } impl JsStringUtf16 { @@ -33,7 +32,6 @@ impl JsStringUtf16 { #[inline] pub fn into_value(self) -> JsString { - ManuallyDrop::into_inner(self.buf); self.inner } } @@ -62,6 +60,6 @@ impl AsRef> for JsStringUtf16 { impl From for Vec { fn from(value: JsStringUtf16) -> Self { - ManuallyDrop::into_inner(value.buf) + value.as_slice().to_vec() } } diff --git a/napi/src/js_values/string/utf8.rs b/napi/src/js_values/string/utf8.rs index f5c2acd9..435d2720 100644 --- a/napi/src/js_values/string/utf8.rs +++ b/napi/src/js_values/string/utf8.rs @@ -1,6 +1,5 @@ use std::convert::TryFrom; use std::ffi::CStr; -use std::mem::ManuallyDrop; use std::os::raw::c_char; use std::str; @@ -8,7 +7,7 @@ use crate::{Error, JsString, Result, Status}; pub struct JsStringUtf8 { pub(crate) inner: JsString, - pub(crate) buf: ManuallyDrop>, + pub(crate) buf: Vec, } impl JsStringUtf8 { @@ -36,24 +35,16 @@ impl JsStringUtf8 { #[inline] pub fn into_owned(self) -> Result { - let buffer = ManuallyDrop::into_inner(self.buf); - - let s = unsafe { CStr::from_ptr(buffer.as_ptr()) } - .to_str() - .map_err(|e| Error::new(Status::InvalidArg, format!("{}", e)))?; - - Ok(s.to_owned()) + Ok(self.as_str()?.to_owned()) } #[inline] pub fn take(self) -> Vec { - let bytes = unsafe { CStr::from_ptr(ManuallyDrop::into_inner(self.buf).as_ptr()) }.to_bytes(); - bytes.to_vec() + self.as_slice().to_vec() } #[inline] pub fn into_value(self) -> JsString { - ManuallyDrop::into_inner(self.buf); self.inner } }