Lavandula is a lightweight, fast, and intuitive C web framework designed for building modern web applications quickly. It focuses on simplicity, performance, and productivity, providing all the essentials without the bloat of heavier frameworks.
#include "lavandula.h"
appRoute(home, ctx) {
return ok("Hello, World", TEXT_PLAIN);
}
int main() {
App app = createApp();
get(&app, "/home", home);
runApp(&app);
}See /examples for more.
β οΈ Notice: Lavandula is still in early development and not ready for production use.
Expect frequent breaking changes and incomplete documentation.
- Controller and routing system
- HTTP endpoint support (GET, POST, etc)
- Controller local/global middleware pipeline
- Minimal dependencies (pure C)
- Quick project scaffolding via the CLI
- Built-in unit testing framework
- Environment variable support
- Built-in logging
- SQLite integration
- Built-in JSON library
- Static file serving
- Request validator library
- 'Hot Restart' mechanism
- CORS policy configuration
- Multithreading
- TLS
- PostgreSL, MySQL integrations, etc
- Rate Limiting
- Session cookies
To install Lavandula, follow these setps.
- Clone the repository
git clone https://github.com/ashtonjamesd/lavandula.git
cd lavandula- Run the install script
./install.shYou should see the following:
[SUCCESS] π Lavandula installation completed!
Quick Start:
lavu new my-project # Create a new project
cd my-project
lavu run # Run your project
Documentation:
GitHub: https://github.com/ashtonjamesd/lavandula- Finish
You should now be able to run the Lavu CLI tool and begin writing your application. Refer to this document for how to use Lavu.
- Create a new project
lavu new myProject
This will set up an application folder structure and copy the Lavandula /src directory into the created folder structure. This allows you to easily compile the framework and your app together.
Output:
Setting up Lavandula project 'myProject'...
-> Created myProject/lavandula.yml
...
π Lavandula project 'myProject' setup finished successfully!
Next steps:
1. cd myProject
2. lavu run
- Run
lavu run
Your application will run on http://localhost:3000/.
-
Read the docs
Contributions are welcome. Feel free to submit pull requests or open issues for feature requests or bugs.
Some places to start:
- Possible memory leaks
- Application security
- Outdated and unfinished documentation (API changes warrant a docs update)
Lavandula is registered under the MIT License.
