Rust #38 /rust/ 3452718 В конец треда | Веб
Добро пожаловать в тред, посвященный гарантиям, обещаниям, владению, заимствованию и другим концепциям языка Rust!
Предыдущий тред : >>3407697 (OP)

Rust — blazing fast язык для системного программирования без segfault'ов и с гарантиями потокобезопасности. Он позволяет писать безопасный и эффективный код, который легко поддерживать и масштабировать.

Ссылка на официальный сайт: https://www.rust-lang.org/

В этом треде мы объясняем базовые и продвинутые концепции языка, а также программирования в целом. Поможем новичкам, подскажем, что выбрать для веба, игр или, прости господи, блокчейна.

НОВИНКА: Rust для Windows: https://metanit.com/rust/windows/

IDE для Rust: https://areweideyet.com/
GUI для Rust: http://www.areweguiyet.com/
Web для Rust: https://www.arewewebyet.org/
Игры на Rust: https://arewegameyet.rs/
Что еще есть для Rust?
- Посмотри сам: https://wiki.mozilla.org/Areweyet

Основная литература:
Rust Book (версия на русском языке): https://doc.rust-lang.ru/book/
Rust Book: https://doc.rust-lang.org/book/
Rustlings (упражнения для привыкания к Rust): https://github.com/rust-lang/rustlings
Rust by Example: https://doc.rust-lang.org/rust-by-example/
The Rustonomicon (для продвинутых): https://doc.rust-lang.org/nomicon/
Programming Rust: https://www.oreilly.com/library/view/programming-rust/9781491927274/
100 упражнений по Rust: https://rust-exercises.com/100-exercises/

Ресурсы на русском:
https://rust-lang.ru/
Отдельное спасибо автору этого гитхаба (старому ОПу). Здесь ты сможешь найти много полезной информации: https://gist.github.com/TatriX/183c816f1346d418f969c4576c2b9b41
2 3453318
ГАЙЗ, А ГДЕ РАСТ?
https://github.com/mozilla-firefox/firefox
Мне волнительно...
3 3453322
>>53318
Эм, ребят....
1681713559834.png26 Кб, 1044x220
4 3453336
>>53318
На нём servo и wgpu...
А писать браузер на расте, ну камон, гайз.
image98 Кб, 900x900
5 3453388
Растишки. Хочу вкатиться к бэкенд. Нужно для себя, а не для работы по найму (я так понимаю, что в этом смысле в РФ не разгуляешься).
Рассматривал разные варианты: PHP, Node.js, Go, Rust (Java и Kotlin не рассматриваю, очень не зашли).

У раста выявил только два минуса для себя:
- кривая обучения очень уж крутая (чтобы что-то начать делать в бэке нормально нужно месяцев 12)
- долгая разработка в сравнении в другими языками (то, что я сделаю на других языках за 1-2 дня, на расте буду делать неделю или две)

В других языках нашел минусов намного больше. Меньше всего в Go, но он не заточен на сложную бизнес-логику, сделать-то можно конечно, но на костылях и с тяжелой поддержкой в дальнейшем. А мой проект содержит сложную бизнес-логику: бухучет, оперативный учет и т.п. (я сам бухгалтер), которую я планирую годами расширять и совершенствовать. И это будет именно веб-проект со всеми вытекающими (будет даже telegram mini app).

Но экспертных материалов по практическому применению Rust в бэкенде я не смог найти. Как-то все в общих чертах, обзорно, толком полную картину не составишь. Это как в статьях про Python - да он может всё, очень гибкий, можно и в бэк и в ml и в гуй тоже может. А на деле - очень медлительный и очень прикладной, но хорошо для DS и ML (клей для Си в основном).

В концепциях программирования я не профессионал, но умею в VBA, Python и 1С в рамках своих компетенций по профессии). А также немного в CSS, HTML и JS.

Дайте пожалуйста вашу экспертную оценку. Если будет время, напишите пожалуйста развернутый ответ.
6 3453403
>>53388
deepseek, qwen
7 3453410
image700 Кб, 1490x1600
8 3453411
>>53403
От нейродебилов не получилось взять релевантную информацию. Они и про Пиструн мне говорят: О да, это отличный вопрос. Python может решить все ваши проблемы. Огромное сообщество, дохулирд фреймворков...
9 3453423
>>53411
Так ты знаешь питон, начинай писать на питоне. А не спрашивай дикпики о выборе языка. И еще думай как сделать так чтобы можно было как можно больше делигировать в будущем, наемным макакам, а не самому писать все.
10 3453447
>>53423
Извини, бро, но неужели ты думаешь, что я не рассматривал этот вариант? Питон не отвечает моим требованиям по производительности. Нужно что-то пошустрее. Хотя бы уровня Node. Но это опять компромиссы. Уже 2 недели в ступоре хожу, читаю, смотрю, слушаю, но так не могу найти консенсус.
11 3453462
>>53447
Чел. Ты хотя бы мвп запили для начала. А уж потом думай о производительности для своего круда. 100% ты не сможешь одновременно учить все и пилить что-то рабочее. Ты в расте только начнешь изучать лайвтаймы с боровчекером и уже забудешь о своей главной цели из-за когнитивного перегруза.
12 3453566
>>53388

>У раста выявил только два минуса для себя:


Я тебе добавлю третий минус от себя - время компиляции. Попробуй хоть раз скомпилировать ну какой-нибудь скажем форум целиком сделанный на расте и ты охуеешь. А то что ты сказал... Нуууу для меня это не является минусами - 1) "кривая обучения очень уж крутая" - хорошо, меньше всяких тупых детей, рукожопов и случайных людей будет. 2) "долгая разработка в сравнении в другими языками" - мне лично похуй, за меня 70% кода нейронка пишет.

>экспертных материалов по практическому применению Rust в бэкенде я не смог найти


Хуёво искал. Заходишь на amazon.com, в поиск вбиваешь слово "rust", категория "books" и там будет писят тыщь этих книг.

>Меньше всего в Go, но он не заточен на сложную бизнес-логику


Скорее проблема в тебе, а не в go. Это ты не заточен на сложную бизнес-логику.
13 3453616
>>53388
Никто не пишет на срасте бек для веба потому что слишком много времени занимает, ты вместо алгоритмов пишешь бойлерпринт и сражаешься с языком. Сервер игры - частично, может быть, чаты - неплохо, почему бы и нет, трансляции поедания кала - вполне рабочая тема.

Бек для веба пишут на ноде, либо жаба если это тырпрайз, всё потому что эти языки позволяют хуякс-хуякс и в продакшн, есть куча встроенных в языки плюшек. А нода/бан/deno ещё и производительные дохуя.

Если хочешь писать бек на компилируемом языке, то во-первых используй zig (этот тред реклама zig на самом деле) потому что бойлерпринта меньше, во-вторых тебе придётся писать ебейшую кучу собственных велосипедов, и я что-то нихуя не уверен что это имеет смысл. Для твоей бизнес-логики придётся самому писать конечные автоматы, сигналы и эвенты, и всё это с аллокацией и структурами данных на массивах. Будешь не только бухгалтером, но и системным архитектором, лолд, готов?
14 3453628
>>53616

>Никто не пишет на срасте бек


ВНИМАНИЕ, ВСЕМ СРОЧНО ПЕРЕСТАТЬ ПИСАТЬ БЭК, АНОН НА ДВАЧЕ СКАЗАЛ ЧТО НА НЕМ НИКТО НЕ ПИШЕТ
ВСМЫСЛЕ УЖЕ НАПИСАЛИ ВСЁ!?!?! УДАЛЯЙТЕ!
15 3453634
>>53628
Ну и что ты там написал, шиз? Покажешь или как всегда?
16 3453637
>>53634
на основе этого свою борду запустил https://github.com/bakape/shamichan
17 3453642
>>53637

> борда


Это хуйня которая занимает 200 строчек в JS для всего сервера и 200 строчек для клиента? Пиздец мощно. Что-то ещё будет?
18 3453644
>>53642
ну напиши за 200 строчек, ну или покажи борду что за 200 строчек написана
19 3453652
>>53644
Блядь, да что угодно https://github.com/jennypeng/ImageBoard Первое что попалось. Тут строчек 300, наверное, основная часть это счётчики, лол, которые можно написать не так уебищно. Думая основная работа с БД, роутами и АПИ для борды занимает строчек 100, не больше.

В пидорасте бойлерпринта просто дохуя. Слишком дохуя для адекватного написания бека.
20 3453661
>>53652

> https://github.com/jennypeng/ImageBoard


ахахахаа там буквально 1 форма + просмотр

> Первое что попалось


тебе реально при поиске движков борды всё что выдало древнее говно уровня лабы 12 летней давности?
попробуй получше поискать, что то реально похожее на борду

> Думая основная работа с БД, роутами и АПИ для борды занимает строчек 100, не больше.


ну если дальше уровня лабы не уходить то да
21 3453686
>>53661

> ахахахаа там буквально 1 форма + просмотр


Погоди, что не так? В борде только это и есть. Треды и доски реализуются ещё двумя функциями.

> тебе реально при поиске движков борды всё что выдало древнее говно уровня лабы 12 летней давности?


Да, гугл в наши дни нихуя не ищет.

> ну если дальше уровня лабы не уходить то да


Чел, это борда. Тут нет ничего сложного. Прямо совсем ничего. На расте это сложно только из-за того что язык говно.
22 3453690
>>53644
Однажды в качестве proof of concept написал вики-движок на пыхе примерно в 150 строк. Правда, с безопасностью там было всё плохо.
23 3453693
>>53686

>Погоди, что не так? В борде только это и есть.


блять чел, ну ты глянь хотя бы как борда на которой ты сейчас находишься выглядит и что делает кроме того что просто тебе показывает треды

>Да, гугл в наши дни нихуя не ищет.


предлагаешь мне вместо тебя гуглить? точно сам не справишься?

>Тут нет ничего сложного


кто тут про сложность говорит?
легко != 10 строчек кода, тут есть еще функционал кроме того чтобы тебе хтмл показать + формочку сделать
24 3453719
>>53693

> блять чел, ну ты глянь хотя бы как борда на которой ты сейчас находишься выглядит и что делает кроме того что просто тебе показывает треды


Так расскажи мне что она такого делает, кроме подсчёта статистики и полутра вызовов апи. Ты точно писал борду? Сколько запросов апи у тебя было?

> предлагаешь мне вместо тебя гуглить? точно сам не справишься?


Да, мне поебать на это дерьмо.

> кто тут про сложность говорит?


> легко != 10 строчек кода,


