Мы используем Makefile думая, что нет альтернатив, что это стандарт и всё такое.
Но make это не запускалка команд, а система сборки. Мы фактически используем его не по назначению.
И на самом деле альтернатива есть! Некоторое время назад я открыл для себя прекрасный инструмент - just. Он решает все проблемы make.
just - это не система сборки как make, это именно исполнитель команд!
Больше никаких Phony Targets и табуляций, привет нормальный синтаксис и передача аргументов!!! 😎
⭐️Что умеет just:
✅ Автодокументирование команд
Не нужно делать отдельную команду с докой, просто добавь комментарий
# команда сборки
build:
...
$ just --list
Available recipes:
build # команда сборки
Команда с именем default запускается по умолчанию если не указано другое, так что я обычно делаю так:
default:
just --list
Теперь просто выполняем just и получаем доку из текущего файла.
✅ Удобная работа с переменными окружения
# загрузить из .env
set dotenv-load
# глобальная переменная
export PYTHONPATH := "./src"
# переменная для команды
test $TESTUNG="true":
pytest
✅ Передача аргументов
build target:
@echo 'Build {{target}}...'
команда запуска
$ just build dev
# Build dev...
✅ Выбор интерпретатора прямо в команде
Пример с инлайн-скриптом на python:
system:
#!/usr/bin/env python3
import platform
print(platform.system())
Эта же функция позволит выполнить скрипт как одну команду вместо перезапуска шела для каждой строки
foo:
#!/usr/bin/env sh
for file in ls .; do
echo $file
done
✅ Выполнение команды в определенной директории. Можно указать как релятивный путь так и абсолютный
[working-directory: 'backend']
build:
docker compose build
Также можно задать рабочую директорию глобально
Там еще много интересного:
- поддержка функций
- автокомплиты и интеграции
- экспрешены
- алиасы команд
- группировка команд
- альтернативы команды под разные ОС
- импорт других just-файлов
- цветной вывод
- ... и другие штуковины!
Так что вперёд - ➡️ читать доку!
Репозиторий: ➡️https://github.com/casey/just
Статья: ➡️https://www.chicks.net/reference/file_formats/just/
ЗЫ. Кажется, на Makefile я уже не вернусь)
#tools
• На хабре есть хорошая статья, где автор рассказывает про семь инструментов для сканирования уязвимостей, которыми сам регулярно пользуется. Каждый из сканеров хорош по-своему: кто-то вылавливает баги в Python-коде, а кто-то проверяет контейнеры, кто-то смотрит на лучшие практики в написании кода. Мы разберем, как эти инструменты установить, настроить и использовать.
• Нужно отметить, что выбор подходящего сканера или комбинации инструментов зависит от специфики вашего проекта, требований к безопасности и возможностей интеграции.
➡️https://habr.com/ru/articles/910840/
• В качестве дополнительного материала рекомендую обратить внимание на проект Scanners Box (scanbox), где опубликована подборка различных сканеров, который включает в себя более 10 различных категорий: от стандартных сканеров для Red Team и Blue Team специалистов, до сканеров анализа кода в мобильных приложениях:
➡https://github.com/We5ter/Scanners-Box
#ИБ#Пентест#Tools
⚔️FOMO Fighters Player Database is Live!
Looking for opponents for PvP battles in 🔥Fomo Fighters ?
Now it's easier than ever.
I’ve created ⚡Fomo Tools — a app that collects the entire player database in one place so you can quickly search and find fighters.
⚔️What you can do:
🟢Find any player instantly
🟢Search fighters for PvP battles
🟢Explore the growing Fomo Fighters community
No more endless scrolling or guessing usernames — just search and battle ⚔️
Try it here:
📣 @FomoTools
If you enjoy the tool, feel free to share it with other fighters and make the PvP scene even more active!
#fomo#fighters#FomoFighters#PvP#tools
erofs-utils
跨平台 erofs 镜像工具
支持多线程提取,包含 fs_config、files_context 信息。
GitHub:
https://github.com/sekaiacg/erofs-utils
完成传参:
extract.erofs --help
usage: [options]
-h, --help Display this help and exit
-i, --image=[FILE] Image file
--offset=# skip # bytes at the beginning of IMAGE
-p Print all entrys
-P, --print=X Print the target of path X
-x Extract all items
-X, --extract=X Extract the target of path X
-c, --config=[FILE] Target of config
-r When using config, recurse directories
-s Silent mode, Don't show progress
-f, --overwrite [default: skip] overwrite files that already exist
-T# [1-X] Use # threads, default: -T0, is X/2
--only-cfg Only extract fs_config|file_contexts|fs_options
-o, --outdir=X Output dir
-V, --version Print the version info
#erofs_utils#tools