RPM/Rust: различия между версиями

Материал из ALT Linux Wiki
< RPM
(The Cargo Book)
Строка 62: Строка 62:
  find vendor/ \( -name '*.a' -o -name '*.lib' -o -name '*.dll' -o -name '*.obj' \) -delete
  find vendor/ \( -name '*.a' -o -name '*.lib' -o -name '*.dll' -o -name '*.obj' \) -delete
  sed -Ei 's!,"[^"]+\.(a|lib|dll|obj)":"[^"]+"!!g' $(find vendor -name .cargo-checksum.json)
  sed -Ei 's!,"[^"]+\.(a|lib|dll|obj)":"[^"]+"!!g' $(find vendor -name .cargo-checksum.json)
Такая чистка часто ломает <code>rustix</code>, что решается включением <code>use-libc</code> feature (например добавлением при сборке <code>export RUSTFLAGS="--cfg=rustix_use_libc"</code>) или включением <code>cc</code> feature — пример как это выглядит в <code>Cargo.toml</code>:
Такая чистка часто ломает <code>rustix</code>, что решается включением <code>use-libc</code> feature (например добавлением при сборке к rustflags <code>--cfg=rustix_use_libc</code>) или включением <code>cc</code> feature — пример как это выглядит в <code>Cargo.toml</code>:
  [dependencies]
  [dependencies]
  rustix = { features = ["cc"] }
  rustix = { features = ["cc"] }
Нужно учитывать, что использование переменой окружения <code>RUSTFLAGS</code> отменяет значение <code>build.rustflags</code> из созданного выше <code>.cargo</code>. Поэтому лучше добавлять новые опции в <code>.cargo</code>:
rustflags = ["-Copt-level=3", "-Cdebuginfo=1", "--cfg=rustix_use_libc"]


* Решение проблем с windows/unix кодировкой текстовых файлов:
* Решение проблем с windows/unix кодировкой текстовых файлов:

Версия от 11:41, 5 июня 2023

Как быстро сделать Rust пакет с вендорингом

Вендоринг — сохранение внешних зависимостей вместе с исходным пакетом (в отличии от помещения их в отдельные пакеты и использования BuildRequires). Как завендорить растовые зависимости (в дире с пакетом):

$ rm Cargo.lock
$ cargo vendor
$ find vendor -name '*.a' -delete
$ git add -A -f vendor Cargo.lock
$ git commit -m "cargo vendor"
  • cargo vendor - поместит все зависимости в диру vendor/, желательно, чтоб она была пустая.
  • find - удалит бинарные библиотеки из виндовых зависимостей (winapi*). Ниже есть более сложный пример.
  • git add -f - чтобы избежать возможных проблем с .gitignore.

В спеке:

BuildRequires: /proc
BuildRequires: rust-cargo
  • /proc необходим для работы cargo.

В секции %prep после %setup:

mkdir -p .cargo
cat >> .cargo/config <<EOF
[source.crates-io]
replace-with = "vendored-sources"

[source.vendored-sources]
directory = "vendor"

[term]
verbose = true
quiet = false

[install]
root = "%buildroot%_prefix"

[build]
rustflags = ["-Copt-level=3", "-Cdebuginfo=1"]

[profile.release]
strip = false
EOF
  • эта конструкция подключит вендореные исходники, настроит опции сборки и инсталляции.

В %build:

cargo build %_smp_mflags --offline --release

В %install (если пакет не библиотека, а бинарник):

cargo install %_smp_mflags --offline --no-track --path .

В %check, если нужен:

cargo test %_smp_mflags --release --no-fail-fast

Полезные советы

  • Более глубокая очистка от бинарных артефактов:
find vendor/ \( -name '*.a' -o -name '*.lib' -o -name '*.dll' -o -name '*.obj' \) -delete
sed -Ei 's!,"[^"]+\.(a|lib|dll|obj)":"[^"]+"!!g' $(find vendor -name .cargo-checksum.json)

Такая чистка часто ломает rustix, что решается включением use-libc feature (например добавлением при сборке к rustflags --cfg=rustix_use_libc) или включением cc feature — пример как это выглядит в Cargo.toml:

[dependencies]
rustix = { features = ["cc"] }

Нужно учитывать, что использование переменой окружения RUSTFLAGS отменяет значение build.rustflags из созданного выше .cargo. Поэтому лучше добавлять новые опции в .cargo:

rustflags = ["-Copt-level=3", "-Cdebuginfo=1", "--cfg=rustix_use_libc"]
  • Решение проблем с windows/unix кодировкой текстовых файлов:
grep -sq -w 'text' .gitattributes && echo '* -text' > vendor/.gitattributes
  • Часто cargo install начинает пересобирать исходники, поэтому лучше делать обычный install:
install -Dp target/release/%name -t %buildroot%_bindir

Ссылки