block_gamut += array( "doBlockWarning" => 45, ); parent::MarkdownExtra_Parser(); } function doBlockWarning($text) { $text = preg_replace_callback('/ ( # Wrap whole match in $1 (?> ^[ ]*![ ]? # "!" at the start of a line .+\n # rest of the first line (.+\n)* # subsequent consecutive lines \n* # blanks )+ ) /xm', array(&$this, '_doBlockWarning_callback'), $text); return $text; } function _doBlockWarning_callback($matches) { $bq = $matches[1]; # trim one level of quoting - trim whitespace-only lines $bq = preg_replace('/^[ ]*![ ]?|^[ ]+$/m', '', $bq); $bq = $this->runBlockGamut($bq); # recurse $bq = preg_replace('/^/m', " ", $bq); # These leading spaces cause problem with
 content, 
		# so we need to fix that:
//		$bq = preg_replace_callback('{(\s*.+?
)}sx', array(&$this, '__doBlockWarning_callback2'), $bq);
		return "\n" . $this->hashBlock("\n$bq\n") . "\n\n";
	}
	function _doBlockWarning_callback2($matches) {
		$pre = $matches[1];
		$pre = preg_replace('/^  /m', '', $pre);
		return $pre;
	}
}
if (!function_exists('load_doc_file')) {
	function load_doc_file($s) {
		global $lang;
		if (!isset($lang))
			$lang = 'en';
		$b = basename($s);
		$d = dirname($s);
		if (file_exists("$d/$lang/$b"))
			return file_get_contents("$d/$lang/$b");
		if (file_exists($s))
			return file_get_contents($s);
		return '';
	}
}
function help_content(&$a) {
	
	
	nav_set_selected('help');
	global $lang;
	$text = '';
	if ($a->argc > 1) {
		$text = load_doc_file('doc/' . $a->argv[1] . '.md');
		$a->page['title'] = t('Help:') . ' ' . str_replace('-', ' ', notags($a->argv[1]));
	}
	$home = load_doc_file('doc/Home.md');
	if (!$text) {
		$text = $home;
		$a->page['title'] = t('Help');
	} else {
		$a->page['aside'] = Markdown($home);
	}
	if (!strlen($text)) {
		header($_SERVER["SERVER_PROTOCOL"] . ' 404 ' . t('Not Found'));
		$tpl = get_markup_template("404.tpl");
		return replace_macros($tpl, array(
					'$message' => t('Page not found.')
				));
	}
	
	$html = Markdown($text);
	$html = "".$html;
	return $html;
		
}