Search Over 30,000 FREE Plugins from the Official WordPress Plugin Directory Repository

Commentcode API

A shortcode API alternative.

Generate Custom Outputs with HTML Comments

Commentcode API lets you generate custom outputs with HTML comment-like codes.

It is similar to the Shortcode API except it takes a form of HTML comments and some few features.

Since it takes a form of HTML comments, even the user disables your plugin, the embedded code will not be visible, on contrary to shortcodes that remain in posts when their plugins are deactivated.

Does not leave a mess in posts

Say, you have been using a plugin that converts a plugin specific shortcode into custom outputs. Later you found something else that is more useful and uninstalled it.

But the shortcodes used by that plugin remained in hundreds of posts and it was too much work to manually delete them so you have to ask somebody to run SQL commands.

That's a problem. What if the shortcode takes a form of an HTML comment? It won't leave such a mess.

Syntax

It looks like this.

<!--- tag foo="bar" --->
<!--- tag color="#333" ---><p>Some outputs.</p><!--- /tag --->

Notice that tripe dashes are used in the both opening and closing part. So it won't hardly conflict with generic HTML comments.

Supports Multi-dimensional Array Arguments

The shortcode cannot pass multi-dimensional arguments to the callback function.

The below attributes won't be parsed.

[my_shortcode foo[1]="one" foo[2]="two"]

However, commentcode can handle it.

<!---my_shortcode foo[1]="one" foo[2]="two" --->

The attributes are interpreted as

array(
    'foo'   => array(
        1 => 'one',
        2 => 'two',
    )
)

Preserved Letter Cases

The shortcode does not allow capitalized attribute names.

[my_shortcode CapitalName="I need it to be capitalized"]

The attribute is interpreted as

array(
    'capitalname' => 'I need it to be capitalized',
)

This is not useful when you need to perform remote API requests which require argument names with capital letters.

However, the commentcode API preserves those argument names.

<!--- my_shortcode CapitalName="Please keep capitalization!" --->

will be

array(
    'CapitalName'   => 'Please keep capitalization!',
)
Author Michael Uno
Profile
Contributors MichaelUno, miunosoft
Tags api, commentcode, HTML comments, shortcode
  1. Upload commentcode-api.php and other files compressed in the zip folder to the /wp-content/plugins/ directory.
  2. Activate the plugin through the 'Plugins' menu in WordPress.

1.0.0

  • Released.

The commentcode inserted in a post does not get converted. What's the problem?

Double check you insert it in the View panel of the editor.

Other Notes

Register a Commentcode

Use the add_commentcode() function. It accepts two parameters. 1. (string) the commentcode tag. 2. (callable) a callback function which gets called when the commentcode of the specified tag is processed.

The callback function receives three parameters. 1. (string) The filtered text, usually an empty string. 2. (array) The attributes set in the commentcode. 3. (string) The commentcode tag name.

function get_my_commentcode( $text, $arguments, $tag ) {
    return "<pre>" . htmlspecialchars( print_r( $arguments, true ) ) . "</pre>";
}
add_commentcode( 'my_commentcode', 'get_my_commentcode' );

For a test, while running the above code, try inserting <!---my_commentcode Foo="bar" numbers[ 1 ]="one" numbers[ 2 ]="two"---> in a post.

It will produce this output,

Array
(
    [Foo] => bar
    [numbers] => Array
        (
            [1] => one
            [2] => two
        )

)
Share  
Download
Version 1.0.0

Requires WordPress version: 3.4 or higher

Compatible up to: 4.7.0

Last Updated 21 Dec 2016

Date Added: 21 Dec 2016

Plugin Homepage

Evaluation
star1
star2
star3
star4
star5

0 stars
0 ratings
29 downloads

Compatibility

Not Enough Data

Reports:
Works: 0
Broken: 0