Если ты пишешь на нормальном языке для бекенда - сложность прямо пропорциональна количеству строк кода. В случае сраста это конечно не так, но это проблема языка.

> тут есть еще функционал кроме того чтобы тебе хтмл показать + формочку сделать


Это борда. Всё что борда делает - сохраняет и отправляет стринги. Доски, топ тредов и прочая хуйня решаются ещё одной строчкой которая добавляет посты в кэш/бд. Самая сложная часть харчка - это капча.
image.png11 Кб, 375x199
25 3453750
>>53719

>Так расскажи мне что она такого делает, кроме подсчёта статистики и полутра вызовов апи.


модерация + админка
медия
(в моем случае) реал тайм постинг
базовая безопасность (чтобы не завайпали гомонеграми)
настройка борды
избранное \ скрытие

>сложность прямо пропорциональна количеству строк кода


во дибил

>Да, мне поебать на это дерьмо.


ну так а о чем с тобой говорить?

> борда это супер просто 20 строчек кода


> хоть один движок видел\писал?


> пук среньк, всё просто строчка бд апи формочка


> ты хоть понимаешь функционал борды


> пук среньк, строчка капча

26 3453786
>>53750

> модерация + админка


Ого, много. Поздравляю, твой апи расширился на один запрос. Вместо пяти стало шесть. Если ты создаёшь команду чмодератеров, то будет семь. Семь апи точек, бля, много...

> медия


Что медия? Стрим файла это функция на 20 строчек. С буферами работает. Конечно, в пидорасте это будет минимум 1к строк отборного говнокода, но что поделать...

> в моем случае) реал тайм постинг


Постинг и так всегда реалтайм. Тут всё наоборот, чтобы делать постинг батчами нужно больше кода, да и нахуй это не нужно особо.

> базовая безопасность (чтобы не завайпали гомонеграми)


Две строчки кода при использовании кук, четыре строчки кода при использовании токена. Много....

> во дибил


Речь идёт про нормальный язык бекенда, а не про раст.

> ну так а о чем с тобой говорить?


Можешь ещё повизжать о том как сложно тебе было писать борду на срасте.

> > пук среньк,


Сколько вызовов апи было на твоей борде? Напиши мне это, не стесняйся.
27 3453804
>>53786
ну уже слишком жирно
LVipHvjfSLg.jpg113 Кб, 660x740
28 3454544
>>53642

>Это хуйня которая занимает 200 строчек в JS для всего сервера и 200 строчек для клиента? Пиздец мощно. Что-то ещё будет?


У меня есть проекты на расте. Я пишу бекенд. Что ты хотел-то?
Вот описание проекта ---> https://pastebin.com/raw/RxjYq1iW
Вот пример кода ---> https://pastebin.com/raw/JBerjWZj
Там около ~130 тысяч строк лютого пиздеца на расте, не считая typescript и фронта.

мимо-другой-анон
29 3454549
>>53616

>ты вместо алгоритмов пишешь бойлерпринт


Смотри... у тебя есть вот такой контент https://pastebin.com/raw/zLD4WLCr Сможешь его декодировать в бинарный файл? Я тебе даже решение на расте могу подсказать https://pastebin.com/raw/Wt90DY9p
30 3454551
>>54544

> Вот пример кода


На какой нейронке генерил?
31 3454649
>>53388

>кривая обучения очень уж крутая (чтобы что-то начать делать в бэке нормально нужно месяцев 12)


С растом ты будешь каждый день своей жизни учиться, потому что две трети любого кода на расте — это объявления новых вспомогательных типов для ублажения компилятора, и соответственно, работающие с тобой люди будут непрерывно писать новые и новые вспомогательные конструкции под свою логику.
Помню, я охуел, когда увидел, насколько сложно. Safe реализация двусвязанного списка на Rust настолько нереальна, что они по итогу сплошной unsafe ебанули в std.

>Меньше всего в Go, но он не заточен на сложную бизнес-логику, сделать-то можно конечно, но на костылях и с тяжелой поддержкой в дальнейшем


В чом тяжесть поддержки? Пиши на Elixir, лол.

>Это как в статьях про Python - да он может всё, очень гибкий, можно и в бэк и в ml и в гуй тоже может. А на деле - очень медлительный и очень прикладной, но хорошо для DS и ML (клей для Си в основном).


По-моему никто не скрывает, что питон еле ползает. Можешь попытаться у нейросетки поспрашивать вопросы, и подчёркивать ей, типа "я хочу не мейнстрим", "какие альтернативные взгляды на этот вопрос бывают?".
Гуй, кстати, очень грустный в питоне. Я не в последнюю очередь думал свою либу многозадачности под нужды гуя адаптировать, но там настолько всё плохо в питоне, что ну его нахуй. Питон — это реально bash, со всеми вытекающими и втекающими.
32 3454650
>>53411

>От нейродебилов не получилось взять релевантную информацию. Они и про Пиструн мне говорят: О да, это отличный вопрос. Python может решить все ваши проблемы. Огромное сообщество, дохулирд фреймворков...


Странно. Можешь показать пример промта, по которому нейросетка выдала тебе хуйню?
33 3454651
>>54544
>>54549
Нейровысеры не интересуют. Следующий раз приноси свой код, посмотрю что там у тебя.

>>54649

>две трети любого кода на расте — это объявления новых вспомогательных типов для ублажения компилятора


>Помню, я охуел, когда увидел, насколько сложно. Safe реализация двусвязанного списка на Rust настолько нереальна, что они по итогу сплошной unsafe ебанули в std.


База. А если это мультипоток будет? На этом пидорастёнок зависнет, потому что токены в GPT исчерпались.
34 3454652
>>54544

>Вот описание проекта ---> https://pastebin.com/raw/RxjYq1iW


>Вот пример кода ---> https://pastebin.com/raw/JBerjWZj


>Там около ~130 тысяч строк лютого пиздеца на расте, не считая typescript и фронта


Наркоман, это ты мне про AWS чесал в облачном тхреаде?
take.png59 Кб, 1065x291
35 3454758
Я вам немного раста принёс.
36 3454762
>>54544

>У меня есть проекты на расте. Я пишу бекенд


Тред про системный язык, пройдите нахуй.
37 3454819
Почему у зига такой ублюдский тулинг спустя 5 лет? Литералли хуже крестов. Вот я создал проект через zig init, он собирается, но при сборке мне пишет:

> error: invalid option: -Dcpu


> error: invalid option: -Dtarget


> error: invalid option: -Doptimize


Что это блять, в build.zig нет никаких аргументов и я не передаю ему?
А дальше под этим стектрейс build.zig, без ошибки. Что ты хочешь, сука?
Есть менеджер пакетов, но название пакета и название модуля разное, я должен идти в репу и смотреть в zig.mod как они назвали модуль. Потом ещё прописывать в build.zig сборку и импорт каждой зависимости. При этом мне пришлось смотреть видос на ютубе как правильно добавить её в build.zig, ведь документация к zon не гуглится. Ебануться.
И эти мудаки зачем-то переписывают LLVM на зиге, не осилив даже сделать нормальную сборку и документацию. Воистину красноглазые пердоли не умеют в юзерфрендли софт, только в пердольное говно.
А потом они ещё рассказывают как у них встроен clang в компилятор и его можно использовать как более удобную замену крестового компилятора. Более удобную чем что? Чем makefile как из нулевых? При этом они рассказывают про нативную поддержку сишки без ffi в зиге, но как мне например заинклюдить Windows.h под виндой? Я должен сам окружение настраивать руками? Виндобляди даже в нулевые про такую дикость не слышали.
38 3454844
>>54819

>Rust #38 /rust/


>Почему у зига



я ебу? это тред раста
39 3455279
Сегодня расту стукнуло 10 лет https://www.linux.org.ru/news/opensource/17968832/
40 3455343
>>55279
hateyoufeel это ты?
sage 41 3455412
>>55279
Назови своё имя, хохлодемон)
42 3455488
>>55343
Неа.

Кстати, какая IDE на расте в 2025 году считается наилучшей?
А то переписывание emacs на расте забросили https://github.com/remacs/remacs
43 3455632
>>55279
Умом Ржавый не понять,
И кол-вом строчек не измерить:
У него особенная стать —
В Раст можно только верить.
(Ф. Тютчев)

ПОЗДРАВЛЯЮ ВАС, РАСТОВЧАНЕ, С ДЕСЯТИЛЕТИЕМ ПОТРЯСАЮЩЕЙ РАСТ ПОБЕДЫ! ПУСТЬ ВАШ КОД БУДЕТ БЕЗОПАСНЫМ КАК НЕПРИСТУПНАЯ КРЕПОСТЬ, БЫСТРЫМ КАК ГОНОЧНЫЙ БАЛИД! ПУСТЬ ЗАВИСТНИКИ КРИЧАТ ПРО СВОЮ СЛАБОСТЬ И НИАСИЛ СИНТАКСИСА! СЛАВА РАСТУ! ПОБЕДЕ СЛАВА!
44 3455744
>>55632
Давно пора, ебена мать, умом растишку понимать!
45 3456720
не понимаю. Почему на обращения на получение элемента в векторе через &v[0] ругается, а на &v.get(0) нет
46 3456726
>>56720
Потому что раст сделали наглухо пизданутые чулочники. Функция get возвращает указатель на элемент массива. Просто получить элемент по индексу будет v[]
Вот так работает:
fn main() {
let mut v = vec![1,2,3,4,5];
let first = v[0];
v[0] = 42;
v.push(6);
println!("{first}");
println!("{v:#?}");
}
47 3456727
>>56720
У тебя println! закомментирован на втором пике.
party.jpg248 Кб, 1752x996
48 3456731
Live from the 10 Years of Rust celebration in Utrecht, Netherlands, the Rust team is happy to announce a new version of Rust, 1.87.0!
49 3456779
>>56726
чо несешь

>>56727
этот прав
image.png176 Кб, 313x305
50 3456790
>>56731
Какого пола?
51 3456807
>>56731
Лучше бы показали кто это говно спонсирует. А то такие довольные, явно баблищем их заваливают, и неспроста, явно не от полезности и прибыльности этого высера.
52 3456825
>>56790
Челик похож на мару бос.
53 3456840
>>56807
На официальном сайте внизу есть ссылки на спонсоров.
54 3456924
>>56825
Кто она по национальности? He? She? His? Hmm? Sheet?
55 3457066
>>56720
>>56726
fn main() {
let mut v = vec![1, 2, 3, 4, 5];
{
let first = &v[0];
println!("The first element is: {}", first);

}
v.push(6);
println!("The vector is: {:?}", v);
}

