Macro-HTML Compiler v1.1 (C) 1999 A'rpi/ESP-team ======================== Description: ~~~~~~~~~~~~ This is a simple macro-compiler for text and HTML files. You can define and call macros, and access parameters on command line. The syntax is very similar to BAPC's language, the only difference is that end of macro is signed by a '#', not ENDM or EOL. The compiler also skip DOS-style newlines (#13), and allow maximum 2 empty lines after eachother in output, it makes HTML files readable. It was designed to help managing a big site (ESP-team's homepage), which is mirrored at many places, and addresses are changed very often. I built the site from macros, so the source isn't redundant, changes can be made very easy! Writting a section for a new program is easy too. Usage: ~~~~~~ mhtml [parameters] < source.mhtml > dest.html If you want to append multiple source files: cat *.mhtml | mhtml [params] > dest.html I'm using: cat global.mac local-1.mac header.mac *.mhtml footer.mac | mhtml > page.html Macro definition: ~~~~~~~~~~~~~~~~~ #macroname=contents# Macroname must be from a character set 'A'..'Z', '0'..'9' and '_'. Contents part can contain spaces and newlines as well. You can access parameters (passed to the macro) by %n, where n is a number 0..9. There is a special macro defined by default, called ARG(n), it returns with the n'th argument in the command-line. Other special macro is DOWNCASE(string), it will return string with all letters down-cased. DOWNCASE("Hello WORLD") = "hello world". Macro call: ~~~~~~~~~~~ $macroname or $macroname(parameters) You can use %n in the parameters part! Special characters: ~~~~~~~~~~~~~~~~~~~ You can quote chars with backslash (\) character. You have to quote hash (#), dollar ($) and percent (%) chars, because they have special meaning in this macro-language. Comments: ~~~~~~~~~ You can put comment into the source file including ` chars: `This is a comment` These comments won't be written to the output. If you want HTML comments, use the standard style. Example: ~~~~~~~~ Source file 'src.mhtml': #B=%1# #R=
# #LINK2=%2# #EMAIL=$LINK2("mailto://%1","%2 <%1>")# #DOMAIN=$ARG(1)# #A_ARPI=$EMAIL("arpi@$DOMAIN","A'rpi")# #A_PILU=$EMAIL("gpilaszy@$DOMAIN","Pilu")# $B(Authors:) $A_ARPI and $A_PILU $R Compile: mhtml esp-team.scene.hu < src.mhtml > page.html Output file 'page.html': Authors: A'rpi <arpi@esp-team.scene.hu> and Pilu <gpilaszy@esp-team.scene.hu>