A fetish is a loadable module written in C, C++ and/or Rust that extends
Fetlang. By default, a fetish called core
loads automatically and contains
the main language functionality.
Using the phrase I have a fetish for
in a comment will load a fetish. Example:
(I have a fetish for assertiveness)
Will load the fetish assertiveness
. Fetish loading takes place during
tokenization, before any keyphrases are recognized, so it doesn't matter where
you place the statement.
You can create your own custom fetishes to extend Fetlang. A fetish is a directory structured as follows
// Directory with name of fetish
assertiveness
// Fetish file - wraps the C code with Fetlang operators, conditional operators, and variables
fetish.json
// A unit test written in Fetlang
unit.fet
// public C headers directory
include
...
// C/C++/Rust source and private headers
source
...
The C headers and source contains whatever you want. The files in ./include
should contain functions and the like you reference either from fetish.json
or another fetish. To access another fetish's members, you can #include "fetish_name/file_name"
The C++ and Rust sources should export unmangled functions to be declared in the C headers.
Every fetish must contain a fetish.json file. You can use fetishes/core/fetish.json as a good example.
Fields:
description
: A string description of the fetish. Used for documentation generation
dependencies
: The libraries and fetishes the fetish depends on
operators
: An array of objects describing a Fetlang operator
comparison_operators
: An array of objects describing a Fetlang comparison operator
builtins
: An array ob objects describing a Fetlang builtin variable
preloop_code
: Code that runs before the main do-while loop
postloop_code
: Cleanup code that runs after the main do-while loop
The documentation for each fetish can be seen here