Причина подрыва?
image.png1,1 Мб, 1325x562
56 3457083
57 3457092
>>57083
Я знаю что растанам больно от реальности, но ЯП с безопасной памятью - это в первую очередь джава и шарп. Про раст никогда речи даже и не шло.
58 3457128
>>57092
ни один из них не системный, лучше бы го хотя бы привел
59 3457130
>>57128
На системных ЯП ничего кроме ОС не пишут. Все реальные задачи решаются безопасными языками с GC.
🤨.jpg58 Кб, 576x1024
60 3457136
>>57130

>На системных ЯП ничего кроме ОС не пишут


ты дурак?
61 3457137
>>57136
А зачем на них что-то другое писать? В вебе у джавы производительность выше раста.
62 3457139
>>57137

>В вебе


в браузерах я так понимаю тоже?
63 3457195
>>57137
Поэтому тот же дискорд на раст а не жаву переписывали?
64 3457217
>>57195
Для освоения выделенных деняк.
65 3457223
>>57217
Откуда у игрулькодаунов деньги?
66 3457332
>>57223
От инвесторов.
67 3457421
решаю задание из туториала. Норм?
Как комментарии принято оформлять?
68 3457711
>>53616
Чел весь финтех сидит на расте и пишет на нем свои микрописьки, альфа, сбер, тинек. Все вакансии открыты можешь сам убедиться в этом.

Впрочем то что это хуйня какая то я согласен. Даже не представляю сколько там у них ебли с этим, как будто проще было на плюсах даже кек
69 3457712
>>57136
Трахать
70 3457726
>>57711

> Чел весь финтех сидит на расте


Проснись.
71 3457831
>>57711
У альфы вижу только одну вакансию с растом. И там же рядом го, жава. У сбера тоже одна. У тинька ноль.
72 3457877
>>57831
Ну да, ну крч у них есть жесткие команды которые пишут на расте требовательное рпс. С улицы не залететь, но пишут же

>>57726
Ладно, согласен погорячился
73 3457891
>>57877
Ну крч ты начал фантазировать про пидорастные команды которых нет. Уверен они там пишут полтора микросервиса, связанные с либой на расте. А в бизнес-логику и БД их даже близко не пускают, даже на полшишечки.
74 3457898
>>57891
Ну ладно, да. Ты только угомонись дерьмое ебаное
75 3457907
>>57898
Не трясись ты так. Подумаешь обосрался прилюдно.
76 3457908
>>57891

> нет


Пидора ответ
77 3457910
>>57908
Шлюхи аргумент
78 3457911
>>57910

> ответ


> аргумент


Какой же ты пидор.
79 3457922
>>57908
Адаптеры крайней будет писать удобнее и ну мере конвертеры по.
80 3458149
>>55279
Языку всего десять лет, а его уже интегрируют в линукс и постепенно вытесняют плюсоговно (в предметной области максимально ригидной к изменениям). Для сравнения какому-нибудь пистону уже больше 30 лет, а выстрелил он только когда нейросетки начали разрабатывать.
81 3458364
кто нибудь собирал rust под mipsel?
на оф сайте нет версии выше 1.71.1
82 3458381
>>58149

>а его уже интегрируют в линукс


Что педики Пинусу Трольвальдосу скажут, то он и будет делать
83 3458386
>>58381
Кто-кто? Батя твой?
84 3458406
>>58149
а на си уже через год после выхода портировали весь юних, значит си в 10 раз пизже
85 3458473
>>58381
Почему плюсопедики за 40 лет не смогли навязать пинусу свою волю, а растофаги смогли?
86 3458474
>>58406
Все так. Для своего времени это был гигапрорыв.
87 3458483
>>58473
Линусу это пропихнули после курса таблеток и прочих нападок со стороны небазового сообщества.
88 3458551
>>58149
плюсы за столько лет к линуксу даже не подпустили
89 3458600
>>58551
Ну и прекрасно, Линукс это говноговна
90 3458817
>>58483
Все так. Лично Сорос и Блэкрок пропихнули.
91 3458976
>>58817
И лично выебали Пинуса в жопу
92 3459234
>>58483

>Линусу это пропихнули после курса таблеток и прочих нападок со стороны небазового сообщества.


Линус уже давно выполняет роль наёмного сотрудника, который будет делать то, что ему скажут, "love it or leave it". Ему просто напомнили об этом, когда он однажды выебнулся. Всем мейнтейнерам об этом аналогично напоминают. Никакой свободы в ядре линя уже давно нет, вся разработка лежит под корпорациями — свобода заключается в том, как эти хотелки корпораций ты будешь выполнять.

Есть объективные проблемы со включением Rust в ядре, например, тот факт, что изначально это был специализированный инструмент для написания браузера — взять те же Sync/Send, которые приколочены гвоздями к компилятору и очевидно являются узкоспециализированным инструментом, бесполезным в ядре, в котором не просто потоки и lock-free код, а есть прерывания, у которых особая культура кодинга.
Пришлось вычищать стандартную библиотеку от браузерного говна, и только после этого Rust подпустили к написанию драйверов. Я не верю, что раст когда-то пустят дальше, потому что дальше там просто сплошняком unsafe код, который лишает применение Rust смысла — всё ядро нужно будет переписывать под прихоти раста, как и вообще любая строчка кода требует усилий для ублажения компилятора, иначе компилятор её не примет.

>>58551

>плюсы за столько лет к линуксу даже не подпустили


Если от плюсов брать безопасное подмножество, то от них почти ничего не остаётся по итогу — в помойку отправляется 80% std и две трети спецификации C++. И даже после этого компиляторы C++ настолько ебливые, что их очень тяжело сделать совместимыми и безопасными, слишком уж это беспорядочное нагромождение фич и слоёв совместимости. Сука, C++ только несколько лет назад научилось линковать static поля в объявлении класса — это пиздец товарищи, как с яхзыком без поддержки интерфейсов типов работать? В языке есть hpp-реализация и cpp-реализация, но интерфейсов в C++ не существует, помимо сишных. А если ты всё равно пользуешься только сишными фичами, то зачем тебе C++?
92 3459234
>>58483

>Линусу это пропихнули после курса таблеток и прочих нападок со стороны небазового сообщества.


Линус уже давно выполняет роль наёмного сотрудника, который будет делать то, что ему скажут, "love it or leave it". Ему просто напомнили об этом, когда он однажды выебнулся. Всем мейнтейнерам об этом аналогично напоминают. Никакой свободы в ядре линя уже давно нет, вся разработка лежит под корпорациями — свобода заключается в том, как эти хотелки корпораций ты будешь выполнять.

Есть объективные проблемы со включением Rust в ядре, например, тот факт, что изначально это был специализированный инструмент для написания браузера — взять те же Sync/Send, которые приколочены гвоздями к компилятору и очевидно являются узкоспециализированным инструментом, бесполезным в ядре, в котором не просто потоки и lock-free код, а есть прерывания, у которых особая культура кодинга.
Пришлось вычищать стандартную библиотеку от браузерного говна, и только после этого Rust подпустили к написанию драйверов. Я не верю, что раст когда-то пустят дальше, потому что дальше там просто сплошняком unsafe код, который лишает применение Rust смысла — всё ядро нужно будет переписывать под прихоти раста, как и вообще любая строчка кода требует усилий для ублажения компилятора, иначе компилятор её не примет.

>>58551

>плюсы за столько лет к линуксу даже не подпустили


Если от плюсов брать безопасное подмножество, то от них почти ничего не остаётся по итогу — в помойку отправляется 80% std и две трети спецификации C++. И даже после этого компиляторы C++ настолько ебливые, что их очень тяжело сделать совместимыми и безопасными, слишком уж это беспорядочное нагромождение фич и слоёв совместимости. Сука, C++ только несколько лет назад научилось линковать static поля в объявлении класса — это пиздец товарищи, как с яхзыком без поддержки интерфейсов типов работать? В языке есть hpp-реализация и cpp-реализация, но интерфейсов в C++ не существует, помимо сишных. А если ты всё равно пользуешься только сишными фичами, то зачем тебе C++?
93 3459238
>>59234

>интерфейсов типов


нинужна
94 3459244
>>59234

> интерфейсов типов


> hpp-реализация и cpp-реализация


Шиз, зачем ты пишешь на си с классами и жалуешься на кресты? Это как писать на расте и жаловаться что ГОвно плохое. Модули уже давно в крестах работают стабильно, сишные хедеры больше не нужны. Что ты там про линковку выдумываешь вообще не понятно, экспорты работают как и должны.
95 3459263
>>59244

> Модули уже давно в крестах работают стабильно, сишные хедеры больше не нужны.


Давно? С 2024 стабильная поддержка в основным компиляторах — это "давно"? Ты какого года рождения? Для меня "давно" модулей C++ вообще не существовало даже в прототипах.
Так-то мне самому модули C++ тоже нравятся — за 35 лет пора бы уже.

Тем не менее, одних модулей недостаточно для решения проблема. Например, проблему непрозрачных и private объявлений типов модули не решают — это по прежнему можно описать только сишными типами. Исключения для ядерной разработки нужно вырезать из яызка — а хули в C++ остаётся без исключений и опирающегося на них RAII? Как я и писал — мало что остаётся.
96 3459265
>>59263

> проблему непрозрачных и private объявлений типов


Шизик, какие ты там проблемы нашёл? Для начала забудь про сишку и пиши на крестах.
97 3459278
>>59234

>сплошняком unsafe код, который лишает применение Rust


Я уже выше вам дэбилам говорил, что раст это не про безопастность, а про нескучный синтаксис, раст никакой безопасности не гарантирует, безопастность может гарантировать только человек, который пишет на язык_нейм и доказательства.
98 3459279
>>59244

>на си с классами и жалуешься на кресты


>си с классами


А если он не использует ооп-дерьмо, а пользуется тем, что в плюсах nullptr - это ключевое слово, а булы - это отдельные типы, это кресты или "си с классами"?
99 3459281
>>59279
Это ещё хуже - он просто притащил крестовый std в сишку и пишет на сишке.
100 3459292
>>59281

>крестовый std


Нахуя его использовать? Алсо, тех же рефов нет в си, а это пиздатая фича, использовать супер ограниченное подмножество плюсов вообще говоря годная идея. Так ты не ответил, что такое си с классами?
101 3459307
Эх ебёт же кто-то такую..
102 3459323
>>59307
Судя по серьге врядли. Интересно она кобла или ковырялка?
103 3459331
>>59307
И не таких ебут. Что поделать, по статистике на 9 кунчиков в мире 10 всратух.
104 3459340
>>59307
>>59323
>>59331
Вам не надоело обсуждать этого пидораса?
105 3459356
>>59340
Какой яп, такое и обсуждение.
106 3459453
>>59340
Но он пидераст фить ха
107 3460917
>>60897 (Del)

