104 lines
3.0 KiB
PHP
104 lines
3.0 KiB
PHP
<?php
|
|
/*
|
|
* $Id: license.txt 13981 2005-03-16 08:09:28Z eespino $
|
|
*
|
|
* Copyright(c) 2004-2006, SpikeSource Inc. All Rights Reserved.
|
|
* Licensed under the Open Software License version 2.1
|
|
* (See http://www.spikesource.com/license.html)
|
|
*/
|
|
?>
|
|
<?php
|
|
|
|
class CoverageLogger {
|
|
|
|
private $level;
|
|
private $logLevels = array(
|
|
"LOG_CRITICAL",
|
|
"LOG_ERROR",
|
|
"LOG_WARNING",
|
|
"LOG_NOTICE",
|
|
"LOG_INFO",
|
|
"LOG_DEBUG"
|
|
);
|
|
|
|
public function setLevel($level) {
|
|
if( ! is_numeric($level)) {
|
|
for($i = 0; $i < count($this->logLevels); $i++) {
|
|
if(strcasecmp($this->logLevels[$i], $level) === 0) {
|
|
$level = $i;
|
|
break;
|
|
}
|
|
}
|
|
}
|
|
$this->level = $level;
|
|
}
|
|
|
|
public function critical($str, $file="", $line="") {
|
|
if($this->level >= 0) {
|
|
error_log("[CRITICAL] [" . $file . ":" . $line . "] " . $str);
|
|
}
|
|
}
|
|
|
|
public function error($str, $file="", $line="") {
|
|
if($this->level >= 1) {
|
|
error_log("[ERROR] [" . $file . ":" . $line . "] " . $str);
|
|
}
|
|
}
|
|
|
|
public function warn($str, $file="", $line="") {
|
|
if($this->level >= 2) {
|
|
error_log("[WARNING] [" . $file . ":" . $line . "] " . $str);
|
|
}
|
|
}
|
|
|
|
public function notice($str, $file="", $line="") {
|
|
if($this->level >= 3) {
|
|
error_log("[NOTICE] [" . $file . ":" . $line . "] " . $str);
|
|
}
|
|
}
|
|
|
|
public function info($str, $file="", $line="") {
|
|
if($this->level >= 4) {
|
|
error_log("[INFO] [" . $file . ":" . $line . "] " . $str);
|
|
}
|
|
}
|
|
|
|
public function debug($str, $file="", $line="") {
|
|
if($this->level >= 5) {
|
|
error_log("[DEBUG] [" . $file . ":" . $line . "] " . $str);
|
|
}
|
|
}
|
|
|
|
public function getLevelName($level) {
|
|
return $this->logLevels[$level];
|
|
}
|
|
}
|
|
|
|
// testing
|
|
if(isset($_SERVER["argv"][1]) && $_SERVER["argv"][1] == "__main__") {
|
|
$logger = new CoverageLogger();
|
|
for($i = 0; $i < 6; $i++) {
|
|
$logger->setLevel($i);
|
|
error_log("############## Level now: " . $i);
|
|
$logger->debug("");
|
|
$logger->info("");
|
|
$logger->notice("");
|
|
$logger->warn("");
|
|
$logger->error("");
|
|
$logger->critical("");
|
|
}
|
|
|
|
error_log("############# With Level Names");
|
|
for($i = 0; $i < 6; $i++) {
|
|
$logger->setLevel($logger->getLevelName($i));
|
|
error_log("############## Level now: " . $logger->getLevelName($i));
|
|
$logger->debug("");
|
|
$logger->info("", __FILE__, __LINE__);
|
|
$logger->notice("");
|
|
$logger->warn("");
|
|
$logger->error("");
|
|
$logger->critical("");
|
|
}
|
|
}
|
|
?>
|