# `flowc` `flowc` is the "compiler and linker" for flows and flow libraries, although it is not very similar to what you might be familiar with as a compiler or linker. It is part of the overall `flow` project ([README.md](https://github.com/andrewdavidmackenzie/flow/README.md)). It loads flow definition files, and builds the flow hierarchy reading from referenced flows/functions and library references, and builds the flow in memory. Then it connects all functions via data flows through the hierarchy and removes most of the flow structure leaving a "network of functions" which it then optimizes (removing unused functions and connections). It checks that types match and required connections exist. It also checks for some illegal or cases that would prove problematic at runtime (specific types of "loops" or contention for a connection) Lastly it generates a manifest describing the flow, which can be executed by `flowr`. It then may (depending on the command line options used) invoke `flowr` (using cargo to ensure it is up to date and built). It is structured as a library with a thin CLI wrapper around it that offers command line arguments and then uses the library to compile and optionally run the compiled flow. # `flowrclib` This library contains most of the compilation and linking logic for `flowc`. ## features These are the conditionally compiled features of the `flowc` crate: - default - The "debugger" feature is enabled by default - debugger - feature to add the debugger