zeek/tools/bifcl
2025-08-20 08:52:25 -07:00
..
include bifcl: Add clang-format and run it on everything 2025-08-20 08:52:25 -07:00
bif_arg.cc bifcl: Add clang-format and run it on everything 2025-08-20 08:52:25 -07:00
builtin-func.l bifcl: Use nullptrs for pointer initializations 2025-08-20 08:52:25 -07:00
builtin-func.y bifcl: Use nullptrs for pointer initializations 2025-08-20 08:52:25 -07:00
CMakeLists.txt bifcl: Only adding subdir if running standalone 2025-08-20 08:52:25 -07:00
module_util.cc bifcl: Add clang-format and run it on everything 2025-08-20 08:52:25 -07:00
README bifcl: Rename Bro to Zeek 2025-08-20 08:52:24 -07:00

.. _Zeek: https://www.zeek.org

=================
Zeek BIF Compiler
=================

The ``bifcl`` program simply takes a ``.bif`` file as input and
generates C++ header/source files along with a ``.zeek`` script
that all-together provide the declaration and implementation of Zeek_
Built-In-Functions (BIFs), which can then be compiled and shipped
as part of a Zeek plugin.

A BIF allows one to write arbitrary C++ code and access it via a
function call inside a Zeek script.  In this way, they can also be
used to access parts of Zeek's internal C++ API that aren't already
exposed via their own BIFs.

At the moment, learning the format of a ``.bif`` file is likely easiest
by just taking a look at the ``.bif`` files inside the Zeek source-tree.