Skip to content

Commit

Permalink
MDL-13904 Scorm structure isn't respected after an update of the pack…
Browse files Browse the repository at this point in the history
…age. This is a large change to the handling of SCORM package update - all SCOes are issued with a new id, and all references to the old ones are deleted. The scorm_scoes_track data is preserved by being reattached to the new SCO ids (unless they have been deleted).
  • Loading branch information
piers committed Aug 13, 2008
1 parent f5ca89f commit 3fd2552
Showing 1 changed file with 16 additions and 17 deletions.
33 changes: 16 additions & 17 deletions mod/scorm/datamodels/scormlib.php
Expand Up @@ -488,16 +488,12 @@ function scorm_parse_scorm($pkgdir,$scormid) {
$newitem->$standarddata = $item->$standarddata;
}

$id = 0;
// Insert the new SCO, and retain the link between the old and new for later adjustment
$id = $DB->insert_record('scorm_scoes',$newitem);
if (!empty($olditems) && ($olditemid = scorm_array_search('identifier',$newitem->identifier,$olditems))) {
$newitem->id = $olditemid;
$id = $DB->update_record('scorm_scoes',$newitem);
unset($olditems[$olditemid]);
$DB->delete_records('scorm_scoes_data', array('scoid'=>$olditemid));
} else {
$id = $DB->insert_record('scorm_scoes',$newitem);
$olditems[$olditemid]->newid = $id;
}

if ($optionaldatas = scorm_optionals_data($item,$standarddatas)) {
$data = new stdClass();
$data->scoid = $id;
Expand Down Expand Up @@ -590,15 +586,18 @@ function scorm_parse_scorm($pkgdir,$scormid) {
}
if (!empty($olditems)) {
foreach($olditems as $olditem) {
$DB->delete_records('scorm_scoes', array('id'=>$olditem->id));
$DB->delete_records('scorm_scoes_data',array('scoid'=>$olditem->id));
$DB->delete_records('scorm_scoes_track',array('scoid'=>$olditem->id));
$DB->delete_records('scorm_seq_objective', array('scoid'=>$olditem->id));
$DB->delete_records('scorm_seq_mapinfo', array('scoid'=>$olditem->id));
$DB->delete_records('scorm_seq_ruleconds', array('scoid'=>$olditem->id));
$DB->delete_records('scorm_seq_rulecond', array('scoid'=>$olditem->id));
$DB->delete_records('scorm_seq_rolluprule', array('scoid'=>$olditem->id));
$DB->delete_records('scorm_seq_rollupcond', array('scoid'=>$olditem->id));
$DB->delete_records('scorm_scoes', array('id'=>$olditem->id));
$DB->delete_records('scorm_scoes_data',array('scoid'=>$olditem->id));
if (isset($olditem->newid)) {
$DB->set_field('scorm_scoes_track', 'scoid', $olditem->newid, array('scoid' => $olditem->id));
}
$DB->delete_records('scorm_scoes_track',array('scoid'=>$olditem->id));
$DB->delete_records('scorm_seq_objective', array('scoid'=>$olditem->id));
$DB->delete_records('scorm_seq_mapinfo', array('scoid'=>$olditem->id));
$DB->delete_records('scorm_seq_ruleconds', array('scoid'=>$olditem->id));
$DB->delete_records('scorm_seq_rulecond', array('scoid'=>$olditem->id));
$DB->delete_records('scorm_seq_rolluprule', array('scoid'=>$olditem->id));
$DB->delete_records('scorm_seq_rollupcond', array('scoid'=>$olditem->id));
}
}
$DB->set_field('scorm','version',$scoes->version, array('id'=>$scormid));
Expand Down

0 comments on commit 3fd2552

Please sign in to comment.