diff --git a/src/ini.php b/src/ini.php
index 87774e1..3313ec0 100644
--- a/src/ini.php
+++ b/src/ini.php
@@ -1,4 +1,22 @@
htmlMessage = $html;
+ }
+
+ public function getHTMLMessage() {
+ return $this->htmlMessage;
+ }
+}
+
+class MSQ_ConfigException extends MSQ_ParseException { }
+
/*
* @brief INI parsing
*
@@ -6,7 +24,7 @@
class INI
{
/**
- * @brief Given a signature string, finds and parses the respective INI file.
+ * @brief Given a signature string, calculates the respective INI file.
*
* Returns an array of the config file contents.
* @param $signature The signature string which will be modified into a firmware/version array.
@@ -60,7 +78,7 @@ class INI
break;
default:
- $msDir = "unknown";
+ throw new MSQ_ConfigException("Unknown/Invalid MSQ signature: $msVersion/$fwVersion");
}
//Setup firmware version for matching.
@@ -76,9 +94,7 @@ class INI
debug("INI File: $iniFile");
- $msqMap = INI::parse($iniFile, TRUE);
-
- return $msqMap;
+ return $iniFile;
}
/**
@@ -87,10 +103,9 @@ class INI
* Based on code from: goulven.ch@gmail.com (php.net comments) http://php.net/manual/en/function.parse-ini-file.php#78815
*
* @param $file The path to the INI file that will be loaded and parsed.
- * @param $something Unused
* @returns A huge array of arrays, starting with sections.
*/
- public static function parse($file, $something)
+ public static function parse($file)
{
try
{
@@ -107,9 +122,8 @@ class INI
if ($ini == FALSE || count($ini) == 0)
{
- echo "
Error opening file: $file
";
error("Error or empty file: $file");
- return null;
+ throw new MSQ_ConfigException("Could not open MSQ config file: $file");
}
else if (DEBUG) debug("Opened: $file");
diff --git a/src/msq.php b/src/msq.php
index 961e970..3b2b97d 100644
--- a/src/msq.php
+++ b/src/msq.php
@@ -69,21 +69,20 @@ class MSQ
$msqHeader .= "Tuning SW: " . $msq->bibliography['author'] . "
";
$msqHeader .= "Date: " . $msq->bibliography['writeDate'] . "
";
$msqHeader .= '';
+ $html['msqHeader'] = $msqHeader;
$sig = $msq->versionInfo['signature'];
$sigString = $sig;
- $msqMap = INI::getConfig($sig);
-
- if ($msqMap == null)
- {
+ try {
+ $iniFile = INI::getConfig($sig);
+ $msqMap = INI::parse($iniFile);
+ } catch (MSQ_ConfigException $e) {
+ error('Error parsing config file: ' . $e->getMessage());
$issueTitle = urlencode("INI Request: $sigString");
- $msqHeader .= 'Unable to load the corresponding configuration file for that MSQ. Please
file a bug! ';
- $html['msqHeader'] = $msqHeader;
- return $html; //TODO Signal caller to skip engine/metadata updates
+ $htmlMessage = $msqHeader . 'Unable to load the corresponding configuration file for that MSQ. Please
file a bug! ';
+ throw new MSQ_ParseException("Could not load configuration file for MSQ: " . $e->getMessage(), $htmlMessage, 100, $e);
}
- $html['msqHeader'] = $msqHeader;
-
//Calling function will update
$metadata['fileFormat'] = $msq->versionInfo['fileFormat'];
$metadata['signature'] = $sig[1];
diff --git a/src/msqur.php b/src/msqur.php
index edb8ad7..818c721 100644
--- a/src/msqur.php
+++ b/src/msqur.php
@@ -155,20 +155,24 @@ class Msqur
$metadata = array();
$xml = $this->db->getXML($id);
if ($xml !== null) {
- $groupedHtml = $msq->parseMSQ($xml, $engine, $metadata);
- $this->db->updateMetadata($id, $metadata);
- $this->db->updateEngine($id, $engine);
-
- $html = "";
- foreach($groupedHtml as $group => $v)
- {
- //TODO Group name as fieldset legend or sth
- $html .= "";
- $html .= $v;
- $html .= '
';
+ try {
+ $groupedHtml = $msq->parseMSQ($xml, $engine, $metadata);
+ $this->db->updateMetadata($id, $metadata);
+ $this->db->updateEngine($id, $engine);
+
+ $html = "";
+ foreach($groupedHtml as $group => $v)
+ {
+ //TODO Group name as fieldset legend or sth
+ $html .= "";
+ $html .= $v;
+ $html .= '
';
+ }
+
+ $this->db->updateCache($id, $html);
+ } catch (MSQ_ParseException $e) {
+ $html = $e->getHTMLMessage();
}
-
- $this->db->updateCache($id, $html);
}
}
}