[[package]]
name = "prolog_parser"
-version = "0.8.58"
+version = "0.8.59"
source = "registry+https://github.com/rust-lang/crates.io-index"
-checksum = "e90d34a4268bf5256d4e55f8ec920220aa96dc7ee779441b32f97635cba72aa9"
+checksum = "029a4682cf40923b8eb05c4b943d1d6be73775e7bf80bcb0866b5ef29abb0802"
dependencies = [
"lexical",
"num-rug-adapter",
[[package]]
name = "scryer-prolog"
-version = "0.8.122"
+version = "0.8.123"
dependencies = [
"cpu-time",
"crossterm",
[package]
name = "scryer-prolog"
-version = "0.8.122"
+version = "0.8.123"
build = "build.rs"
repository = "https://github.com/mthom/scryer-prolog"
nix = "0.15.0"
num-rug-adapter = { optional = true, version = "0.1.3" }
ordered-float = "0.5.0"
-prolog_parser = { version = "0.8.58", default-features = false }
+prolog_parser = { version = "0.8.59", default-features = false }
ref_thread_local = "0.0.0"
rug = { version = "1.4.0", optional = true }
rustyline = "6.0.0"
'\u{d8}' ..= '\u{f6}' => c.to_string(),
'\u{f8}' ..= '\u{74f}' => c.to_string(),
'\x20' ..= '\x7e' => c.to_string(),
- _ => format!("\\x{:x}\\", c as u32),
+ _ => format!("\\{:x}\\", c as u32),
}
}
#[inline]
pub(crate)
fn put_complete_string(&mut self, s: &str) -> Addr {
+ if s.is_empty() {
+ return Addr::EmptyList;
+ }
+
let addr = self.allocate_pstr(s);
self.pop();
pub(crate)
fn allocate_pstr(&mut self, src: &str) -> Addr {
self.write_pstr(src)
- .unwrap_or_else(|| {
- let h = self.h();
-
- self.push(HeapCellValue::PartialString(
- PartialString::empty(),
- true,
- ));
-
- self.push(HeapCellValue::Addr(
- Addr::HeapCell(h + 1)
- ));
-
- Addr::PStrLocation(h, 0)
- })
+ .unwrap_or_else(|| Addr::EmptyList)
}
#[inline]
&QueryInstruction::PutPartialString(_, ref string, reg, has_tail) => {
let pstr_addr =
if has_tail {
- let pstr_addr = self.heap.allocate_pstr(&string);
- self.heap.pop(); // the tail will be added by the next instruction.
- pstr_addr
+ if !string.is_empty() {
+ let pstr_addr = self.heap.allocate_pstr(&string);
+ self.heap.pop(); // the tail will be added by the next instruction.
+ pstr_addr
+ } else {
+ Addr::EmptyList
+ }
} else {
self.heap.put_complete_string(&string)
};
let mut terminator_idx = 0;
for c in iter {
- if c == '\u{0}' {
- break;
+ if c == '\u{0}' && terminator_idx != 0 {
+ return terminator_idx;
}
terminator_idx += c.len_utf8();
}
}
- #[inline]
- pub(super)
- fn empty() -> Self {
- let mut pstr = PartialString {
- buf: ptr::null(),
- len: 0,
- _marker: PhantomData,
- };
-
- unsafe {
- let layout = alloc::Layout::from_size_align_unchecked(
- '\u{0}'.len_utf8(),
- mem::align_of::<u8>(),
- );
-
- pstr.buf = alloc::alloc(layout) as *const _;
- pstr.len = '\u{0}'.len_utf8();
-
- pstr.write_terminator_at(0);
- }
-
- pstr
- }
-
unsafe fn append_chars(mut self, src: &str) -> Option<(Self, &str)> {
let terminator_idx = scan_for_terminator(src.chars());
- if terminator_idx == 0 {
- return None;
- }
-
let layout = alloc::Layout::from_size_align_unchecked(
terminator_idx + '\u{0}'.len_utf8(),
mem::align_of::<u8>(),
self.write_terminator_at(terminator_idx);
- Some(if terminator_idx != src.len() {
- (self, &src[terminator_idx + '\u{0}'.len_utf8() ..])
+ Some(if terminator_idx != src.as_bytes().len() {
+ (self, &src[terminator_idx ..])
} else {
(self, "")
})
#[inline]
pub fn at_end(&self, end_n: usize) -> bool {
- unsafe {
- ptr::read((self.buf as usize + end_n) as *const u8) == 0u8
- }
+ end_n + 1 == self.len
}
#[inline]
let h = self.heap.h();
+ if atom.as_str().is_empty() {
+ self.fail = true;
+ return Ok(());
+ }
+
let pstr = self.heap.allocate_pstr(atom.as_str());
let pstr_tail = self.heap[h + 1].as_addr(h + 1);