This repository has been archived by the owner on Sep 9, 2024. It is now read-only.
forked from nakal/BugzillaReports
-
Notifications
You must be signed in to change notification settings - Fork 2
/
BMWExtension.php
87 lines (81 loc) · 2.41 KB
/
BMWExtension.php
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
<?php
/**
* Bemoko MediaWiki Extension
*/
/**
* Copyright (C) 2008 - Ian Homer & bemoko
*
* This program is free software; you can redistribute it and/or modify it
* under the terms of the GNU General Public License as published by the Free
* Software Foundation; either version 2 of the License, or (at your option)
* any later version.
*
* This program is distributed in the hope that it will be useful, but
* WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY
* or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
* more details.
*
* You should have received a copy of the GNU General Public License along
* with this program; if not, see <http://www.gnu.org/licenses>.
*/
abstract class BMWExtension {
public $debug;
var $warnings;
abstract protected function set($name,$value);
/**
* Extract options from a arguments
*
* @param string $args function arguments
*/
public function extractOptions( $args ) {
foreach( $args as $line ) {
if( strpos( $line, '=' ) === false )
continue;
list( $name, $value ) = explode( '=', $line, 2 );
$value=trim($value);
$match=$this->getParameterRegex($name);
if (!$match) {
/**
* Safe parameter reading by default
* only allowing alphanumeric
*/
$match="/^[\w]*$/";
}
if (preg_match($match, $value, $matches)) {
$this->set($name,$matches[0]);
$this->debug &&
$this->debug("Parameter [".$name."=".$matches[0]."]");
} else {
$this->warn("Parameter ".
$name."=".$value." is invalid using regex $match");
}
}
$this->debug && $this->debug("Called extractOptions : ".$args);
}
/**
* MediaWiki debug message
*/
public function debug($message) {
if ($this->debug) {
if ($message) {
wfDebugLog("BMWExtension",$message);
} else {
$this->warn("Null message sent to debug statement");
}
}
}
/**
* MediaWiki warn message
*/
public function warn($message) {
wfDebugLog("BMWExtension","WARN: *** ".$message);
$this->warnings.="<li>".$message."</li>";
}
public function getWarnings() {
if ($this->warnings) {
return "<div class=\"warning\"><b>Warnings were generated during the execution of function</b><ol>".$this->warnings."</ol></div>";
} else {
return NULL;
}
}
}