소스 검색

drop DIR pointers again

Jeremy Soller 6 년 전
부모
커밋
fc9e3923f6
1개의 변경된 파일4개의 추가작업 그리고 12개의 파일을 삭제
  1. 4 12
      src/header/dirent/mod.rs

+ 4 - 12
src/header/dirent/mod.rs

@@ -57,20 +57,12 @@ pub unsafe extern "C" fn opendir(path: *const c_char) -> *mut DIR {
 
 #[no_mangle]
 pub unsafe extern "C" fn closedir(dir: *mut DIR) -> c_int {
+    let mut dir = Box::from_raw(dir);
 
-    let ret = {
-        let mut dir = Box::from_raw(dir);
+    let ret = Sys::close(*dir.file);
 
-        let ret = Sys::close(*dir.file);
-
-        // Reference files aren't closed when dropped
-        dir.file.reference = true;
-
-        //TODO: find out why dropping dir can crash
-        mem::forget(dir);
-
-        ret
-    };
+    // Reference files aren't closed when dropped
+    dir.file.reference = true;
 
     ret
 }