Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/madebylydia/Fabricius

A Python3 project scaffolder.
https://github.com/madebylydia/Fabricius

cookiecutter jinja2 mustache renderer template tools

Last synced: 5 days ago
JSON representation

A Python3 project scaffolder.

Awesome Lists containing this project

README

        

# Fabricius

Fabricius - A Python 3.10 Project Template engine with superpowers!

> :warning: Fabricius is a work in progress! Please, play with it with a grain of salt; expect bugs, crashes, non-documented portion of the application & more unexpected behavior.

Documentation:

> :warning: Fabricius still does not comes with it's CLI tool! It is a work in progress!

> [!CAUTION]
> As of 7 March 2024, this repository has been officially dropped and is **no longer supported**.
> The reasons are:
> - I do not want to deal with Python for my personnal projects.
> - I believe there's no real need for me to keep this project "as alive" when I do not plan to commit ever again.
>
> I feel truly sorry for the person I might disappoint here. I know a few peoples was following the project and had interest. I just don't feel like keeping up with Python and how unsupportive it feels toward my programming goals.
> I also feel disappointed toward myself as, that mean, I never could achieve the goal I was trying to reach for. But this feel like a necessity for me. Farewell, Python.
>
> As such, this repository will now be archived. I hope you understand this decision. If you'd like to, feel free to fork this repository, make changes, and enjoy it yourself.

## Goals

1. Create a working project from a project template
2. Create a fully working CLI using Rich
3. Ability to clone repository and use their templates
4. Create a secure tool (Do not allow unsecure scripts)
5. Create a fully type hinted tool

## Why the name of "Fabricius"?

I am an immense fan of roman names, and I very often name my project after a meaningful roman name.

"Fabricius" (In French, "Artisan") is translated to "craftsman", which is what Fabricius, the tool we create, aims to. His goal is to help at its best to create your projects easily.

## Why not just use CookieCutter or Copier instead of creating your own tool?

See goals, but other than that,

It's a question I am expecting with fears, I tried to first use CookieCutter myself but I never liked it at all, it always broke with me and was painful to use. On top of that, it does not comes with crucial things I would personally require, such as basic type checking when gathering user's input.
As for Copier, while it seems like a much more grown-up tool and *actually* fitting my need, I honestly did not try it, I just lost interested towards it and wanted to challenge myself in creating a new tool for the Python ecosystem.

On top of all of these, during my work in 2022, I ended up using TypeScript and using AdonisJS's CLI tool, and its awesome [template generator](https://docs.adonisjs.com/guides/ace-commandline#templates-generator), and so it made me really interested into creating a project scaffolder but using code, not a directory structure, which was lacking for both tools.

I wanted to create a complete and customizable experience of project scaffolding, I wanted to allow users to be free of do whatever they've meant to do, it's how I came up with the idea of plugins.

To me, Fabricius is more than just a simple project scaffolder, it's a complete handy swiss knife for their users. :)