Code Coverage
 
Classes and Traits
Functions and Methods
Lines
Total
100.00% covered (success)
100.00%
6 / 6
100.00% covered (success)
100.00%
8 / 8
CRAP
100.00% covered (success)
100.00%
46 / 46
elog($mixed)
100.00% covered (success)
100.00%
1 / 1
0
100.00% covered (success)
100.00%
7 / 7
Hm_List
100.00% covered (success)
100.00%
1 / 1
100.00% covered (success)
100.00%
4 / 4
8
100.00% covered (success)
100.00%
19 / 19
 add($string)
100.00% covered (success)
100.00%
1 / 1
1
100.00% covered (success)
100.00%
2 / 2
 get()
100.00% covered (success)
100.00%
1 / 1
1
100.00% covered (success)
100.00%
1 / 1
 str($mixed, $return_type=true)
100.00% covered (success)
100.00%
1 / 1
3
100.00% covered (success)
100.00%
9 / 9
 show($type='print')
100.00% covered (success)
100.00%
1 / 1
3
100.00% covered (success)
100.00%
7 / 7
Hm_Output
100.00% covered (success)
100.00%
1 / 1
100.00% covered (success)
100.00%
2 / 2
3
100.00% covered (success)
100.00%
5 / 5
 output_content($content)
100.00% covered (success)
100.00%
1 / 1
1  
 
 send_response($response, $input=array())
100.00% covered (success)
100.00%
1 / 1
2
100.00% covered (success)
100.00%
5 / 5
Hm_Output_HTTP
100.00% covered (success)
100.00%
1 / 1
100.00% covered (success)
100.00%
2 / 2
3
100.00% covered (success)
100.00%
8 / 8
 output_headers($headers)
100.00% covered (success)
100.00%
1 / 1
2
100.00% covered (success)
100.00%
4 / 4
 output_content($content, $headers=array())
100.00% covered (success)
100.00%
1 / 1
1
100.00% covered (success)
100.00%
4 / 4
Hm_Image_Sources
100.00% covered (success)
100.00%
1 / 1
 
 
0  
 
Hm_Msgs
100.00% covered (success)
100.00%
1 / 1
 
 
0  
 
Hm_Debug
100.00% covered (success)
100.00%
1 / 1
100.00% covered (success)
100.00%
1 / 1
1
100.00% covered (success)
100.00%
6 / 6
 load_page_stats()
100.00% covered (success)
100.00%
1 / 1
1
100.00% covered (success)
100.00%
6 / 6
<?php
if (!defined('DEBUG_MODE')) { die(); }
/**
 * Base class that controls how data is output
 */
abstract class Hm_Output {
    /**
     * Extended classes must override this method to output content
     *
     * @param $content mixed data to output
     *
     * @return void
     */
    abstract protected function output_content($content);
    /**
     * Wrapper around extended class output_content() calls
     *
     * @param $response mixed data to output
     * @param $input array raw module data
     *
     * @return void
     */
    public function send_response($response, $input=array()) {
        if (array_key_exists('http_headers', $input)) {
            $this->output_content($response, $input['http_headers']);
        }
        else {
            $this->output_content($response);
        }
    }
}
/**
 * Output request responses using HTTP
 */
class Hm_Output_HTTP extends Hm_Output {
    /**
     * Send HTTP headers
     *
     * @param $headers array headers to send
     *
     * @return void
     */
    protected function output_headers($headers) {
        foreach ($headers as $header) {
            Hm_Functions::header($header);
        }
    }
    /**
     * Send response content to the browser
     *
     * @param $content mixed data to send
     * @param $headers array HTTP headers to set
     *
     * @return void
     */
    protected function output_content($content, $headers=array()) {
        $this->output_headers($headers);
        ob_end_clean();
        echo $content;
    }
}
/**
 * Data URLs for icons used by the interface.
 * TODO: eventually move this to a themes module
 */
class Hm_Image_Sources {
    public static $power = '';
    public static $home = '';
    public static $box = '';
    public static $env_closed = '';
    public static $star = '';
    public static $globe = '';
    public static $doc = '';
    public static $monitor = '';
    public static $cog = '';
    public static $people = '';
    public static $caret = '';
    public static $folder = '';
    public static $chevron = '';
    public static $check = '';
    public static $refresh = '';
    public static $big_cog = '';
    public static $big_caret = '';
    public static $big_caret_left = '';
    public static $search = '';
    public static $info = '';
    public static $bug = '';
    public static $code = '';
    public static $person = '';
    public static $rss = '';
    public static $rss_alt = '';
    public static $caret_left = '';
    public static $caret_right = '';
}
/**
 * Message list struct used for user notices and system debug
 */
trait Hm_List {
    /* message list */
    private static $msgs = array();
    /**
     * Add a message
     *
     * @param $string string message to add
     *
     * @return void
     */
    public static function add($string) {
        self::$msgs[] = self::str($string, false);
    }
    /**
     * Return all messages
     *
     * @return array all messages
     */
    public static function get() {
        return self::$msgs;
    }
    /**
     * Stringify a value
     *
     * @param $mixed mixed value to stringify
     *
     * @return string
     */
    public static function str($mixed, $return_type=true) {
        $type = gettype($mixed);
        if (in_array($type, array('array', 'object'), true)) {
            $str = print_r($mixed, true);
        }
        elseif ($return_type) {
            $str = sprintf("%s: %s", $type, $mixed);
        }
        else {
            $str = (string) $mixed;
        }
        return $str;
    }
    /**
     * Show all messages
     *
     * @param $type string can be one of "print", "log", or "return"
     *
     * @return mixed
     */
    public static function show($type='print') {
        if ($type == 'log') {
            Hm_Functions::error_log(print_r(self::$msgs, true));
        }
        elseif ($type == 'return') {
            return print_r(self::$msgs, true);
        }
        else {
            print_r(self::$msgs);
        }
    }
}
/**
 * Notices the user sees
 */
class Hm_Msgs { use Hm_List; }
/**
 * System debug notices
 */
class Hm_Debug {
    
    use Hm_List;
    /**
     * Add page execution stats to the Hm_Debug list
     *
     * @return void
     */
    public static function load_page_stats() {
        self::add(sprintf("PHP version %s", phpversion()));
        self::add(sprintf("Zend version %s", zend_version()));
        self::add(sprintf("Peak Memory: %d", (memory_get_peak_usage(true)/1024)));
        self::add(sprintf("PID: %d", getmypid()));
        self::add(sprintf("Included files: %d", count(get_included_files())));
    }
}
/**
 * Easy to use error logging
 *
 * @param $mixed value to send to the log
 * 
 * @return void
 */
function elog($mixed) {
    if (DEBUG_MODE) {
        $bt = debug_backtrace();
        $caller = array_shift($bt);
        Hm_Debug::add(sprintf('ELOG called in %s at line %d', $caller['file'], $caller['line']));
        Hm_Functions::error_log(Hm_Debug::str($mixed));
    }
}
?>