109 lines
3.5 KiB
Markdown
109 lines
3.5 KiB
Markdown
---
|
||
title: "indent из OpenBSD в Linux"
|
||
date: 2022-10-06T16:06:13+03:00
|
||
draft: false
|
||
tags: [c, linux, openbsd]
|
||
---
|
||
|
||
## О утилите
|
||
|
||
[indent.1](https://man.openbsd.org/indent.1) —
|
||
unix утилита для исправления отступов
|
||
и форматирования исходного кода программ на Си.
|
||
|
||
**Справочный материал:**
|
||
[OpenBSD manual page](https://man.openbsd.org/indent.1)
|
||
[Indent_(Unix) _Wikipedia_](https://en.wikipedia.org/wiki/Indent_(Unix))
|
||
|
||
Эта утилита своеобразный **code beautifier** для Си.
|
||
|
||
## GNU реализации
|
||
|
||
В Linux существует [GNU Indent](https://www.gnu.org/software/indent/manual/),
|
||
код доступен на серверах **savannah.gnu.org**:
|
||
|
||
```sh
|
||
git clone https://git.savannah.gnu.org/git/indent.git
|
||
```
|
||
|
||
Версия 2.2.12 вышла 18 апреля 2021 года.
|
||
|
||
Но ведь этоже GNU, бее.
|
||
|
||
## OpenBSD реализация
|
||
|
||
В OpenBSD есть своя версия. Издавно известно, что разработчики OpenBSD
|
||
_они пишут лучший C код в мире_ [[1](https://www.opennet.ru/openforum/vsluhforumID3/128533.html#57)].
|
||
|
||
Исходный код доступен по следующей ссылке:
|
||
|
||
```text
|
||
https://github.com/openbsd/src/tree/master/usr.bin/indent
|
||
```
|
||
|
||
Однако собрать его не получится, без некоторых изменений :)
|
||
|
||
## Код
|
||
|
||
Я клонировал исходный код на свой Git сервер и сделал изменений,
|
||
которые позволяют собрать библиотеку в Linux.
|
||
|
||
Коммит с изменениями доступен по
|
||
[этой ссылке](https://git.a2s.su/iiiypuk/indent/commit/a250dd83d47981cf6ed9a4382aae120a7fb24468).
|
||
|
||
Изменения коснулись следующих файлов:
|
||
|
||
* Makefile
|
||
* args.c
|
||
* indent.c
|
||
* lexi.c
|
||
|
||
В файле `Makefile` я закоментировал строку с инклудом параметром для сборки OpenBSD.
|
||
|
||
```text
|
||
.include <bsd.prog.mk>
|
||
```
|
||
|
||
В файле `indent.c` убрал механизм безопасности OpenBSD
|
||
[Pledge](https://man.openbsd.org/pledge.2).
|
||
|
||
Оригинальный код:
|
||
|
||
```c
|
||
if (pledge("stdio rpath wpath cpath", NULL) == -1)
|
||
err(1, "pledge");
|
||
```
|
||
|
||
Мои правки:
|
||
|
||
```text
|
||
#if defined(__linux__)
|
||
//
|
||
#else
|
||
if (pledge("stdio rpath wpath cpath", NULL) == -1)
|
||
err(1, "pledge");
|
||
#endif
|
||
```
|
||
|
||
В файлах `args.c` и `indent.c` я сколхозил, заменив OpenBSD специфичные функции
|
||
`errc` и `warnc` на функцию `printf`.
|
||
|
||
По хорошему нужно изучить работу функций, похоже что они возвращают ещё код ошибки,
|
||
но на текущий момент и так сойдёт.
|
||
|
||
В файле `lexi.c` заменил функцию `strlcpy` на `strncpy`:
|
||
|
||
```diff
|
||
- strlcpy(ps.procname, token, sizeof ps.procname);
|
||
+ strncpy(ps.procname, token, sizeof ps.procname);
|
||
```
|
||
|
||
Работют они конечно по разному, но ничего сломаться в штатной обстановке не должно.
|
||
|
||
## Итог
|
||
|
||
По факту код оказался полностью кросс-платформенным,
|
||
за исключением нескольных моментов.
|
||
|
||
Бинарных сборок нет, собирайте сами!
|