aboutsummaryrefslogtreecommitdiff
path: root/engines/sci/engine/gc.cpp
diff options
context:
space:
mode:
authorJordi Vilalta Prat2009-02-22 12:18:22 +0000
committerJordi Vilalta Prat2009-02-22 12:18:22 +0000
commitac409a2ab7a15c08bde95f0647847dc71407ed88 (patch)
treeacbd1a57b0d6f50c460c27ae39d8373196df3b45 /engines/sci/engine/gc.cpp
parent7d21acd18b65d8d213755754ce16f7b075c52039 (diff)
downloadscummvm-rg350-ac409a2ab7a15c08bde95f0647847dc71407ed88.tar.gz
scummvm-rg350-ac409a2ab7a15c08bde95f0647847dc71407ed88.tar.bz2
scummvm-rg350-ac409a2ab7a15c08bde95f0647847dc71407ed88.zip
SCI: Converted "segment interfaces" into classes
svn-id: r38782
Diffstat (limited to 'engines/sci/engine/gc.cpp')
-rw-r--r--engines/sci/engine/gc.cpp18
1 files changed, 9 insertions, 9 deletions
diff --git a/engines/sci/engine/gc.cpp b/engines/sci/engine/gc.cpp
index 94632a6b7c..531ecf8d19 100644
--- a/engines/sci/engine/gc.cpp
+++ b/engines/sci/engine/gc.cpp
@@ -100,7 +100,7 @@ static void free_worklist(worklist_t *wl) {
}
}
-static reg_t_hash_map * normalise_hashmap_ptrs(reg_t_hash_map *nonnormal_map, SegInterface **interfaces, int interfaces_nr) {
+static reg_t_hash_map *normalise_hashmap_ptrs(reg_t_hash_map *nonnormal_map, SegInterface **interfaces, int interfaces_nr) {
reg_t_hash_map *normal_map = new reg_t_hash_map();
for (reg_t_hash_map::iterator i = nonnormal_map->begin(); i != nonnormal_map->end(); ++i) {
@@ -109,7 +109,7 @@ static reg_t_hash_map * normalise_hashmap_ptrs(reg_t_hash_map *nonnormal_map, Se
interfce = (reg.segment < interfaces_nr) ? interfaces[reg.segment] : NULL;
if (interfce) {
- reg = interfce->find_canonic_address(interfce, reg);
+ reg = interfce->findCanonicAddress(reg);
normal_map->setVal(reg, true);
}
}
@@ -181,8 +181,8 @@ reg_t_hash_map *find_all_used_references(EngineState *s) {
// Init: Explicitly loaded scripts
for (i = 1; i < sm->heap_size; i++)
if (interfaces[i]
- && interfaces[i]->type_id == MEM_OBJ_SCRIPT) {
- script_t *script = &(interfaces[i]->mobj->data.script);
+ && interfaces[i]->getType() == MEM_OBJ_SCRIPT) {
+ script_t *script = &(interfaces[i]->getMobj()->data.script);
if (script->lockers) { // Explicitly loaded?
int obj_nr;
@@ -209,7 +209,7 @@ reg_t_hash_map *find_all_used_references(EngineState *s) {
sciprintf("[GC] Checking "PREG"\n", PRINT_REG(reg));
#endif
if (reg.segment < sm->heap_size && interfaces[reg.segment])
- interfaces[reg.segment]->list_all_outgoing_references(interfaces[reg.segment], s, reg,
+ interfaces[reg.segment]->listAllOutgoingReferences(s, reg,
&worklist_manager, add_outgoing_refs);
}
}
@@ -220,7 +220,7 @@ reg_t_hash_map *find_all_used_references(EngineState *s) {
// Cleanup
for (i = 1; i < sm->heap_size; i++)
if (interfaces[i])
- interfaces[i]->deallocate_self(interfaces[i]);
+ delete interfaces[i];
free(interfaces);
delete nonnormal_map;
@@ -243,7 +243,7 @@ void free_unless_used(void *pre_use_map, reg_t addr) {
if (!use_map->contains(addr)) {
// Not found -> we can free it
- deallocator->interfce->free_at_address(deallocator->interfce, addr);
+ deallocator->interfce->freeAtAddress(addr);
#ifdef DEBUG_GC
sciprintf("[GC] Deallocating "PREG"\n", PRINT_REG(addr));
deallocator->segcount[deallocator->interfce->type_id]++;
@@ -271,8 +271,8 @@ void run_gc(EngineState *s) {
#ifdef DEBUG_GC
deallocator.segnames[deallocator.interfce->type_id] = deallocator.interfce->type;
#endif
- deallocator.interfce->list_all_deallocatable(deallocator.interfce, &deallocator, free_unless_used);
- deallocator.interfce->deallocate_self(deallocator.interfce);
+ deallocator.interfce->listAllDeallocatable(&deallocator, free_unless_used);
+ delete deallocator.interfce;
}
}