let mut compiler = ListingCompiler::new(&wam.code_repo);
let indices = try_eval_session!(compile_decl(wam, &mut compiler, decl));
- try_eval_session!(wam.check_toplevel_code(&indices));
+ try_eval_session!(wam.check_toplevel_code(&indices, &DynamicClauseMap::new()));
add_toplevel_code(wam, vec![], indices);
EvalSession::EntrySuccess
module.code_dir.extend(as_module_code_dir(code_dir));
if module.module_decl.exports.contains(&(name.clone(), arity)) {
- if let Some(idx) = wam.indices.code_dir.get(&(name.clone(), arity)) {
- let module = name.owning_module();
- set_code_index!(idx, IndexPtr::Index(wam.code_repo.code.len()), module);
+ if let Some(idx) = wam.indices.code_dir.get(&(name.clone(), arity)) {
+ if module.module_decl.name == idx.0.borrow().1 {
+ let module = module.module_decl.name.clone();
+
+ if module_code.len() > 0 {
+ set_code_index!(idx, IndexPtr::Index(wam.code_repo.code.len()), module);
+ } else {
+ set_code_index!(idx, IndexPtr::Undefined, module);
+ }
+ }
}
}
},
indices: IndexStore)
-> Result<(), SessionError>
{
- let mut clause_code_generator = ClauseCodeGenerator::new(code.len());
+ wam.check_toplevel_code(&indices, &dynamic_clause_map)?;
+ let mut clause_code_generator = ClauseCodeGenerator::new(code.len());
clause_code_generator.generate_clause_code(dynamic_clause_map, wam)?;
- wam.check_toplevel_code(&indices)?;
add_toplevel_code(wam, code, indices);
clause_code_generator.add_clause_code(wam);
if let Some(module) = compiler.module.take() {
let mut clause_code_generator = ClauseCodeGenerator::new(module_code.len() + toplvl_code.len());
+ try_eval_session!(wam.check_toplevel_code(&results.toplevel_indices, &results.dynamic_clause_map));
try_eval_session!(clause_code_generator.generate_clause_code(results.dynamic_clause_map, wam));
- try_eval_session!(wam.check_toplevel_code(&results.toplevel_indices));
add_module_code(wam, module, module_code, indices);
add_toplevel_code(wam, toplvl_code, results.toplevel_indices);
use prolog::machine::machine_indices::*;
use prolog::machine::machine_state::*;
use prolog::machine::modules::*;
+use prolog::machine::toplevel::*;
use std::collections::{HashMap, VecDeque};
use std::mem;
Ok(())
}
- pub fn check_toplevel_code(&self, indices: &IndexStore) -> Result<(), SessionError>
+ pub fn check_toplevel_code(&self, indices: &IndexStore, dynamic_clause_map: &DynamicClauseMap)
+ -> Result<(), SessionError>
{
for (key, idx) in &indices.code_dir {
match ClauseType::from(key.0.clone(), key.1, None) {
}
};
- self.check_dynamic_clause_overwrite(key.0.clone(), key.1)?;
+ if dynamic_clause_map.contains_key(&key) {
+ self.check_dynamic_clause_overwrite(key.0.clone(), key.1)?;
+ }
if let Some(ref existing_idx) = self.indices.code_dir.get(&key) {
// ensure we don't try to overwrite an existing predicate from a different module.