An open API service indexing awesome lists of open source software.

https://github.com/dacap/htmlex

A small HTML preprocesor
https://github.com/dacap/htmlex

Last synced: 17 days ago
JSON representation

A small HTML preprocesor

Awesome Lists containing this project

README

          

# htmlex
**A powerful hypertext markup language preprocessor (HTML)**
> Copyright (C) 2001, 2002, 2003 by David Capello

## Introduction

htmlex is a small but powerful HTML preprocesor, which has numerous
advantages compared to conventional HTML files. On top of that, htmlex
is fully compatible with the standard HTML syntax. This means that you
can use any HTML file that you have previously made, rename it to
`.htex`, and start using htmlex.

This software is distributed under the [MIT license](license.txt).

## Options

htmlex interprets the following options from the command line:

-c compiles all subsequent files (gets an output file name
from '-o' or generates a name with .html extension, see -E)
-o adds output files
-a adds arguments for the input files
-I adds search include paths (you can use old '-i' parameter)
-E changes the HTML extension generated by -c option (.html by default)
-k kills comments (old htmlex behavior)
-d calculates dependencies of the input files (output to STDOUT)
-v activates the verbose mode (to see what htmlex does)
-V activates very verbose mode (to debug .htex files)
-h displays help screen and exit
-- breaks -coaI arguments

## Execution

### References

* `STDIN` (standard input): from the keyboard or from file.
* `STDOUT` (standard output): to the screen or to file.

### Common behavior

./htmlex
Process `STDIN` and leave the results in `STDOUT`.

./htmlex file arguments...
Process `file` and leave the results in `STDOUT`.

./htmlex -c files... -a arguments...
Process `files` and leave the results in `files.html`.

./htmlex -c files... -o destinations...
./htmlex -o destinations... -c files...
Process the `files` and leave the results in the `destinations`.

### Some equivalent examples

./htmlex file.htex arg1 arg2 > file.html
./htmlex -c file.htex -a arg1 arg2
./htmlex -c file.htex -o file.html -a arg1 arg2
./htmlex -a arg1 arg2 < file.htex > file.html
./htmlex -a arg1 arg2 -o file.html < file.htex

### Common mistakes

#### File to compile

./htmlex -I examples file.htex > file.html

Here the program waits for input from `STDIN`, because `file.htex`
counts as another path for `-I`.
Possible solutions:

./htmlex -I examples -- file.htex > file.html
./htmlex -I examples -c file.htex
./htmlex file.htex -I examples > file.html

#### Arguments for the input file

./htmlex -c index.htex en English

Here, htmlex will try to compile the files `index.htex`, `en` and
`English`, instead of passing the arguments to `index.htex`.
Possible solutions:

./htmlex -c index.htex -a en English
./htmlex index.htex en English > index.html

### Changes from previous versions

* Now you can use `-I` instead of `-i` (like gcc).
* The argument order isn't necessary anymore, so you can do:

./htmlex -c src.htex -o dst.html -I dir

## Features

### Reference

This notation will be used along of the definitions:

* `expression`: The `expression` is mandatory.
* `[ expression ]`: The `expression` is optional.
* `{ expression }`: The `expression` is optional and repeatable.
* `source -> result`: Indicates that `results` will be obtained when
the program will process the `source` text.

### Tags

Lists of tags which you can use in the `.htex` files (by alphabetical
sorting):

#### args

Returns the number of arguments which was passed to the input file.

Example:

You input argument(s).

#### argN

...
Returns the argument's value. The arguments are passed to the files
via the command line's `-a` option, or from the `` tag.

Example:

2nd argument = .

#### basename

Returns the base name of the `file`. In other words, removes its
extension.

Examples:

-> src/foo
-> src-1.0/bar
-> hacks

#### chop

Removes the last character of `word`.

Examples:

-> hell
-> directorio

#### clean

Cleans `word` removing blank space (tabulators and line breaks)
around it.

Example:

** -> *hola*

#### dep


Adds 'file' as a dependency. This tag takes effect only in the dependency
generation process.

Example:


#### dir

Returns the directory part of `file`. In other words, deletes the file name.

