removes `ref_thread_local` which was still at 0.0.0 released October 2018 while latest 0.1.1 was released mid November 2021
fixes libraries.rs UB
"thiserror",
]
-[[package]]
-name = "ref_thread_local"
-version = "0.0.0"
-source = "registry+https://github.com/rust-lang/crates.io-index"
-checksum = "d813022b2e00774a48eaf43caaa3c20b45f040ba8cbf398e2e8911a06668dbe6"
-
[[package]]
name = "regex"
version = "1.10.2"
"proc-macro2",
"quote",
"rand",
- "ref_thread_local",
"regex",
"reqwest",
"ring 0.17.7",
ordered-float = "2.6.0"
phf = { version = "0.9", features = ["macros"] }
rand = "0.8.5"
-ref_thread_local = "0.0.0"
regex = "1.9.1"
ring = { version = "0.17.5", features = ["wasm32_unknown_unknown_js"] }
ripemd160 = "0.8.0"
writeln!(
libraries,
"\
-ref_thread_local::ref_thread_local! {{
- pub(crate) static managed LIBRARIES: IndexMap<&'static str, &'static str> = {{
+std::thread_local!{{
+ static LIBRARIES: IndexMap<&'static str, &'static str> = {{
let mut m = IndexMap::new();"
)
.unwrap();
use crate::machine::{QueryMatch, QueryResolution, Value};
#[test]
- #[cfg_attr(miri, ignore = "blocked on libraries.rs UB")]
+ #[cfg_attr(miri, ignore = "it takes too long to run")]
fn programatic_query() {
let mut machine = Machine::new_lib();
use fxhash::FxBuildHasher;
use indexmap::IndexSet;
-pub use ref_thread_local::RefThreadLocal;
use std::collections::VecDeque;
use std::fs::File;
ListingSource::File(filename, path_buf),
)
}
- ModuleSource::Library(library) => match LIBRARIES.borrow().get(&*library.as_str()) {
+ ModuleSource::Library(library) => match libraries::get(&library.as_str()) {
Some(code) => {
if let Some(module) = self.wam_prelude.indices.modules.get(&library) {
if let ListingSource::DynamicallyGenerated = &module.listing_src {
ListingSource::File(filename, path_buf),
)
}
- ModuleSource::Library(library) => match LIBRARIES.borrow().get(&*library.as_str()) {
+ ModuleSource::Library(library) => match libraries::get(&library.as_str()) {
Some(code) => {
if self.wam_prelude.indices.modules.contains_key(&library) {
return self.import_qualified_module(library, exports);
#[inline]
fn err_on_builtin_module_overwrite(module_name: Atom) -> Result<(), SessionError> {
- if LIBRARIES.borrow().contains_key(&*module_name.as_str()) {
+ if libraries::contains(&module_name.as_str()) {
Err(SessionError::CannotOverwriteBuiltInModule(module_name))
} else {
Ok(())
mod libraries {
include!(concat!(env!("OUT_DIR"), "/libraries.rs"));
-}
-pub(crate) use libraries::LIBRARIES;
+ pub(crate) fn contains(name: &str) -> bool {
+ LIBRARIES.with(|libs| libs.contains_key(name))
+ }
+
+ pub(crate) fn get(name: &str) -> Option<&'static str> {
+ LIBRARIES.with(|libs| libs.get(name).map(|&lib| lib))
+ }
+
+ #[cfg(test)]
+ std::thread_local! {
+ #[allow(dead_code)]
+ static LIBRARIES2 : IndexMap<&'static str, &'static str> = {
+ let mut m = IndexMap::new();
+ m.insert("test", "test2");
+ m
+ };
+ }
+}
pub static BREAK_FROM_DISPATCH_LOOP_LOC: usize = 0;
pub static INSTALL_VERIFY_ATTR_INTERRUPT: usize = 1;
#[allow(clippy::new_without_default)]
pub fn new(config: MachineConfig) -> Self {
- use ref_thread_local::RefThreadLocal;
-
let args = MachineArgs::new();
let mut machine_st = MachineState::new();
bootstrapping_compile(
Stream::from_static_string(
- libraries::LIBRARIES.borrow()["ops_and_meta_predicates"],
+ libraries::get("ops_and_meta_predicates")
+ .expect("library ops_and_meta_predicates should exist"),
&mut wam.machine_st.arena,
),
&mut wam,
.unwrap();
bootstrapping_compile(
- Stream::from_static_string(LIBRARIES.borrow()["builtins"], &mut wam.machine_st.arena),
+ Stream::from_static_string(
+ libraries::get("builtins").expect("library builtins should exist"),
+ &mut wam.machine_st.arena,
+ ),
&mut wam,
ListingSource::from_file_and_path(atom!("builtins.pl"), lib_path.clone()),
)
use fxhash::{FxBuildHasher, FxHasher};
use indexmap::IndexSet;
-pub(crate) use ref_thread_local::RefThreadLocal;
-
use std::cell::Cell;
use std::cmp::Ordering;
use std::collections::BTreeSet;
#[cfg(feature = "http")]
use warp::{Buf, Filter};
+use super::libraries;
+
#[cfg(feature = "repl")]
pub(crate) fn get_key() -> KeyEvent {
let key;
pub(crate) fn load_library_as_stream(&mut self) -> CallResult {
let library_name = cell_as_atom!(self.deref_register(1));
- use crate::machine::LIBRARIES;
-
- let lib_ref = LIBRARIES.borrow();
- let lib = lib_ref.get(&*library_name.as_str());
+ let lib = libraries::get(&library_name.as_str());
match lib {
Some(library) => {
let lib_stream = Stream::from_static_string(library, &mut self.machine_st.arena);