>Блять и чо? Я дрочу на трапов ииии?


Ты гей просто. Гомосексуал. Гомосексуалист, как раньше говорили.
108 3460931
>>60917
Нормисопроблемы
109 3461225
таки не могу понять, чем отличается &str от String.

"asdfaf" выдает &str, ссылку на строку. Кто при этом владеет строкой?
110 3461261
>>61225
По-твоему правомерно говорить о "владении" без соответствующей записи? По-моему, нихуя. Прямая цитата из учебника: "такая запись становится владельцем".
111 3461274

>в растотреде удалили пост с трапопикчей


Рустакеаны, вас это не задевает?
112 3461412
Нужно ли знать С++, чтобы писать на Rust?
113 3461686
>>61412
Зачем тебе писать на раст тогда. Зачем в принципе писать на раст, чтобы с языком сражаться?
8724be18-d947-474b-a0af-740ffb96d5dd.png2,6 Мб, 1024x1536
114 3461737
Главная истеричка треда
115 3461814
>>61737
сам то понял что сказать хотел?
почему он растоман когда пишет не писать на расте
116 3461909
Я вот не понимаю, вроде язык считается новопарадигменным, современным етц. НО сука вся та же сишная пердольксольная шляпа присутствует

fn, str, dyn, fs, Vec и прочее. Че больные что-ли?

Мы вроде не в девяностых где нужно было сэкономить пару килобайт текста, нахуя эти сокращения сраные нужны? Что полностью так впадлу слово написать? При чем не понятно по какому принципу сокращения, одна часть языка нормальная, другую решили отрезать. Какого хуя String полностью, а Vec уже сокращение?
117 3461910
>>61909
Vec - базовый тип. String - обертка.
118 3461911
>>61909
А то! Нет бы сразу написать AbstractProxyDecoratorBeanImpl
119 3462067
>>61910
Напиздела пидорастическая проститутка придорожная
120 3462093
>>61686
На расте есть сборщик карго, а не С++ ничего такого даже близко нет
121 3462112
>>62093

>На расте есть сборщик карго, а не С++ ничего такого даже близко нет


Уже отвечали — vcpkg есть для C++.
122 3462113
>>62093

>сборщик


Заказов?
123 3462114
>>62112

>vcpkg


уже отвечали, даже близко нет
124 3462116
>>62114

>уже отвечали, даже близко нет


Уже отвечали — близко да. Rust не умеет сам собираться на винде, просто для справки.
125 3462118
>>62116

> близко да


копиум

> сам собираться


сам то понял что сказал, затупок-студентик?
126 3462216
>>62118

>сам то понял что сказал, затупок-студентик?


Нет это ты, долбоебина, не смог решить задачи, которую решает chatgpt даже старой версии. Rust не умеет комплиировать сорцы в бинарники под win32 без установки стороннего ПО.
127 3462225
>>62216
я тебя услышал, студентик долбоёбик, напиши еще 10 постов где себя тупизднем выставляешь не понимающем нихуя в матчасти, а то думаю еще не всем понятно
128 3462243
>>62114
Поддерживаю, у раста хуже vcpkg. Где-то посередине между зигом в простынями скриптов сборки на зиге и простотой vcpkg.
129 3462248
>>62243
Ага. Когда хочешь версию либы запинить в vcpkg.json то нужно искать и прописывать хеш из репозитория vcpkg, когда эту версию запушили. Ничего более наркоманского Майкрософт придумать не смогла..
131 3462252
>>62093
Ты сборщиком пользуешься примерно пару раз один раз за весь проект.
132 3462259
>>62252

>проект


лаба

>>62243

>простотой vcpkg.


копиум
133 3462383
>>61412

>Нужно ли знать С++, чтобы писать на Rust?


Нужно ли знать итальянскую кухню, чтобы готовить русские блюда?
Нужно ли знать вьетнамский язык, чтобы говорить по-немецки?
Нужно ли уметь водить машину, чтобы научиться ездить на мотоцикле?

Такого же рода вопросы.
134 3462578
Собеседование на раст-девелопера:

1. Что такое турборыба
2. Какого цвета чулочки сейчас на вас
unnamed.webp7 Кб, 640x360
135 3462586
>>62578

>1. Что такое турборыба


Ну кстати это не шутки. Турборыба действительно используется, чтобы показать компилятору в какой тип приводить - ::<НекийТип>
136 3462621
>>62112

>vcpkg


А он умеет собирать проект по команде vcpkg build? Или прежде надо ручками написать CMake-душнину?
137 3462782
Реально ли взять книгу по алгоритмам и запрограммировать их на Rust без использования unsafe? Мне вот почему-то кажется, что любой алгоритм на графах просто невозможно реализовать из-за слишком жесткой системы владения. Естественно, мы рассматриваем реализацию через ссылки и динамическую память, а не статические матрицы, как делают некоторые студенты в своих лабах.
138 3462817
>>62782

>из-за слишком жесткой системы владения


Значит раст плохой инструмент для этой задачи. Проходите мимо.

>а не статические матрицы


>как делают некоторые студенты в своих лабах


Но повышается локальность данных. Алсо, если идти подобным путём, то получаем нулевую пользу от баран чекера.
Водкакнига.jpeg79 Кб, 700x933
139 3462818
Подскажите хорошую бумажную книгу по Rust?
140 3462819
>>61910

>Vec - базовый тип. String - обертка.



Про fn что скажешь? У меня это основная претензия сейчас

Мимо вкатун с C-образных языков

Вообще, нахуя синтаксис изобретали новый? Что это дало по факту?
141 3462837
>>62819

>Вообще, нахуя синтаксис изобретали новый? Что это дало по факту?


Ничего не дало, пидорасам захотелось сделать что-то ПРОГРЕССИВНОЕ просто так - это же пидорасы. Не потому что оно лучше, а потому что оно отличается от старого и типа нитакоекакфсе, понимаешь? В итоге ожидаемо получился кал, даже говноланг лучше выглядит.
142 3462844
>>62837

>пидорасам захотелось сделать что-то ПРОГРЕССИВНОЕ просто так - это же пидорасы


Те, кто долго жил среди пидарасов, говорят, что они втайне стыдятся своего греха и стараются поразить всякими фокусами. Думают про себя так: «Да, я пидарас. Так уж вышло – что теперь делать… Но может быть, я гениальный пидарас! Вдруг я напишу удивительную музыку! Разве посмеют плохо говорить о гениальном музыканте…» И поэтому все время стараются придумать новую музыку, чтобы не стыдно было и дальше харить друг друга в дупло. И если б делали тихо, в специальном обитом пробкой месте, то всем было бы так же безразлично, как и то, что долбятся в сраку. Но их музыку приходится слушать каждый день, ибо заводят ее повсеместно. И потому не слышим ни ветра, ни моря, ни шороха листьев, ни пения птиц. А только один и тот же пустой и мертвый звук, которым хотят удивить, запуская его в небо под разными углами. Бывает, правда, что у пидарасов ломается музыкальная установка. В такие минуты спеши слушать тишину.
143 3462881
>>62621

>А он умеет собирать проект по команде vcpkg build? Или прежде надо ручками написать CMake-душнину?


Cargo — это игрушка для написания hello world. Когда проект становится сложнее, то начинается:
https://github.com/ranger-finance/ostium-rust-sdk/blob/main/build.rs
https://github.com/rust-random/getrandom/blob/master/build.rs
https://github.com/rust-lang/libz-sys/blob/main/build.rs
https://github.com/dtolnay/proc-macro2/blob/master/build.rs
Я советую очень внимательно посмотреть на последний скрипт и осознать суть проблемы, которую я писал выше — вся "простота" опирается на единственный компилятор и тулчейн. Если компилятор-тулчейн не один, а если ещё и внешнее окружение может быть разное — всё, пиздец, приехали, расчехляй build.rs.

С другой стороны, действительно, включение одной либы на CMake выглядит больше:
option(ENABLE_FOO "Enable the Foo feature" ON)
if (ENABLE_FOO)
find_package(Foo REQUIRED)
target_link_libraries(myapp PRIVATE Foo::Foo)
endif()

Я для ответа попытался найти что-то масштаба SDL2, но ничего подобного для Rust просто нет. SDL2 я люблю потому, что у неё одни из самых ебливых зависимостей, потому что она сама абстрагирует особенности целевых платформ. Но ящик для Rust просто оборачивает SDL2 в FFI, полагаясь на уже произведённую CMake-ом конфигурацию при сборке SDL2.
Самая писечка:
https://github.com/Rust-SDL2/rust-sdl2/blob/master/Cargo.toml
[package.metadata.vcpkg]
dependencies = ["sdl2"]
Ой, шо за хуйня, Cargo не может собрать SDL2 на винде без vcpkg. Как же так?
Я напоминаю, что SDL2 — это каких-то сраных 150 тыс строк, это даже не GTK4, в котором уже порядка 600 тыс строк. Возьмите и перепишите SDl2 на расте! — А, не, не хотим, слишком сложно, хотим cargo build.

Ещё раз повторюсь: Cargo и Rust работают так классно, пока их используют в роли потешной дёргалки для внешних библиотек, пока им самим не нужно адаптироваться под окружение.
Питон тридцать лет назад прошёл по ТЕМ ЖЕ граблям, когда его система сборки считала, что на компьютере может быть единственный интерпретатор, единственный набор библиотек, и вообще, подходит любая платформа, если эта платформа — Unix.

Да, кстати, чуть не забыл, вообще-то в мире бывают ситуации, когда существует более одного репозитория, потому что на некоторых ЯП пишут что-то большее, чем hello world-ы, потому возникают патченные библиотеки, у которых своё версионирование — удачи применять pkgname >= 1.2.1 в таком случае. В данном случае я соглашусь с тем, что всё-таки дефолтное версионированние для центральной репы Cargo всё-таки проще, а сложные случаи такие же сложные, как и в vcpkg.
143 3462881
>>62621

>А он умеет собирать проект по команде vcpkg build? Или прежде надо ручками написать CMake-душнину?


