]> Repositorios git - scryer-prolog.git/commitdiff
some fixes in response to miri
authorMark Thom <[email protected]>
Thu, 13 Mar 2025 19:33:37 +0000 (12:33 -0700)
committerMark Thom <[email protected]>
Tue, 8 Jul 2025 05:02:27 +0000 (22:02 -0700)
src/lib/builtins.pl
src/machine/heap.rs
src/machine/machine_state_impl.rs
src/machine/stack.rs
src/types.rs

index 31b40a3ad0036e8446c18725108bad5c8a95bb2d..bc78b7113b41bc301514b18383e76660324a3de3 100644 (file)
@@ -568,7 +568,6 @@ parse_options_list(Options, Selector, DefaultPairs, OptionValues, Stub) :-
                                                 % maplist isn't
                                                 % declared as a
                                                 % meta-predicate yet
-       '$debug_hook',
        catch(lists:maplist(Selector, Options, OptionPairs0),
              error(E, _),
              builtins:throw(error(E, Stub))) ->
index b753809dfa9c461a981bd32d7a0871327bbbe3be..d628391c661cc0971937914449a95fd0ad744607 100644 (file)
@@ -1281,3 +1281,17 @@ pub(crate) fn to_local_code_ptr(heap: &Heap, addr: HeapCellValue) -> Option<usiz
         }
     )
 }
+
+#[cfg(test)]
+mod test {
+    use super::*;
+
+    #[test]
+    fn heap_manipulation() {
+        let mut heap = Heap::new();
+
+        for idx in 0 .. 10 {
+            heap.push_cell(heap_loc_as_cell!(idx)).unwrap();
+        }
+    }
+}
index a7dc5d9e8e767ec5bfa9909890551f9a5ae85fa9..ef1d32dc275cf78636c766dced21b7699bff8d77 100644 (file)
@@ -267,16 +267,6 @@ impl MachineState {
         unifier.unify_atom(atom, value);
     }
 
-    pub fn unify_list(&mut self, l1: usize, value: HeapCellValue) {
-        let mut unifier = DefaultUnifier::from(self);
-        unifier.unify_list(l1, value);
-    }
-
-    pub fn unify_partial_string(&mut self, pstr_loc: usize, value: HeapCellValue) {
-        let mut unifier = DefaultUnifier::from(self);
-        unifier.unify_partial_string(pstr_loc, value);
-    }
-
     pub fn unify_char(&mut self, c: char, value: HeapCellValue) {
         let mut unifier = DefaultUnifier::from(self);
         unifier.unify_char(c, value);
index bf330813dfc34c3312db373d59df18b5dc740f50..4d8b970adfd376a597f0fb26c9dd5692d2fb4784 100644 (file)
@@ -228,7 +228,7 @@ impl Stack {
 
             for idx in 0..num_cells {
                 ptr::write(
-                    (new_ptr as usize + offset) as *mut HeapCellValue,
+                    new_ptr.byte_add(offset) as *mut HeapCellValue,
                     stack_loc_as_cell!(OrFrame, b, idx),
                 );
 
index a2dd7225c3a2d9010f7c0204152f8bb486bd08d8..67e482cc9b15f0236f4e19597fbff073906cc9d9 100644 (file)
@@ -97,8 +97,7 @@ impl ConsPtr {
 
     #[inline(always)]
     pub fn as_ptr(self) -> *mut u8 {
-        let addr: u64 = self.ptr();
-        addr as usize as *mut _
+        unsafe { mem::transmute::<_, *mut u8>(self.ptr()) }
     }
 
     #[inline(always)]
@@ -676,23 +675,22 @@ impl UntypedArenaPtr {
     }
 
     #[inline]
-    pub fn get_ptr(self) -> *const u8 {
-        let addr: u64 = self.ptr();
-        addr as usize as *const u8
+    pub fn get_ptr(self) -> *const ArenaHeader {
+        unsafe { mem::transmute::<_, *const ArenaHeader>(self.ptr()) }
     }
 
     #[inline]
     pub fn get_tag(self) -> ArenaHeaderTag {
         unsafe {
             debug_assert!(!self.get_ptr().is_null());
-            let header = *(self.get_ptr() as *const ArenaHeader);
+            let header = *self.get_ptr();
             header.get_tag()
         }
     }
 
     #[inline]
     pub fn payload_offset(self) -> *const u8 {
-        unsafe { self.get_ptr().add(mem::size_of::<ArenaHeader>()) }
+        unsafe { self.get_ptr().byte_add(mem::size_of::<ArenaHeader>()) as *const _ }
     }
 
     /// # Safety