[ Previous ] [ Contents ] [ Index ] [ Next ]

ns_register_adptag

Overview

Register a tag for use within an ADP

Syntax

ns_register_adptag command ?endcommand? proc

Description

ns_register_adptag registers a procedure to be called when the specified beginning and ending tags are used in an ADP. The command is the beginning tag to look for, and the endcommand is the ending tag to look for. The proc is the procedure that will be called when AOLserver encounters those tags when processing an ADP.

There are two ways to use ns_register_adptag, with and without the endcommand parameter:

The string is the string of characters between the beginning tag and the ending tag. The tagset is an ns_set of parameters that were specified with the beginning tag. The return value of the procedure will be sent to the browser in place of the string of text that was specified between the beginning and ending tags.

The string is not parsed, which means that you cannot include ADP tags in the string unless you execute ns_adp_parse on the string inside the procedure that processes the registered ADP tag.

Note: This function cannot be called after the server has started. It must be called in a Tcl script in a virtual server's Tcl directory so that it can be initialized at server startup time.

Example

  1. For example, suppose you want to register a tag that displays the enclosed text only if it is Christmas. You could register the tag as follows:

        ns_register_adptag "christmas" "/christmas" xmas
        proc xmas {string tagset} {
          if {[ns_fmttime [ns_time] "%m/%d"] == "12/25"}  then {
          return $string
          }
        }
    

    Then, in an ADP, you could use these tags:

        <christmas>Merry Christmas to all, and to all a good night!
        </christmas>
    

  2. This example shows the use a registered tag without an endcommand. The tag is registered as follows:

        ns_register_adptag hello helloproc
        proc helloproc { tags } {
            return "Hello, [ns_set get $tags name]."
        }
    

    In an ADP, you could then use this tag:

        <hello name=Bob>
    

Top of Page

[ Previous ] [ Contents ] [ Index ] [ Next ]
Copyright © 1998-99 America Online, Inc.