Cargo — это игрушка для написания hello world. Когда проект становится сложнее, то начинается:
https://github.com/ranger-finance/ostium-rust-sdk/blob/main/build.rs
https://github.com/rust-random/getrandom/blob/master/build.rs
https://github.com/rust-lang/libz-sys/blob/main/build.rs
https://github.com/dtolnay/proc-macro2/blob/master/build.rs
Я советую очень внимательно посмотреть на последний скрипт и осознать суть проблемы, которую я писал выше — вся "простота" опирается на единственный компилятор и тулчейн. Если компилятор-тулчейн не один, а если ещё и внешнее окружение может быть разное — всё, пиздец, приехали, расчехляй build.rs.

С другой стороны, действительно, включение одной либы на CMake выглядит больше:
option(ENABLE_FOO "Enable the Foo feature" ON)
if (ENABLE_FOO)
find_package(Foo REQUIRED)
target_link_libraries(myapp PRIVATE Foo::Foo)
endif()

Я для ответа попытался найти что-то масштаба SDL2, но ничего подобного для Rust просто нет. SDL2 я люблю потому, что у неё одни из самых ебливых зависимостей, потому что она сама абстрагирует особенности целевых платформ. Но ящик для Rust просто оборачивает SDL2 в FFI, полагаясь на уже произведённую CMake-ом конфигурацию при сборке SDL2.
Самая писечка:
https://github.com/Rust-SDL2/rust-sdl2/blob/master/Cargo.toml
[package.metadata.vcpkg]
dependencies = ["sdl2"]
Ой, шо за хуйня, Cargo не может собрать SDL2 на винде без vcpkg. Как же так?
Я напоминаю, что SDL2 — это каких-то сраных 150 тыс строк, это даже не GTK4, в котором уже порядка 600 тыс строк. Возьмите и перепишите SDl2 на расте! — А, не, не хотим, слишком сложно, хотим cargo build.

Ещё раз повторюсь: Cargo и Rust работают так классно, пока их используют в роли потешной дёргалки для внешних библиотек, пока им самим не нужно адаптироваться под окружение.
Питон тридцать лет назад прошёл по ТЕМ ЖЕ граблям, когда его система сборки считала, что на компьютере может быть единственный интерпретатор, единственный набор библиотек, и вообще, подходит любая платформа, если эта платформа — Unix.

Да, кстати, чуть не забыл, вообще-то в мире бывают ситуации, когда существует более одного репозитория, потому что на некоторых ЯП пишут что-то большее, чем hello world-ы, потому возникают патченные библиотеки, у которых своё версионирование — удачи применять pkgname >= 1.2.1 в таком случае. В данном случае я соглашусь с тем, что всё-таки дефолтное версионированние для центральной репы Cargo всё-таки проще, а сложные случаи такие же сложные, как и в vcpkg.
144 3462891
>>62881
Если не заниматься линковкой архивов/шаред объектов, зачем вообще системы модулей/пакетов в целом, если можно дёргать репозиторий с исходниками?
145 3462894
>>62881
Ещё добавлю, build.rs/build.zig - це харашо, потому что это 1 система сборки на язык, а в сях их больше 1-й, ну там Autotools/Cmake/Meson, если что не спорю с утверждением "Cargo — это игрушка для написания hello world".

>Я советую очень внимательно посмотреть на последний скрипт


Килотонны сборочного кода это везде так, где не hello world надо собирать, тут да, просто не отделаешься, если надо писать, то придётся написать.
https://github.com/systemd/systemd/blob/main/meson.build
146 3462941
>>62891

>Если не заниматься линковкой архивов/шаред объектов, зачем вообще системы модулей/пакетов в целом, если можно дёргать репозиторий с исходниками?


Я напоминаю, что Cargo не в последнюю очередь был создан для того, чтобы побороть бесконечно медленную компиляцию в Rust. Без этой хуйни можно просто скачивать сорцы с гитхабов и класть в один каталог — зачем их как-то предварительно собирать, если они на одном языке и для одного тулчейна?
Тот же Delphi/Pascal, с которого я начинал и в котором я обожаю систему сборки, может вообще собирать огромный проект без единого прекомпилированного модуля. У меня так и было: полная сборка 6 млн строк библиотек из сорцов целых 5 минут собиралось на двухъяденой машине в хуй знает каком году — нейросетка мне подсказывает, что аналогичный объем кода на расте на той же машине будет собираться 3 часа. Инкрементальная сборка не делфи где-то 20 секунд была.

>3462894


>build.rs/build.zig - це харашо, потому что это 1 система сборки на язык, а в сях их больше 1-й, ну там Autotools/Cmake/Meson


Cargo НЕ решает целого ряда задач, для которых нужны Autotools/CMake/Meson. А именно — платформоспецифичная конфигурация зоопарка библиотек и инструментов на разных ЯП. Там, где нужно это сделать — Cargo дёргает тот же vcpkg (который дёргает cmake), как я показывал выше.

>Килотонны сборочного кода это везде так, где не hello world надо собирать, тут да, просто не отделаешься, если надо писать, то придётся написать.


Если взять скрип попроще:
https://github.com/DPDK/dpdk/blob/main/meson.build
где половину кода — это просто принты, то даже тут скрипт build.rs выглядит жирнее в два раза:
https://pastebin.com/jQzw8eYv
Нужно понимать, что DSL для CMake/Meson созданы не просто так, они решают задачу, которые неудобно решать ни башем, ни питоном, ни C/C++. Я сам имел честь делать проект на SCons, и я знатно наебался с этими вашими Тьюринг полными ЯП. Но разрабы Cargo посчитали, что они самые умные и им DSL не нужен.
По факту в Cargo просто повторили NPM со всеми его недостатками, а именно — хуёвой поддержкой сторонних средств сборки и распределённых источников сорцов (хорошо работают только если все пакеты есть в центральной репе). И лучшее, что может Cargo — это дёрнуть те же vcpkg+CMake.

Если же Rust начнёт претендовать на системный ЯП с собственным управлением внешними зависимостями, то тот же Meson внезапно напялят на Cargo, будете писать в дополнение к build.rs еще и meson.build, и рассказывать, что "лучше придумать было нельзя".
146 3462941
>>62891

>Если не заниматься линковкой архивов/шаред объектов, зачем вообще системы модулей/пакетов в целом, если можно дёргать репозиторий с исходниками?


Я напоминаю, что Cargo не в последнюю очередь был создан для того, чтобы побороть бесконечно медленную компиляцию в Rust. Без этой хуйни можно просто скачивать сорцы с гитхабов и класть в один каталог — зачем их как-то предварительно собирать, если они на одном языке и для одного тулчейна?
Тот же Delphi/Pascal, с которого я начинал и в котором я обожаю систему сборки, может вообще собирать огромный проект без единого прекомпилированного модуля. У меня так и было: полная сборка 6 млн строк библиотек из сорцов целых 5 минут собиралось на двухъяденой машине в хуй знает каком году — нейросетка мне подсказывает, что аналогичный объем кода на расте на той же машине будет собираться 3 часа. Инкрементальная сборка не делфи где-то 20 секунд была.

>3462894


>build.rs/build.zig - це харашо, потому что это 1 система сборки на язык, а в сях их больше 1-й, ну там Autotools/Cmake/Meson


Cargo НЕ решает целого ряда задач, для которых нужны Autotools/CMake/Meson. А именно — платформоспецифичная конфигурация зоопарка библиотек и инструментов на разных ЯП. Там, где нужно это сделать — Cargo дёргает тот же vcpkg (который дёргает cmake), как я показывал выше.

>Килотонны сборочного кода это везде так, где не hello world надо собирать, тут да, просто не отделаешься, если надо писать, то придётся написать.


Если взять скрип попроще:
https://github.com/DPDK/dpdk/blob/main/meson.build
где половину кода — это просто принты, то даже тут скрипт build.rs выглядит жирнее в два раза:
https://pastebin.com/jQzw8eYv
Нужно понимать, что DSL для CMake/Meson созданы не просто так, они решают задачу, которые неудобно решать ни башем, ни питоном, ни C/C++. Я сам имел честь делать проект на SCons, и я знатно наебался с этими вашими Тьюринг полными ЯП. Но разрабы Cargo посчитали, что они самые умные и им DSL не нужен.
По факту в Cargo просто повторили NPM со всеми его недостатками, а именно — хуёвой поддержкой сторонних средств сборки и распределённых источников сорцов (хорошо работают только если все пакеты есть в центральной репе). И лучшее, что может Cargo — это дёрнуть те же vcpkg+CMake.

Если же Rust начнёт претендовать на системный ЯП с собственным управлением внешними зависимостями, то тот же Meson внезапно напялят на Cargo, будете писать в дополнение к build.rs еще и meson.build, и рассказывать, что "лучше придумать было нельзя".
147 3462944
>>62819
Не знаю, по-моему всё красиво.

Мимо вкатун из ниоткуда
148 3462947
опять троллинг тупостью от постеров?

систему сборки от пакетного менеджера отличить не могут и понять кто что делать должен?
149 3462949
>>62947

>систему сборки от пакетного менеджера отличить не могут и понять кто что делать должен?


А где система сборки для Rust? Её нету.
150 3462989
>>52718 (OP)
Какие чулочки и анальные пробки вы используете при разработке?
151 3463004
>>62949
build.rs
152 3463139
>>62782
А какой смысл переизобретать велосипед, если есть https://crates.io/crates/petgraph ? Что тебе в петграфе не устраивает?
154 3463181
>>63154

> nanoservices


huh?
155 3463184
>>63181
У вас мегасервисы и гигасервисы? Понимаю..
157 3463278
>>63242

>A nanoservice has the ability to run as a microservice if needed. However, a nanoservice also has the ability to be compiled for use within another server.


Получается обычные микросервисы которые можно в один бинарь объединить?
Звучит прикольно конечно, оссобено если они в одном бинаре как то эффективно между собой общаться начнут, но хзы какую эту проблему решает
158 3463281
>>63278
Зумеры изобрели dll библиотеки.
159 3463312
>>63281

>dll


Спермоблядь, плиз.
160 3463407
Что там по вкату в айти с вашим чудо-языком?
Без названия.jpeg195 Кб, 1200x630
sage 161 3463413
>>63278

>Звучит прикольно конечно, оссобено если они в одном бинаре как то эффективно между собой общаться начнут, но хз какую эту проблему решает


Сам автор объяснял https://youtu.be/J94ARUzhhWI?t=924 что
был кубернетис кластер, но его сложно было тестировать на локалхосте, отслеживать http-запросы и т.д. Они тогда разделили проект на несколько воркспейсов и закатали их в один dockerfile. В итоге несколько наносервисов сидят в одном докерфайле и общаются по tcp через контракты. Получается строгая типизация, проще тестирование и нет запросов по сети.

