IV. API Reference
[ Previous: A. Alphabetical Function List | Next: C. Language-Behavior Functions ]
B. Core Parsing Functions
	BBCode::BBCode ( )
	This is the constructor for the BBCode object.  It assigns default values
		to all settings and creates all attached objects like the BBCodeLibrary object.
	Parameters:  None.
	Return Value:  None.
 
	string BBCode::Parse ( string $string )
	This function is the public interface to the core BBCode
		parser; supply this with BBCode as input, and it will return that BBCode converted to HTML.
	Parameters:
		
		- string: The string to be converted from BBCode to HTML.
 
	Return Value:  A string containing HTML converted from the input BBCode.
 
	string BBCode::DoTag ( string $action , string $tag_name ,
		string $default_value , array $params , string $contents )
	This function is called by the parser to check tags and to convert tags into HTML.
		It is called at most twice for each tag.  Normally, it dispatches the checking/conversion job to
		other functions, like library functions and callback functions, but you can override this
		behavior by inheriting the BBCode class and overriding this function.
	Parameters:
		
		- action: One of BBCODE_CHECK or BBCODE_OUTPUT, depending
			on the task to be performed.  If this is BBCODE_CHECK, DoTag() must return
			true if the inputs are acceptable, or false if the inputs are unacceptable;
			if this is BBCODE_OUTPUT, DoTag() must return an HTML string that contains
			the converted output of this tag.
- tag_name: The name of the tag being processed, without surrounding brackets
			or an end-tag slash (/), as in "b" or "quote".
- default_value: The default value of the tag.  The default value is the
			value assigned to the tag name itself; for example, in [quote=John], the default
			value is "John", but in [quote name=John] or [b], the default
			value is the empty string.
- params:  This is an array of key => value parameters given in the tag.
			For example, in the tag [tag="foo" bar="baz" chocolate="good"], this array would be:
 array(
        "_name" => "tag",
        "_default" => "foo",
        "bar" => "baz",
        "chocolate" => "good",
    );
			The "_name" and "_default" parameters will always be present in this
			array, and will always contain the same values as $tag_name and $default_value.
- contents:  This parameter is only valid during BBCODE_OUTPUT;
			during BBCODE_CHECK it will always be the empty string.  This parameter contains
			the "contents" of the tag, the text between the start tag and its matching end tag.  For
			example, with this input:
 [b]The quick brown "fox" jumps over the lazy dog.[/b]
 during BBCODE_OUTPUT, the $contents parameter will be set to:
 The quick brown "fox" jumps over the lazy dog.
 This parameter is always either the empty string or fully-validated HTML contents.
 
	Return Value:  For BBCODE_CHECK, this must return true if
		the default value and parameters are acceptable, or false if they're malformed.  For
		BBCODE_OUTPUT, this must return clean HTML output text.
	Warning:  This function is part of NBBC's internal parser.  It is exposed
		and documented so that you can inherit and override its behavior if you want, should
		you want exotic tag processing that NBBC does not perform by default; however,
		be aware that by changing this you are changing NBBC's internals, so be careful.
 
	void BBCode::SetDebug ( bool $enable )
	This function enables NBBC's built-in debug mode.  When in debug mode,
		NBBC will dump huge quantities of data to the browser to indicate what it is doing
		when it parses a given chunk of input (it's not unusual for a single line of BBCode input
		to produce several pages of debug output).  This is useful if you think NBBC is
		misbehaving, or if you're adding a tag of your own and trying to figure out why it is or
		is not working correctly.  You should not enable debug mode in production environments.
	Parameters:
		
		- enable: Whether to turn debug mode on or off; if this parameter is true,
			debug mode will be enabled and huge quantities of debugging information will be dumped to the
			browser; if this parameter is false, no debugging information will be displayed.
 
	Note:  Debug mode is disabled by default, and is only available if
		you use the multi-file version of NBBC (nbbc_main.php, nbbc_parse.php,
		nbbc_lex.php, etc.):  In the compressed version of NBBC (nbbc.php),
		all debugging code has been removed to make the code smaller and faster.  This function
		and GetDebug() still both exist in the compressed version, but regardless of the state
		of the debug flag, compressed NBBC will not display any debugging information.
	
 
	bool BBCode::GetDebug ( )
	This function returns the current state of NBBC's built-in 
debug mode.
		See 
SetDebug() for more details.
Return values:  Returns true or false, depending on
		whether debug mode is enabled.
 
[ Previous: A. Alphabetical Function List | Next: C. Language-Behavior Functions ]
Copyright © 2010, the Phantom Inker.  All rights reserved.