Мы используем 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
Updated @RulesRulesBot:
Bringing you some much requested features:
- It is now possible to get the last set rules or welcome text with /getgreeting and /getrules. That way you don't have to recreate all the HTML formatting, but can copy, paste and edit.
- It will delete old messages (greetings and rules) after more than 5 minutes. Not always exactly 5 minutes, as the cleanup job might not run every minute.
- If you grant admin rights to delete messages to the bot, it will also clean up any /rules and /greet command messages when deleting the sent message that.
#update#RulesRulesBot
Updated@RulesRulesBot:
Will now check for syntax error regarding variable usage when you set new rules or greeting text.
If you have an error there, it is most likely because you wanted to use "{" or "}" in your text. It will now tell you that you can use {{ or }} to display those.
Note that HTML errors where Telegram doesn't accept the message still can't be checked as the bot doesn't send the text immediately.
#update#RulesRulesBot
Updated @BanWarnBot, added {user_id}, {user_url} and {user_link} variables. This way you can link the user. This is also the new default replacing the bold text, in case you did't set any greeting.
#RulesRulesBot#update
New beta feature for @RulesRulesBot:
Read-the-Rules Highscores.
When enabled with /enable_highscores@RulesRulesBot,
the bot will send a game message to your chat which allows the bot to send highscores if somebody reads the rules, who hasn't before or hasn't after a change in the rules.
This might engage reading the rules more, and provide an overview for admins if joined users clicked the rules links.
If you don't like it, just send /disable_highscores@RulesRulesBot, and delete the game message.
Note, the game message is needed for telegram to notify about changed highscores. If the message got accidentially deleted, it can be recreated with /enable_highscore@RulesRulesBot command, which will also restore the scores.
Screenshot: https://t.me/luckydonaldsbots/146
#RulesRulesBot#beta#update
It was brought to attention that with some bots admin commands were no longer working.
That was happining for the bots migrated yesterday, because of the new bot API version.
This is #fixed now.
Thanks for letting me know, A. A.!
#BanWarnBot#RulesRulesBot#JoinCaptchaBot
I will soon migrage some services onto a new server.
Therefore those services will be unavailable for the next two hours:
@JoinCaptchaBot@BanWarnBot@RulesRulesBot and @ForwardWhitelistBot.
#downtime
#JoinCaptchaBot#BanWarnBot#RulesRulesBot#ForwardWhitelistBot
I will definitely work hard to keep the most important group management services stable, including:
@JoinCaptchaBot, @RulesRulesBot, @BanWarnBot, and @HeyAdminBot. And for now also the less important @NoServiceBot.
#PermalinkBot#NoServiceBot#RulesRulesBot, #BanWarnBot#HeyAdminBot
#ongoing#issue