Но не суть. Это что-то типа тоника https://docs.rs/tonic/latest/tonic/ но чуть более колхозная реализация. Мне ещё нравится курс "Rust, data engineering course". Но его можно только купить, на торрентах нет нигде.
1665175154326.png416 Кб, 2873x1489
162 3463414
>>63413

> на торрентах нет нигде

163 3463416
>>63407
Нулевой, вката нет. Можешь только на месте затащить в проекты, обладая достаточной экспертизой
sage 164 3463417
>>63414
Ах ты сука... ну ладно, был неправ, значит есть. А я за бабки его смотрел на oreilly. Но вообще я бы скачал всю серию https://www.coursera.org/specializations/rust-programming#courses Там неплохие такие курсы.
Каракал рычит шипит.mp410 Мб, mp4,
1080x1920, 0:14
165 3463554
>>63154

>>хорошую бумажную книгу



Мне нужна одна книга, а не 4. И она нужна на русском языке, я ебал в рот изучать новую область на неродном
166 3463588
>>63416

>Нулевой, вката нет. Можешь только на месте затащить в проекты, обладая достаточной экспертизой


Это показательно. Ещё раз повторяясь: писать код на Rust сложно, долго, и дорого. В том числе из-за пиздецки долгой компиляции. Да, нейросетки ускоряют процесс, но другие ЯП они ускоряют ещё сильнее. Итого что-то более-менее серьёзное на Rust представляет собой тупо дёргалку библиотек на C/C++ — о какой безопасности указателей мы тогда ведём речь?
167 3463602
>>63588
Скоро Пинус Трольвальдос свое говноподелие на Руст перепишет
168 3463611
>>63139

>https://crates.io/crates/petgraph/0.8.1/dependencies


Ебал в рот этот продукт нпмоподобный.

>графы


>алгоритмы


>хуилион зависимостей


Чёт я охуеваю.
169 3463625
>>63602

>Скоро Пинус Трольвальдос свое говноподелие на Руст перепишет


Очень нескоро. Им для драйверов пришлось std раста переделывать.

>>63611

>>https://crates.io/crates/petgraph/0.8.1/dependencies


>Ебал в рот этот продукт нпмоподобный.


>>графы


>>алгоритмы


>>хуилион зависимостей


>Чёт я охуеваю.


Ну так они автоматически разрешаются Cargo, чо ты паришься? Да, в C/C++ большая часть этих зависимостей была бы в самом проекте.
170 3463638
>>63611

> нпм


Ну до этого кала невозможно дотянуться, он задал слишком высокую планку. Я помню как-то пытался развернуть китайский кал на ноде, там 1500 зависимостей и npm где-то на 800 зависимости отъёбывает, жмёшь рестарт сборки, он доходит до 850 и опять отъёбывает, и так по 50 зависимостей, причём каждый запуск пересборки это 10 минут. Я так долго даже с крестами никогда не ебался, как с нодой. А ещё если TS есть в проекте, это вообще мрак.
>>63625

> они автоматически разрешаются Cargo


Проблема в том что время сборки улетает в космос, т.к. карга пересобирает часть зависимостей. У того же bevy каждая пересборка пересобирет 10 зависимостей из 350, в итоге поменял строчку, нажал сборку и ждёшь минуту-две в хеллоу-ворлде. Ещё и нет глобального кэша. Для примера опять тот же vcpkg можно привести, где есть нормальный глобальный кэш, зависимость собирается только один раз для всех проектов.
Алсо, почему так получилось что только на на крестах в msvc есть хот-релоад, а больше компилируемого ЯП с таким не существует? С задачей поменять строчку кода на горячую и сразу увидеть изменения справляется отлично.
171 3463642
>>63638
потому что нет abi а значит и нет .dll\.so
172 3463650
>>63554

>неродном


В ойти родной - это английский.
173 3463656
>>63625

>большая часть этих зависимостей была бы в самом проекте.


Что хорошо и правильно.
>>63650
Он толстит.
174 3463791
>>63638

>Алсо, почему так получилось что только на на крестах в msvc есть хот-релоад, а больше компилируемого ЯП с таким не существует?


Спорная фича в целом. Если мне нужно один раз изменить поведение логики, то я просто в отладчике меняю переменные. Уже на уровне оптимизации "-Og" код становится настолько хуй пойми каким, что вообще теоретическая возможность его горячей подмены становится сомнительной — слишком много вещей потенциально может поменять одна строчка кода.
Во всяких там JVM/CLR/V8 есть заранее заложенные алгоритмы JIT-оптимизации-деоптимизации, благодаря которым можно нужную функцию деоптимизировать и подменить, но в AoT компиляции такой возможности нет.

В Паскале эта проблема решалась мгновенной перекомпиляцией — я щитаю, что это намного более радикальное решение проблемы, чем горячая подмена. Я не верю в хуету плана "у меня упала БД, но мне нельзя её перезапускать, я к ней подключился отладчиком, сейчас ручками восстановлю правильный ход алгоритма, и продолжу работу БД" — это просто фантазия из какой-то методички, никакой продакшен так не работает.

Вот интерактивный REPL уже есть в отладчиках-компиляторах:
https://clang.llvm.org/docs/ClangRepl.html
Чо вам ещо надо?
175 3463839
>>63791

> Если мне нужно один раз изменить поведение логики, то я просто в отладчике меняю переменные.


Хот-релоад тупа быстрее, если большой проект. Отладчик слишком ограниченный контроль имеет, хот-релоад же любой код может пропатчить налету.

> вообще теоретическая возможность его горячей подмены становится сомнительной — слишком много вещей потенциально может поменять одна строчка кода


В msvc хот-релоад работает с О2, главное чтобы LTO выключено было.
176 3463910
>>63839

>хот-релоад же любой код может пропатчить налету


И нахуя? Откуда ты знаешь, что старый код не наделал сайдэффектов?

>В msvc хот-релоад работает с О2, главное чтобы LTO выключено было.


Мне нейросетка говорит, что с /O2 не работает. Уже сделали поддержку?
177 3463912
>>63910

>И нахуя?


чтобы не перезапускать сборку после изменения пары строчек, ускоряет дебаг в разы
хзы как там в вебе это у вас, в геймдеве это мастхев

мимо пробегал
178 3463933
>>63910

> Откуда ты знаешь


А ты откуда знаешь как код вообще работает? Это же читать надо, сложно.

> Мне нейросетка говорит


А бабки у подъезда что по этому поводу говорят?

> Уже сделали поддержку?


Всегда работало. Компилятору похуй на оптимизации, из дебаг-информации он знает всё. Дебаггер же без проблем работает с оптимизированным кодом в релизном билде, даже с LTO.
179 3463951
>>63933

>А бабки у подъезда что по этому поводу говорят?


Офф доки говорят то же:
https://learn.microsoft.com/en-us/visualstudio/debugger/supported-code-changes-cpp?view=vs-2022
"Unsupported scenarios
Debugging native apps compiled with /Zo (Enhance Optimized Debugging)...
Debugging optimized code.
"

>Компилятору похуй на оптимизации, из дебаг-информации он знает всё. Дебаггер же без проблем работает с оптимизированным кодом в релизном билде, даже с LTO.


Разговор шел не про отладчик, а про Hot Reload — это совершенно разные функции. Похоже, что ты долбоеб, который тупее нейросетки.

>>63912

>чтобы не перезапускать сборку после изменения пары строчек, ускоряет дебаг в разы


>хзы как там в вебе это у вас, в геймдеве это мастхев


В геймдеве тесты обычно ведутся на минимальном уровне оптимизации, потому что без оптимизации игра бегает недопустимо медленно. А с оптимизацией Hot Reload не работает.
В остальном я согласен с тем, что стар игры может очень долго происходить. Возможно, стоит придумать что-то для ускорения старта игры. рукописный Hot Reload через DLL делался и без хитрых компиляторов — в таком видео его возможно выполнить даже с оптимизированным кодом.
180 3463957
>>63951

> А с оптимизацией Hot Reload не работает


работает

> Hot Reload через DLL


а ой, я про него и говорил (думал дебаггер также это и делает)
в расте кстати вобще возможно такое запилить?
1643799335451.png27 Кб, 932x204
181 3463959
>>63951

> Офф доки говорят то же


Так я тебе написал с какими оптимизациями он не работает. Мог бы уже сам проверить давно.

> это совершенно разные функции


Это ты даун. Хот-релоад в msvc делает дебаггер. Для этого надо включить дебаг-информацию для него.
182 3463961
почему println! работает без use? Я тут https://doc.rust-lang.org/stable/std/prelude/index.html не нашел его
183 3463962
Почему в расте присваиваение зовётся биндом, а не ассайментом? В хаскеле понятно, что бинд это бинд, а расте то почему?
image.png38 Кб, 839x135
185 3464010
Уже в какой лекции вижу. Почему у нас есть мутабельная ссылка на константу?
186 3464022
>>64010

> Почему


temporary lifetime extension

> Зачем


чтобы не возникало проблем в коде по типу r = &Class:new();

> константу


создается новая переменная, константа не изменяется
187 3464027
>>64022

> создается новая переменная, константа не изменяется


Разве не смысл ссылки в том, что она ссылается на существующий объект? Я сравниваю с плюсами, так там такое бы просто не скомпилировалось без const, что логично
188 3464028
>>64027

>на существующий объект?


он и существует, я же написал тебе переменную под капотом новую создают
189 3464030
>>64028
а, понял. только не перменная, а объект новый создался. это не rvalue из плюсов, а больше как если бы сделали новый объект инта от параметра 92. спасибо
190 3464051
Блиц, нахуй.

fn main() {
let mut r = &mut 2;
r += 1;
println!("{}", r);
r = &mut 3;
r += 1;
println!("{}", r);
}

Такой код не сработает. Почему?
191 3464052
>>64051
на пастбин залей
192 3464064
>>64052
Зачем?
193 3464067
Единственное, что хочу сказать - >>64051 и >>64064
не мой пост. Говорю, чтобы мне потом отвечали на вопросы, а не приняли за долбоёба
194 3464073
>>63962

>Почему в расте присваиваение зовётся биндом, а не ассайментом? В хаскеле понятно, что бинд это бинд, а расте то почему?


Самое смешное то, что в BPCL/CPL был бинд и для присваивания не использовался символ тождества, но два индуса, керниган и ритчи, нахуевертили нам фортрана, и с тех пор тождеством во многих ЯП обозначают присваивание. То есть, рандомная хуйня становится Industry Standard и Best Practice.

>>64027

>Я сравниваю с плюсами, так там такое бы просто не скомпилировалось без const, что логично


