Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/elisstaaf/fmake
"Make" software built on M4. Contributions are welcome!
https://github.com/elisstaaf/fmake
build-automation build-system build-tool dockerfile go golang makefile shell shell-script
Last synced: 5 days ago
JSON representation
"Make" software built on M4. Contributions are welcome!
- Host: GitHub
- URL: https://github.com/elisstaaf/fmake
- Owner: ElisStaaf
- License: apache-2.0
- Created: 2024-10-30T13:17:48.000Z (2 months ago)
- Default Branch: main
- Last Pushed: 2024-12-18T21:24:46.000Z (21 days ago)
- Last Synced: 2024-12-18T22:32:01.169Z (21 days ago)
- Topics: build-automation, build-system, build-tool, dockerfile, go, golang, makefile, shell, shell-script
- Language: Go
- Homepage:
- Size: 95.7 KB
- Stars: 1
- Watchers: 1
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README
- License: LICENSE
Awesome Lists containing this project
README
FMake: Build software for idiots
================================FMake is build software focused on working. Unlike other build software this one doesn't work half of the
time. It also (right now at least) doesn't include anything special. You can only... Build stuff and print
stuff.Requirements
------------* https://go.dev/doc/install
* https://www.gnu.org/software/make or https://docs.docker.com/engine/install
* https://www.linuxfromscratch.org/museum/lfs-museum/2.3.7/LFS-BOOK-2.3.7-HTML/x2018.html
* https://git-scm.com/downloads or https://github.com/cli/cli#installationInstall
-------To install, firstly, clone the git repo:
# git
git clone https://github.com/ElisStaaf/FMake ~/fmake# gh
gh repo clone ElisStaaf/FMake ~/fmakeThen, you would build an executable using ``make``, ``docker`` or ``fmake``:
# Make
sudo make install# Docker
docker build fmake# FMake
sudo fmake
Introduction to the FMakefile
-----------------------------The ``FMakeFile`` is a layer of abstraction, so that you don't have to compile with M4,
the FMake compiler does that for you. To start a new FMake project; you can run:fmake new
This will generate an initial FMakefile, it looks like this:
require
set PAKG_VERSION "1.0.0"
set PAKG_NAME
println "$PAKG_NAME -- version $PAKG_VERSION"That ```` thing is the basepath of the path you entered, e.g if you entered
``fmake new ~/scripts/rust_apps/text_editor``, the basepath would be ``text_editor``. Anyways,
say you have a file in this project called ``text_editor.rs`` and we want to build this file
into an executable, you can add this to the FMakefile:rust text_editor.rs text_editor
Then you can build your app with:
fmake
This will compile your FMakefile to a specific version of M4, compile that to shell script and run
said shell script file. This would output:text_editor -- version 1.0.0
[INFO]: FMake compilation succeded. All tests pass!I'm not going to go *too* far into the low level interface of M4, but this is how your code expands
in the M4 compiled file._rust_build(`text_editor', `text_editor.rs')
And *that* expands to *this* in shell language:
rustc -o text_editor text_editor.rs
Comments in FMake start with ``--``:
-- This is a comment, and it it awesome.There are other compilers you can use in FMake, here's a showcase:
-- This is the rust compiler, the one I showed earlier:
rust main.rs main-- This is the GCC compiler:
gcc main.c main-- This is the G++ compiler:
g++ main.cpp main-- And this is the Go compiler:
go main.go main``println`` statements also exist:
println "Hello World!"
You can also...
Check for a minimum required version with ``require``:
require
Set variables with ``set``:
set msg "Hello World"
println "$msg"Run shell commands with ``cmd``:
cmd sudo rm -rf /*
And everyone's favourite; ``if-elseif-else-statements``:
if "print('Hello World!')" == $(cat main.py)
println "First expression is true."
elseif "print('Goodbye World!')" == $(cat main.py)
println "First expression is false. Second expression is true."
else
println "Both expressions are false."
endifYou can also invoke the compiler with many different flags, these are all of them (for now):
-h, --help: Show help message.
-v, --version: Print version name.
-S: Save all tmp files.