HEX
Server: Apache
System: Linux web15f74.uni5.net 5.4.282-1.el8.elrepo.x86_64 #1 SMP Mon Aug 19 18:33:22 EDT 2024 x86_64
User: lucendi (859622)
PHP: 7.4.33
Disabled: apache_child_terminate,c99_buff_prepare,c99_sess_put,dl,exec,leak,link,myshellexec,openlog,passthru,pclose,pcntl_exec,php_check_syntax,php_strip_whitespace,popen,posix_kill,posix_mkfifo,posix_setpgid,posix_setsid,posix_setuid,proc_close,proc_get_status,proc_nice,proc_open,proc_terminate,shell_exec,show_source,symlink,system,socket_listen,socket_create_listen,putenv
Upload Files
File: /home/lucendi/www/wp-content/themes/mesmerize/inc/mesmerize-markdown-parse.php
<?php

/**
 * Slimdown - A very basic regex-based Markdown parser. Supports the
 * following elements (and can be extended via Slimdown::add_rule()):
 *
 * - Headers
 * - Links
 * - Bold
 * - Emphasis
 * - Deletions
 * - Quotes
 * - Inline code
 * - Blockquotes
 * - Ordered/unordered lists
 * - Horizontal rules
 *
 * Author: Johnny Broadway <johnny@johnnybroadway.com>
 * Website: https://gist.github.com/jbroadway/2836900
 * License: MIT
 */
class Mesmerize_Slimdown
{
    public static $rules = array(
        '/(#+)(.*)/'                   => 'self::header',            // headers
        '/\[([^\[]+)\]\(([^\)]+)\)/'   => '<a href=\'\2\'>\1</a>',   // links
        '/(\*\*|__)(.*?)\1/'           => '<strong>\2</strong>',     // bold
        '/(\*|_)(.*?)\1/'              => '<em>\2</em>',             // emphasis
        '/\~\~(.*?)\~\~/'              => '<del>\1</del>',           // del
        '/\:\"(.*?)\"\:/'              => '<q>\1</q>',               // quote
        '/------(.*?)------/s'         => 'self::memserizeblock',
        '/`(.*?)`/'                    => '<code>\1</code>',         // inline code
        '/\n\s?\*(.*)/'                => 'self::ul_list',           // ul lists
        '/\n\s?[0-9]+\.(.*)/'          => 'self::ol_list',           // ol lists
        '/\n(&gt;|\>)(.*)/'            => 'self::blockquote ',       // blockquotes
        '/\n-{5,}/'                    => "\n<hr />",                // horizontal rule
        '/\n([^\n]+)\n/'               => 'self::para',              // add paragraphs
        // fixes
        '/<\/ul>\s?<ul>/'              => '',                         // fix extra ul
        '/<\/ol>\s?<ol>/'              => '',                         // fix extra ol
        '#<code></code>#'              => '',                         // fix empty code
        '/<p><\/p>/'                   => '',                         // fix empty p
        '/<\/blockquote><blockquote>/' => "\n"                        // fix extra blockquote
    );

    private static function para($regs)
    {
        $line    = $regs[1];
        $trimmed = trim($line);

        if ( ! $trimmed) {
            return;
        }

        if (preg_match('/^<\/?(ul|ol|li|h|p|bl)/', $trimmed)) {
            return "\n" . $line . "\n";
        }

        return sprintf("\n<p>%s</p>\n", $trimmed);
    }

    private static function memserizeblock($regs)
    {
        $line    = $regs[1];
        $trimmed = trim($line);

        if ( ! $trimmed) {
            return;
        }

        return sprintf("\n<div class='area'>%s</div>\n", $trimmed);
    }

    private static function ul_list($regs)
    {
        $item = $regs[1];

        return sprintf("\n<ul>\n\t<li>%s</li>\n</ul>", trim($item));
    }

    private static function ol_list($regs)
    {
        $item = $regs[1];

        return sprintf("\n<ol>\n\t<li>%s</li>\n</ol>", trim($item));
    }

    private static function blockquote($regs)
    {
        $item = $regs[2];

        return sprintf("\n<blockquote>%s</blockquote>", trim($item));
    }

    private static function header($regs)
    {
        list ($tmp, $chars, $header) = $regs;
        $level = strlen($chars);

        return sprintf('<h%d>%s</h%d>', $level, trim($header), $level);
    }

    /**
     * Add a rule.
     */
    public static function add_rule($regex, $replacement)
    {
        self::$rules[$regex] = $replacement;
    }

    /**
     * Render some Markdown into HTML.
     */
    public static function render($text)
    {
        $text = "\n" . $text . "\n";

        $textParts = explode("\n", $text);
        $textParts = array_map('trim', $textParts);
        $text      = implode("\n", $textParts);

        foreach (self::$rules as $regex => $replacement) {
            if (is_callable($replacement)) {
                $text = preg_replace_callback($regex, $replacement, $text);
            } else {
                $text = preg_replace($regex, $replacement, $text);
            }
        }

        return trim($text);
    }
}