From 5bac2475b0017d6a635d641df17165d71b951f0e Mon Sep 17 00:00:00 2001 From: David Tolnay Date: Thu, 21 Dec 2023 12:12:49 -0800 Subject: [PATCH] Fill in unsafe blocks inside unsafe functions --- src/libyaml/emitter.rs | 11 ++++++----- src/libyaml/error.rs | 26 +++++++++++++------------- src/libyaml/parser.rs | 29 +++++++++++++++-------------- 3 files changed, 34 insertions(+), 32 deletions(-) diff --git a/src/libyaml/emitter.rs b/src/libyaml/emitter.rs index a0ce25f8..686f06ef 100644 --- a/src/libyaml/emitter.rs +++ b/src/libyaml/emitter.rs @@ -197,13 +197,14 @@ impl<'a> Emitter<'a> { unsafe fn write_handler(data: *mut c_void, buffer: *mut u8, size: u64) -> i32 { let data = data.cast::(); - match io::Write::write_all( - &mut *(*data).write, - slice::from_raw_parts(buffer, size as usize), - ) { + match io::Write::write_all(unsafe { &mut *(*data).write }, unsafe { + slice::from_raw_parts(buffer, size as usize) + }) { Ok(()) => 1, Err(err) => { - (*data).write_error = Some(err); + unsafe { + (*data).write_error = Some(err); + } 0 } } diff --git a/src/libyaml/error.rs b/src/libyaml/error.rs index 603557dc..8397f6e2 100644 --- a/src/libyaml/error.rs +++ b/src/libyaml/error.rs @@ -18,41 +18,41 @@ pub(crate) struct Error { impl Error { pub unsafe fn parse_error(parser: *const sys::yaml_parser_t) -> Self { Error { - kind: (*parser).error, - problem: match NonNull::new((*parser).problem as *mut _) { - Some(problem) => CStr::from_ptr(problem), + kind: unsafe { (*parser).error }, + problem: match NonNull::new(unsafe { (*parser).problem as *mut _ }) { + Some(problem) => unsafe { CStr::from_ptr(problem) }, None => CStr::from_bytes_with_nul(b"libyaml parser failed but there is no error\0"), }, - problem_offset: (*parser).problem_offset, + problem_offset: unsafe { (*parser).problem_offset }, problem_mark: Mark { - sys: (*parser).problem_mark, + sys: unsafe { (*parser).problem_mark }, }, - context: match NonNull::new((*parser).context as *mut _) { - Some(context) => Some(CStr::from_ptr(context)), + context: match NonNull::new(unsafe { (*parser).context as *mut _ }) { + Some(context) => Some(unsafe { CStr::from_ptr(context) }), None => None, }, context_mark: Mark { - sys: (*parser).context_mark, + sys: unsafe { (*parser).context_mark }, }, } } pub unsafe fn emit_error(emitter: *const sys::yaml_emitter_t) -> Self { Error { - kind: (*emitter).error, - problem: match NonNull::new((*emitter).problem as *mut _) { - Some(problem) => CStr::from_ptr(problem), + kind: unsafe { (*emitter).error }, + problem: match NonNull::new(unsafe { (*emitter).problem as *mut _ }) { + Some(problem) => unsafe { CStr::from_ptr(problem) }, None => { CStr::from_bytes_with_nul(b"libyaml emitter failed but there is no error\0") } }, problem_offset: 0, problem_mark: Mark { - sys: MaybeUninit::::zeroed().assume_init(), + sys: unsafe { MaybeUninit::::zeroed().assume_init() }, }, context: None, context_mark: Mark { - sys: MaybeUninit::::zeroed().assume_init(), + sys: unsafe { MaybeUninit::::zeroed().assume_init() }, }, } } diff --git a/src/libyaml/parser.rs b/src/libyaml/parser.rs index ae8f3758..3492edd0 100644 --- a/src/libyaml/parser.rs +++ b/src/libyaml/parser.rs @@ -110,15 +110,16 @@ unsafe fn convert_event<'input>( sys::YAML_STREAM_END_EVENT => Event::StreamEnd, sys::YAML_DOCUMENT_START_EVENT => Event::DocumentStart, sys::YAML_DOCUMENT_END_EVENT => Event::DocumentEnd, - sys::YAML_ALIAS_EVENT => Event::Alias(optional_anchor(sys.data.alias.anchor).unwrap()), + sys::YAML_ALIAS_EVENT => { + Event::Alias(unsafe { optional_anchor(sys.data.alias.anchor) }.unwrap()) + } sys::YAML_SCALAR_EVENT => Event::Scalar(Scalar { - anchor: optional_anchor(sys.data.scalar.anchor), - tag: optional_tag(sys.data.scalar.tag), - value: Box::from(slice::from_raw_parts( - sys.data.scalar.value, - sys.data.scalar.length as usize, - )), - style: match sys.data.scalar.style { + anchor: unsafe { optional_anchor(sys.data.scalar.anchor) }, + tag: unsafe { optional_tag(sys.data.scalar.tag) }, + value: Box::from(unsafe { + slice::from_raw_parts(sys.data.scalar.value, sys.data.scalar.length as usize) + }), + style: match unsafe { sys.data.scalar.style } { sys::YAML_PLAIN_SCALAR_STYLE => ScalarStyle::Plain, sys::YAML_SINGLE_QUOTED_SCALAR_STYLE => ScalarStyle::SingleQuoted, sys::YAML_DOUBLE_QUOTED_SCALAR_STYLE => ScalarStyle::DoubleQuoted, @@ -133,13 +134,13 @@ unsafe fn convert_event<'input>( }, }), sys::YAML_SEQUENCE_START_EVENT => Event::SequenceStart(SequenceStart { - anchor: optional_anchor(sys.data.sequence_start.anchor), - tag: optional_tag(sys.data.sequence_start.tag), + anchor: unsafe { optional_anchor(sys.data.sequence_start.anchor) }, + tag: unsafe { optional_tag(sys.data.sequence_start.tag) }, }), sys::YAML_SEQUENCE_END_EVENT => Event::SequenceEnd, sys::YAML_MAPPING_START_EVENT => Event::MappingStart(MappingStart { - anchor: optional_anchor(sys.data.mapping_start.anchor), - tag: optional_tag(sys.data.mapping_start.tag), + anchor: unsafe { optional_anchor(sys.data.mapping_start.anchor) }, + tag: unsafe { optional_tag(sys.data.mapping_start.tag) }, }), sys::YAML_MAPPING_END_EVENT => Event::MappingEnd, sys::YAML_NO_EVENT => unreachable!(), @@ -149,13 +150,13 @@ unsafe fn convert_event<'input>( unsafe fn optional_anchor(anchor: *const u8) -> Option { let ptr = NonNull::new(anchor as *mut i8)?; - let cstr = CStr::from_ptr(ptr); + let cstr = unsafe { CStr::from_ptr(ptr) }; Some(Anchor(Box::from(cstr.to_bytes()))) } unsafe fn optional_tag(tag: *const u8) -> Option { let ptr = NonNull::new(tag as *mut i8)?; - let cstr = CStr::from_ptr(ptr); + let cstr = unsafe { CStr::from_ptr(ptr) }; Some(Tag(Box::from(cstr.to_bytes()))) }