Examples:

-> src/
-> a/b/
-> ./

#### elif

See [if](#if).

#### else

See [if](#if).

#### end

See [function](#function).

#### exec

Executes the indicated `command` passing the `arguments` to it. Whatever
the command prints to the standard output (`STDOUT`) will be inserted at
this position in the file.

Examples:


#### exec-proc

Equal to `` except that it will process the results as other
htmlex file.

Examples:



>

#### fi

See [if](#if).

#### file-size

Returns the size of `file` in a format that's more human-readable
(bytes, KB, MB or GB).

Example:

image

#### find

Tries to find `file` in the search path (the active directory and
all directories added with the `-I` option), and will return the name
of the `file` with the matching path. In the case that the file isn't
found, nothing is returned.

Examples:

>
english

#### function

Creates a new functional macro like in C/C++. When the program see
this tag, it follows reading the file in "raw" mode until finds
`` tag. Then, the macro could be called like any other tag:
``

Example:

a is b c
.

Output:

This is my macro.

#### if

One of the more powerful features of htmlex relative to
conventional HTML is the conditional-blocks.

Through four tags you can do some of the conditional operations
of "normal" programming languages. Although nowadays, htmlex has a
poor handling of operations, improvements to this construct will
made.

The general syntax is the following:

block
{ block }
[ block ]

The `block` can be any text (or just nothing), can have other tags,
and consequentialy, can have more nested `` tags.

The `expression` to be evaluated can have any of the formats below:

FORMAT TRUE IF...
------- ----------
number number is not zero
! number number is zero
word word has one character as minimum
! word word is empty
number1 < number2 number1 is less than number2
number1 > number2 number1 is greater than number2
number1 <= number2 number1 is less or equal than number2
number1 >= number2 number1 is greater or equal than number2
number1 == number2 number1 is equal than number2
number1 != number2 number1 is different than number2
word1 == word2 word1 is identical than word2
word1 != word2 word1 differs in just one character than word2

If the expression format cannot be resolved to the table above, then
false is returned.

`numbers` are distinguished from `words` when they have some of these
formats:

[1-9][0-9]* decimals
0x[0-9a-fA-F]* hexadecimals
0[0-7] octals

Examples:

== --help>
Do you need help?

Try with --help.

== >
works

For here it won't never pass

#### include

Includes the `file` to be processed like an normal `.htex` file. This file
will also be used for calculating dependencies. This is equivalent to
C's `#include`.

Examples:


#### macro

Creates or modifies a macro with the specified `name` and `value`.
If `value` is not specified, the macro will be eliminated from
memory. The main use of macros is to replace a certain keyword
(its `name`) for some predetermined text (its `value`).

Example:


hi -> bye

hi -> hi

#### macro-reset

Removes any macro which was created before this tag.

Example:

aa -> ba

#### notdir

Returns the name of the `file` without the directory.

Examples:

-> foo.c
-> foo.h
-> hacks

#### shift

Removes the first character of `word`.

Examples:

-> our
-> txt

#### suffix

Returns the extension of `file`.

Examples:

-> .c
->
->

#### tolower

See [toupper](#toupper).

#### toupper

Converts partially or completelly `word` to lower or upper case
depending on if you specify or not the `beginning` and/or the `final`
character index. Indecies start at 0.

If only `beginning` is specified, then the range starting from
`beginning` to the last character is converted.
If you also indicate `final`, you are specifying an upper bound
to the conversion range.

Note: negative values for `final` indicates that values are to be taken
from the end of the `word`.

Examples:

-> hello
-> hELLO
-> hELlo
-> HELLo

#### version

Shows the program version which is processing the file.

Example:

This page was created with htmlex .

# Important Notes

* `` deletes the X macro, so if you use ``
that expression will give you true (because the string "X"
will be used, and not the value of X).

* `` assigns a null value to the X macro, this is
necessary for a false result in `` (because in this case,
the X is replaced by its value).

## Author

David Capello

Any suggestion, thank-you letters, or (preferably) donations ;-),
will be most welcomed.

You can visit http://davidcapello.com/donate/ for more information.