Back to mnoGoSearch site

mnoGoSearch 3.3.12 reference manual: Full-featured search engine software
PrevChapter 10. Searching documentsNext

Template operators

mnoGoSearch template language provides a set of operators making it possible to create templates with some logic.

Conditional operators

mnoGoSearch supports a number of conditional operators in search templates: IF, IFCS, IFNOT, IFLIKE, ELSEIF (ELIF), ELSELIKE (ELIKE), IFLE, IFLT, IFGE, IFGT.

Comparison is performed case insensitively for the operators IF, IFNOT, IFLIKE, ELSEIF, ELSELIKE, and case sensitively for IFCS. The operators IFLE, IFLT, IFGE, IFGT perform numeric comparison: less-or-equal, less, greater-or-equal and greater comparison correspondingly.


<!IF   NAME="Content-Type" Content="application/pdf">
<img src="pdf.png">
<!ELIF NAME="Content-Type" Content="text/plain">
<img src="text.png">

This is an HTTP address
This is an FTP address
This is an unknown address type>

It is possible to use nested conditional operators. This gives much power for search template construction. You can find some examples in the default template search.htm-dist.

The SET operator

This operator is designed to set a variable value from a constant, from another variable, or from a more complex expression.


<!SET NAME="a" Content="Some string">
<!SET NAME="b" Content="Another string">
<!SET NAME="c" Content="$(a)">
<!SET NAME="d" Content="a is '$(a)', b is '$(b)', c is '$(c)'">

The COPY operator

The COPY operator calculates the expression given in the attribute CONTENT, then treats this value as a name of another variable, whose value is then copied into to the variable with the name given in the attribute NAME.


<!SET NAME="v1" CONTENT="The first value">
<!SET NAME="v2" CONTENT="The second value">
<!SET NAME="v3" CONTENT="The third value">
<!SET NAME="i"  CONTENT="2">
<!COPY NAME="value" CONTENT="v$(i)">
The above code will display this text:

Value="The second value"

Arithmetic operators

Arithmetic operators INC and DEC respectively increment and decrement a variable value treating it as an integer number.


<!SET NAME="a" Content="10">a is $(a)
<!INC NAME="a">After increment, a is $(a)
<!DEC NAME="a">After decrement, a is $(a)

Arithmetic operators ADD, SUB, MUL perform integer addition, subtraction and multiplication of two variables specified in the NAME and CONTENT attributes and write the result back into the variable specified in the NAME attribute.


<!SET NAME="b" CONTENT="20">
<!SET NAME="a" CONTENT="10">
<!MUL NAME="a" CONTENT="$(b)">a*b=$(a)
<!SET NAME="a" CONTENT="10">
<!ADD NAME="a" CONTENT="$(b)">a+b=$(a)
<!SET NAME="a" CONTENT="10">
<!SUB NAME="a" CONTENT="$(b)">a-b=$(a)             

Loop operators

Three loop operators WHILE, WHILENOT and FOR are available. The FOR operator was introduced in mnoGoSearch 3.3.0.


<!SET      NAME="a" Content="10">
<!WHILENOT NAME="a" Content="0">
  a is $(a)
<!DEC NAME="a">

<!FOR NAME="a" FROM="10" TO="20">a=$(a)<!ENDFOR>

<!SET NAME="from" CONTENT="80">
<!SET NAME="to" CONTENT="90">
<!FOR NAME="a" FROM="$(from)" TO="$(to)">a=$(a)<!ENDFOR>

Miscellaneous operators and functions

URLDECODE - decodes an URL-encoded string.

All instances of the %## encoding in the given string are decoded and the decoded string is written into the variable specified in the NAME attribute.


<!URLDECODE NAME="decoded" Content="$(url)">URL is $(decoded)

HTMLENCODE - converts special characters to HTML entities

. The conversion rules are:


<!HTMLENCODE NAME="encoded" Content="$(url)">URL is $(encoded)

EREG - Replaces a regular expression.

<!EREG NAME="a" CONTENT="string" MATCH="pattern" RESULT="replacement">

EREG scans the string given in the CONTENT attribute for matches to the string given in MATCH and stores the matched text into variable given in NAME using the RESULT value as a replacement pattern. The replacement string can contain substrings in the form $N, where N is a decimal digit 0..9, which is replaced to the text matching the N-th parenthesized substring. $0 produces the entire contents of matching string. The CONTENT string can have references to other variables.


<!SET NAME="str" CONTENT="">
<!EREG NAME="a" CONTENT="$(str)"
MATCH="^([a-z]*)://([^/]*)/(.*)" RESULT="scheme=$1; host=$2
will display:

scheme=http path=path/file.ext