"Const" в C++ — это одна из самых ублюдочных бездарных фичей высранных за историю IT. Вот насколько нужно быть ебанатом, чтобы обозначать переменную ключевым словом "const"? Потому логично, что в новом языке неконец-то сделали адекватные константы.
195 3464074
>>63959

>Это ты даун. Хот-релоад в msvc делает дебаггер. Для этого надо включить дебаг-информацию для него.


Его делает отладчик с компилятором. Причем, компилятор также высирает обновлённый PDB, чтобы отладчик в следующей итерации мог правильно обновить код.

>Так я тебе написал с какими оптимизациями он не работает. Мог бы уже сам проверить давно.


не мог, у меня не стоит VS. То, что я проверил, говорит однозначно, что для оптимизированного кода ни в каких версиях нельзя сделать Hot Reload.
196 3464079
>>64074

> То, что я проверил, говорит однозначно


Там где ты проверял ничего про О2 не написано. Ты просто тупой и не понимаешь что значит оптимизации.
197 3464094
>>64073

>чтобы обозначать переменную ключевым словом "const"


всегда обозначаю, это показатель хорошего кода.
198 3464095
>>64073

>"Const" в C++ — это одна из самых ублюдочных бездарных фичей высранных за историю IT. Вот насколько нужно быть ебанатом, чтобы обозначать переменную ключевым словом "const"? Потому логично, что в новом языке неконец-то сделали адекватные константы.


почему? вполне нормальная штука - константная переменная. В чём проблема?
199 3464096
>>64095
если че в расте по сути то же самое по умолчанию навешивается
200 3464108
>>64096

>по умолчанию


Шо бы не як у москалейв других яп?
201 3464122
>>64108
типо чтобы было удобнее писсать в фп стиле
202 3464139
>>64122

> фп стиле


А кто в нем пишет?
203 3464145
>>64122

>фп стиле


>пидораст


Но это же убогая байтоёбская императивщина для либерально-педерастических js-петухов, которые ещё вчера кнопки красили в веб-параше.
204 3464148
>>64139
Я раст учу только 2 часа, так что не могу ответить на этот вопрос. Но фп (а точнее его элементы) протекает посепенно в другие языки, в том числе в плюсы (в шаблоны в основном, хотя и на ренжах че то есть интересное). Так что скорее всего элементы кто то использует. Да даже в джаве стримы есть, что тоже отголосок фп и часто используется.
Снимок экрана от 2025-05-28 02-17-52.png19 Кб, 484x231
205 3464158
>>64051
Звездочки проебались.
206 3464165
>>64094

>всегда обозначаю, это показатель хорошего кода.


Это очень спорный подход, который так или иначе будет заканчиваться в районе const_cast. Как ты не крутись, а всё равно что-то придётся кастовать. А потом пошло friend mutable, и по сути const превращается в хинт для линтера — примерно так к нему и стоит относиться. И уж точно const не гарантирует корректности работы с памятью. То есть, да, "показатель хорошего кода" — но это всё ещё не значит, что код не говно.
При этом код либы без const будет лаконичнее, особенно если имеют место сишные интерфейсы, в которых часто забивают на const.

>>64096

>если че в расте по сути то же самое по умолчанию навешивается


Если чо — нет:
let mut x = 5;
let immut_ref = &x;
let mut_ref = &mut x; // error[E0502]: cannot borrow `x` as immutable because it is also borrowed as mutable

let mut x = 5;
let immut_ref = &x;
x = 10; // error[E0506]: cannot assign to `x` because it is borrowed

Всё то же самое спокойно работает в C++:
int x = 5;
const int immut_ref = &x;
mut_ref = &x;
mut_ref = 10;

x = 5;
immut_ref = &x;
x = 10;
207 3464168
>>64165
Ладно, разные вещи. Но в чем проблема то конста в плюсах? Конст касты - костыль. Его нет в норм коде. Он наверное существует только, как ты заметил, из за сишных либ, где мы точно знаем, что туда можно положить конст, но оно так не помечено
Что меня в джаве бесило - нет конста, передавая объект в функцию, ты не можешь быть уверен, что функция его не поломаеи
208 3464171
>>64168

>Конст касты - костыль. Его нет в норм коде


Я "норм кода" в жизни не видел. Если чо — по твоим же критериям libstdc++ не является норм кодом:
https://github.com/search?q=repo%3Agcc-mirror%2Fgcc+path%3A%2F^libstdc\%2B\%2B-v3\%2F%2F+const_cast&type=code
Mutable используется реже, но он всё равно есть:
https://github.com/search?q=repo%3Agcc-mirror%2Fgcc+path%3A%2F^libstdc\%2B\%2B-v3\%2F%2F+mutable&type=code

>Что меня в джаве бесило - нет конста, передавая объект в функцию, ты не можешь быть уверен, что функция его не поломаеи


Так и в C++ ты не можешь быть уверен, лол. Во-первых const_cast, во-вторых указатели-псевдонимы без const — в чём тут вообще можно быть уверенным? Уверенным можно быть только после строгого ревью каждого пул реквеста.
209 3464205
>>64165

>который так или иначе будет заканчиваться в районе const_cast.


Мы про константные переменный или про методы? В любом случае константные методы это так же прекрасно и нужно пихать const везде где только возможно.

>А потом пошло friend mutable


Значит проблемы в архитектуре приложения. Зочем тогда насиловать Кресты если можно писать на Си где тебя ни что не ограничивает?
image.png127 Кб, 1430x816
210 3464206
>>64171

>Я "норм кода" в жизни не видел.


норм посаны так ебашут
211 3464473
>>64073

>переменную ключевым словом


>>64094

>всегда обозначаю, это показатель хорошего кода.


Конст не для этого.
212 3464555
>>64473

>Конст не для этого.


Чулочки поправь
213 3464586
>>64555
Зверёк, ты сходи и выясни для чего const в сях, а не выёбывайся лишний раз.
214 3464596
>>64586
Пишу на Си и Крестах и хочу пояснения от чулочников итт поводу const, а не жалкие пуки через анальную пробку.
image43 Кб, 1267x709
215 3464665
Анон, угадай редактор
216 3464721
>>64665
CLion?
217 3464742
>>64596

>на Си и Крестах


тред для ретардов ниже
218 3464763
rust это попытка долбоёбов сделать паскаль.
219 3464766
>>64665
Зед
220 3464864
>>64742

>тред для ретардов ниже


Тогда почему чулочниики бугурят итт?
image.gif2,9 Мб, 360x288
221 3464873
222 3465102
>>64766
Ага, но с патчем на шрефты.
2213231362d6c7b7490ec.jpg161 Кб, 800x600
223 3465130
>>53388

>Python


Ок, а с JS node что не так?
Зачем тебе ебля в туза нон-стоп на ближайшее десятилетие? (теперь понятно откуда мемы про фембойчиков...)
Ещё есть Ruby
224 3465132
>>53447

>компромиссы


Node может в производительность уровня Go,
безкомпромисные только аутисты и ситхи
225 3465228
>>53447
А какая такая охуенная производительность нужна для веб-параши? Если вдруг будет очень нужно производительно дробить числа - напиши дробилку на плюсах и вызывай из питухона.
226 3465265
>>64864
потому что не идут в тред для ретардов к плюсовикам
227 3465327
>>58364
держи

cat << EOF >config.toml
change-id = 136941

[build]
build = "x86_64-unknown-linux-gnu"
host = ["x86_64-unknown-linux-gnu"]
target = ["x86_64-unknown-linux-gnu", "mipsel-unknown-linux-gnu"]
docs = false
extended = true
tools = ["cargo", "rustfmt", "clippy"]

[rust]
codegen-units-std = 1
dist-src = false
channel = "stable"
rpath = true
lld = false

[target.mipsel-unknown-linux-gnu]
linker = "mipsel-unknown-linux-gnu-gcc"
cc = "mipsel-unknown-linux-gnu-gcc"
cxx = "mipsel-unknown-linux-gnu-g++"
ar = "mipsel-unknown-linux-gnu-ar"
ranlib = "mipsel-unknown-linux-gnu-ranlib"
crt-static = false

[target.x86_64-unknown-linux-gnu]
linker = "свой gcc"
cc = "свой gcc"
cxx = "свой g++"
ar = "свой ar"
ranlib = "свой ranlib"
crt-static = false

[install]
prefix = "куда хочешь поставить"

[llvm]
link-shared = true
download-ci-llvm = false
EOF

./x.py build
./x.py install

пользуйся
227 3465327
>>58364
держи

cat << EOF >config.toml
change-id = 136941

[build]
build = "x86_64-unknown-linux-gnu"
host = ["x86_64-unknown-linux-gnu"]
target = ["x86_64-unknown-linux-gnu", "mipsel-unknown-linux-gnu"]
docs = false
extended = true
tools = ["cargo", "rustfmt", "clippy"]

[rust]
codegen-units-std = 1
dist-src = false
channel = "stable"
rpath = true
lld = false

[target.mipsel-unknown-linux-gnu]
linker = "mipsel-unknown-linux-gnu-gcc"
cc = "mipsel-unknown-linux-gnu-gcc"
cxx = "mipsel-unknown-linux-gnu-g++"
ar = "mipsel-unknown-linux-gnu-ar"
ranlib = "mipsel-unknown-linux-gnu-ranlib"
crt-static = false

[target.x86_64-unknown-linux-gnu]
linker = "свой gcc"
cc = "свой gcc"
cxx = "свой g++"
ar = "свой ar"
ranlib = "свой ranlib"
crt-static = false

[install]
prefix = "куда хочешь поставить"

[llvm]
link-shared = true
download-ci-llvm = false
EOF

./x.py build
./x.py install

пользуйся
228 3465350
Правильно понимаю, что ссылки как и в плюсах указывают на одну и ту же переменную(объект) и нельзя сделать так, чтобы ссылка привязалаь к чему то другому и мы только можем присовоить в ссылку новый объект, меняя старый?
229 3465358
Понял, неправильно
230 3465363
>>65350
Ты можешь прикрутить мутабельность у любому объекту типа.
231 3465536
>>64206

>норм посаны так ебашут


