Index: backup/cc/restore_cc.php =================================================================== RCS file: /cvsroot/moodle/moodle/backup/cc/restore_cc.php,v retrieving revision 1.1.2.2 diff -u -r1.1.2.2 restore_cc.php --- backup/cc/restore_cc.php 19 Oct 2009 17:19:20 -0000 1.1.2.2 +++ backup/cc/restore_cc.php 6 Aug 2010 19:37:06 -0000 @@ -24,6 +24,32 @@ require_once($CFG->dirroot . '/backup/cc/includes/constants.php'); require_once($CFG->dirroot . '/backup/cc/cc2moodle.php'); +function cc_convert_errors (){ + $errors = libxml_get_errors(); + $result = array(); + foreach($errors as $error){ + $result[ $error->level] [] = $error; + } + krsort($result); + libxml_use_internal_errors(false); + return $result; +} + +function cc_convert_errors_notify($errors){ + foreach($errors as $level => $level_errors){ + foreach($level_errors as $error){ + notify("File: + {$error->file} Line: + {$error->line} Column: + {$error->column} Level: + {$error->level}
\nError: + {$error->message}" + , "notifyproblem imscc_level_{$level}" + , 'left'); + } + } +} + function cc_convert ($dir) { $manifest_file = $dir . DIRECTORY_SEPARATOR . 'imsmanifest.xml'; @@ -65,30 +91,40 @@ echo get_string('cc2moodle_checking_schema', 'imscc') . '
'; $cc_manifest = new DOMDocument(); + $cc_manifest->validateOnParse = false; + + libxml_use_internal_errors(true); + $loaded = $cc_manifest->load($manifest_file); + if (!$loaded) { + cc_convert_errors_notify(cc_convert_errors()); + notify(get_string('cc2moodle_manifest_dont_load', 'imscc')); + return false; + } + + $valid = $cc_manifest->schemaValidate($schema_file); + if (!$valid) { + cc_convert_errors_notify(cc_convert_errors()); + notify(get_string('cc2moodle_invalid_schema', 'imscc')); + return false; + } - if ($cc_manifest->load($manifest_file)) { - if ($cc_manifest->schemaValidate($schema_file)) { - - echo get_string('cc2moodle_valid_schema', 'imscc') . '
'; - - $cc2moodle = new cc2moodle($manifest_file); - - if (!$cc2moodle->is_auth()) { - return $cc2moodle->generate_moodle_xml(); - } else { - notify(get_string('cc2moodle_req_auth', 'imscc')); - return false; - } - - } else { - notify(get_string('cc2moodle_invalid_schema', 'imscc')); - return false; + echo get_string('cc2moodle_valid_schema', 'imscc') . '
'; + + $cc2moodle = new cc2moodle($manifest_file); + + $result = false; + + if (!$cc2moodle->is_auth()) { + $result = $cc2moodle->generate_moodle_xml(); + if (!$result) { + cc_convert_errors_notify(cc_convert_errors()); } - } else { - notify(get_string('cc2moodle_manifest_dont_load', 'imscc')); - return false; + cc_convert_errors_notify(cc_convert_errors()); + notify(get_string('cc2moodle_req_auth', 'imscc')); } + + return $result; } }