SNOBOL4SETUP(3) | CSNOBOL4B 2.3.2 | Janurary 1, 2024
NAME
snobol4setup – SNOBOL4 Loadable module setup utility
SYNOPSIS
snobol4 setup.sno command
DESCRIPTION
The example program below (canonically called setup.sno) can be invoked
(portably across different operating systems)
with the following commands:
OPTIONS
-
build
-
Compiles and links a dynamicly loadable executable file
named modulename (with the appropriate extension for the local system).
modulename.sno will be created from:
pre.sno (if it exists), followed by lines from sourcefiles:
any instances of LOAD(...) present in * comments,
any groups of lines starting with *=pea and ending with *=cut (inclusive),
any comment lines bracketed by *=snobol4 and *=cut (exclusive)
will be copied without the leading *,
and finally funcs.sno (if it exists).
-
install
-
installs binary, include and man page files.
-
clean
-
cleans up.
EXAMPLE
-INCLUDE 'setuputil.sno'
t = TABLE()
t['module'] = 'modulename'
t['sources'] = 'sourcefile.c,othername.c'
t['author'] = t['maintainer'] = 'Yourname Here'
t['author_email'] = t['maintainer_email'] = 'name@doma.in'
t['include_dirs'] = 'list,of,dirs,to,search'
t['library_dirs'] = 'list,of,dirs,to,search'
t['libraries'] = 'list,of,library,names,to,link,against'
t['license'] = 'BSD'
setup(t)
end
If LOAD() functions appear as the first thing on a comment line
in the source files, they are output to the generated
modulename.sno include file so that the module and its functions
are loaded when the include file is used.
snopea(7) directives in comments in the source files will be used
to generate man(7) and .html documentation files.
NOT CONFORMING TO
Inspired by Python setuptools, easyinstall, et.al.
AUTHOR
Philip L. Budne
BUGS
Has not been tested with proprietary Un*x native toolchains.
SEE ALSO
snobol4(1), snobol4load(3), snopea(7)