А потом вашему const методу нужен кэш или разделяемая ссылка — и пиздец, вот тебе твой const и закончился.
....
Ну я как и думал:
https://github.com/SerenityOS/serenity/blob/d653eec65ce58fb317e0c6ae64dc00646a566395/Userland/Libraries/LibGfx/Bitmap.cpp#L578-L584
Bitmap::to_shareable_bitmap() вызывает to_bitmap_backed_by_anonymous_buffer(), и вуаля:
https://github.com/SerenityOS/serenity/blob/d653eec65ce58fb317e0c6ae64dc00646a566395/Userland/Libraries/LibGfx/Bitmap.cpp#L533-L543
return NonnullRefPtr { const_cast<Bitmap&>(*this) }
Не может быть разделяемый объект const, хоть ты тресни. То есть, чисто теоретически можно было изойти на говно, сделать несколько объектов, заставить пользователя во всех методах передавать два объекта, но разрушительность такого подхода в плане читаемости-понимаемости будет намного хуже, чем простое дублирование const/nonconst методов, как у тебя на скрине (с мостиком через const_cast, естественно).
232 3465537
>>64766

>Зед


>>65102

>Ага, но с патчем на шрефты.


Тоже всопнился зед, но я не ебу, что на пикче. Его пытаются хайповать, мол "смотрите, на расте не только hello world можно писать". И, в принципе, за 5 лет прогресс впечатляющий, оно даже в кооперацию умеет. Но что-то как-то комьюнити не спешит никуда.
Для сравнения — VS Code делался три года, с нуля до версии 1.0.
233 3465538
>>65132

>Node может в производительность уровня Go,


Нода может в производительность только если с ней наебаться столько времени, за которое уже можно было написать код на Rust.
234 3466352
в rust есть красивые решения для работы с SQL?
нужно например:
1) создавать одно соединение и юзать его где угодно и не таскать его везде воюя с барроу чекером;
2) в одну строчку запихать вектор (или любой другой тип) в базу, без явной сериализации и прочего говна;
3) прочитать то, что запихнули в п.2
235 3466367
>>66352

> юзать его где угодно


> не таскать его везде


что

>запихать вектор (или любой другой тип) в базу, без явной сериализации


что
236 3466395
>>66352
Ты сам-то хоть понял, что написал?
237 3466401
>>66395
да, лень расписывать
238 3466418
>>66352

>в rust есть красивые решения для работы с SQL?


Есть. https://github.com/launchbadge/sqlx

>создавать одно соединение и юзать его где угодно и не таскать его везде воюя с барроу чекером;


https://docs.rs/sqlx/latest/sqlx/type.PgPool.html

>в одну строчку запихать вектор (или любой другой тип) в базу, без явной сериализации и прочего говна;


Используй unnest

sqlx::query(
r#"
UPDATE orders
SET strategy_id = $1
WHERE order_id IN (SELECT * FROM UNNEST($2))
"#,
)
.bind(&strategy_id)
.bind(order_ids)
.execute(&mut tx)
.await?
239 3466421
>>66418

>unnest


тоже гавно, что и json получается

я хотел, чтобы оно мне сразу все в bytea запихала, я только derive прописал у структуры
уже смирился, что все сначала с помощью bincode в Vec<u8> захуярю, но тут выясняется, что для chrono, что в моей структуре прячется, нет импла Encode/Decode

ладно, похуй, и на том спасибо

>https://docs.rs/sqlx/latest/sqlx/type.PgPool.html


про пулы знаю, но там же все равно его создаешь, а потом ссылку (мутабельную?) гоняешь из функцию в функцию
а мне бы хотелось бы из любого места в кода хуйнуть sql запрос без параши типа "let mut client =
Client::connect("postgresql://postgres:postgres@localhost/main", NoTls).unwrap();"
240 3466423
идем нахуй дальше
какая блядь разница между [u8; 10] и [u8; 50]??
241 3466424
>>66423

>какая блядь разница между [u8; 10] и [u8; 50]??


Ну он говорит, что имплементация есть только для [u8, 0], [u8, 10], [u8, 11], [u8, 12]... Разработчик не запилил сериализацию для таких массивов с таким количеством повторений.
242 3466425
>>66424
эт я прочитал, но все равно не понял
вы имеете сказать шо там для каждого [T; x] отдельная реализация?
пахнет хуйней, я бы даже сказал воняет
243 3466437
>>66424
проиграл
244 3466641
>>66425

>вы имеете сказать шо там для каждого [T; x] отдельная реализация?


Нуууу да. А в других библиотеках тоже самое. Допустим если библиотека линейной алгебры, то ты не можешь сделать матрицу миллиард на миллиард строк. Он тебе скорее всего скажет, что нет такой реализации. К сожалению, это обратная сторона строгих типов. Возвращаемый тип у функции должен быть заранее известен. Я не могу сделать дженерик а-ля Output<T>, чтобы он один раз возвратил Output<foo>, а в другой раз возвратил Output<bar>. Мне надо описать все возможные значения Output заранее. В принципе, можно попробовать стереть тип, конвертировать в Box<dyn Any + Send + Sync> (это что-то наподобие any в typescript), но тогда у тебя будет ёпка с downcast'ингом, когда ты будешь превращать его в конкретный тип. В твоём случае, надо было использовать не [u8, 10], а либо какой-нибудь Arc<[u8]>, либо Vec<u8>, а в самом коде делать let arr = std::array::repeat(0); тогда было бы правильно.
245 3466670
>>66641

>Допустим если библиотека линейной алгебры, то ты не можешь сделать матрицу миллиард на миллиард строк. Он тебе скорее всего скажет, что нет такой реализации.


А чулочникам аналоги крестовых шаблонов не завезли?
246 3466739
>>66670
Я хз про что ты говоришь. Поскольку я не программирую на С++. Но в целом, проблема не является нерешаемой. Её можно решить через какой-нибудь трейт обжект, другой вопрос - кому это нахуй надо. Это второстепенный функционал, от которого большинству не жарко ни холодно. Стараться ради додика, которому хочется посраться а-ля АЗАЗАЗА НИ МОЖИШЬ СДЕЛАТЬ. Короче просто лень.
247 3466753
>>66423
ну как видишь в serde не написали определение для произвольного размера массива

> почему так сделали?


не ебу, не разраб serde, но кажется что то со старыми версиями раста связано
https://users.rust-lang.org/t/derive-serde-serialize-when-struct-has-array-as-one-of-its-member/81820/2

> как пофиксить


в ссылке описано

> как должно быть реализовано правильно


нужен раст 1.51 для const generics:
impl<T, const N: usize> MyTrait for [T; N]

>>66670

>аналоги крестовых шаблонов


макросы
248 3468890
как делать такое?
trait Hui {}
struct Pizda<const M: usize> {}
impl<const M: usize> Hui for Pizda<M> {}
impl !Hui for Pizda<12> {}
нихуя не получается, ни через трейты, ни через ассоциативные типы никак. через макросы получилось только через процедурные и оно компилировалось очень долго, тк делал импл от usize::MIN до usize::MAX без некоторых значений, типа 12, 7, 5 и тд для примера, те оно на cargo check захлёбывалось.
249 3468918
>>68890
хм посмотрел дамп, оказывается произошёл оом и процесс был убит нахуй, те через макросы невозможно сделать нормально.
image.png41 Кб, 821x307
250 3469108
>>68890
Негатив импл из-за пикрила не работает. Я вот такое навайбкодил, но там найтли:

https://play.rust-lang.org/?version=nightly&mode=debug&edition=2024&gist=99255a8ddc16973342721f9fdbf828c7
251 3469371
>>68890
Нахуя вы этим говном занимаетесь долбонавты? Скоро абстракные фактори в раст завезут?
252 3469918
https://habr.com/ru/articles/905544/

Выбрали инструмент потому что любят раст - очень инженерненько, очень прагматичненько.
@
Раст вытрахал всю любовь через анальный рефакторинг и бойлерплейт.
@
Переписали все на юнити всего за 6 недель, выкинув 400% бойлерплейта (то есть за все время они топтались на месте на расте, офигенное КПД).

Почему это говно еще вывозит на своем хайпе в 2025?
253 3470197
>>69918

>Ebitengine


Кек

>Смотрите сами - преимущества ECS и rust - скорость кода, точность, сильная типизация - это все про производительный и безопасный код


Чёт обосрался с этого долбоёба, там под капотом какой-нибудь ансейф, который пизданёт рано или поздно.
254 3470409
>>69918

> почему выбрали для разработки раст и Bevy


> ну мне нрав просто язык, а еще сообщество нрав


> а всмысле Bevy это нихуя не продакшен реди и делается любителями для прикола



Но а виноват конечно же раст)
255 3470838
>>70409

>Но а виноват конечно же раст)


Челики решили в гейдев на языке для вебчика в оборонке и криптонаебалова, что могло пойти не так ))
256 3471285
>>70838
Да чел, дело в языке, а не в игровых движках

существует 2-3 движка на которых реально можно написать игру и миллион движков на которых не написано ни одной игры
257 3471611
>>71285
Модель владения в пидорасте слишком сильно режет пространство возможных програм на этом языке. Ты решил вписаться в пидорасто движуху, потом понял, что инструмент неподходящий, потому что челики в интернете нахваливали пидораст и продали тебе, потом читаешь в интернете

>Да чел, дело в языке, а не в игровых движках


>Ты просто недостаточно хорош для пидораста


>Etc


https://loglog.games/blog/leaving-rust-gamedev/
ЯЗЫК ИДЕАЛЬНЫЙ ДЛЯ ГЕЙ ДЕВА, ПРОСТО ПРОБЛЕМА В ВАС
258 3471628

> https://github.com/spring-rs/spring-rs


проиграл)

>>71611
попробуй мой пост не жопой прочитать
буквально во всей истории можно смело менять раст на с++ и окажется что и плюсы для геймдева не подходят.
Ведь челы решили использовать вместо нормально движка кустарную залупу опенсорсную, и НЕОЖИДАННО оказывается легче всё на юнити\гейм мейкере переписать
259 3471670
>>71628
Жопочтец тут только ты, пиздуй перечитывать, любитель засовывать раст во все дырки.
260 3471673
>>71670

> пук пук, ну ребят ну скажите что раст плохой, всмысле не в нем проблема, Я СКАЗАЛ В НЕМ, ЭТО ОН МНЕ МЕШАЕТ БЫТЬ ВЕЛИКИМ ГЕЙМДЕВЕЛОПЕРОМ

261 3471677
>>71673

>Ребята раст идеальный язык для гейдева

Untitled.png1 Кб, 50x42
262 3471678
>>71677
покажешь где я хотя бы примерно это писал?)
Обновить тред
« /pr/В начало тредаВеб-версияНастройки
/a//b//mu//s//vg/Все доски

Скачать тред только с превьюс превью и прикрепленными файлами

Второй вариант может долго скачиваться. Файлы будут только в живых или недавно утонувших тредах.Подробнее