172 похожих чатов

Не могу убрать пробел из процмакроса :( Нужно составить набор токенов

$1, но оно упорно ставит между ними пробел: $ 1.

Пытался через quote!($#arg_number_at_query)
Через
let mut ts = proc_macro2::TokenStream::from_str("$").unwrap();
ts.append(proc_macro2::Literal::usize_unsuffixed(arg_number_at_query)); // тут лежит 1, 2, 3, etc.

Через вот так:
let dollar = pm2::Punct::new('$', pm2::Spacing::Joint);
let num_lit = pm2::Literal::usize_unsuffixed(arg_number_at_query);
let num = quote::quote!(#dollar#num_lit);
eprintln!("{:?}", &num);
// вывод: TokenStream [Punct { ch: '$', spacing: Joint, span: #1914 bytes(4053..4113) }, Literal { kind: Integer, symbol: "1", suffix: None, span: #1914 bytes(4053..4113) }]
Итог: "SELECT * FROM users WHERE login = $ 1 AND email = $ 2", т.е. всё равно пробел.

Не понимаю, как это делается.

8 ответов

19 просмотров

https://docs.rs/quote/1.0.9/quote/macro.format_ident.html

а тебе точно нужен токен, а не строка?

George-C. Автор вопроса
Andrey Vlasov
https://docs.rs/quote/1.0.9/quote/macro.format_ide...

message: "$1" is not a valid identifier какой ж это идент

George-C. Автор вопроса
Денис
а тебе точно нужен токен, а не строка?

Строка раскрывается в \"$1\" `SELECT * FROM users WHERE login = \"$1\" AND email = \"$2\"`

George C.
Строка раскрывается в \"$1\" `SELECT * FROM users ...

let value = format!("${}", arg_number_at_query); let value = quote!(#value);

George C.
Строка раскрывается в \"$1\" `SELECT * FROM users ...

А нельзя сначала собрать литерал с плейсхолдерами {} вместо чисел, а потом сделать format! в самом quote?

George-C. Автор вопроса
Traveller Kolsky
А нельзя сначала собрать литерал с плейсхолдерами ...

format неконстантный. Суть в склеивании всего запроса в компайл-тайме, в функции уже будет просто склеенная строка - "SELECT * FROM users WHERE login = $1 AND email = $2". Я могу обновить тот репо тем способом, который получился у меня через concatcp, а вы можете форкнуть его и сделать тем, который имеете в виду

George C.
format неконстантный. Суть в склеивании всего запр...

конкатенация, да еще и константная?:) и с литералами и всей мишурой?:) помню время страдал этим, и пакетик готовый имеется... сделанный еще до всей этой нормальной движухи с const.. но в большую свободу не вышло, бо наступил на грабли раст... https://github.com/clucompany/cluConstData <—— работает и на дженериках и еще на чем... единственное был огроменный прокол.. когда Rust не мог определить константно, что T относиться к нужному дженерику с целью получения const значения... // работает только на nightly:), но это похоже можно уже современными методами легко исправить... бо transmute на const... , а раньше и const transmute надо было выдумывать) бо не было этого...

Похожие вопросы

Обсуждают сегодня

а через ESC-код ?
Alexey Kulakov
29
30500 за редактор? )
Владимир
47
Чёт не понял, я ж правильной функцией воспользовался чтобы вывести отладочную информацию? но что-то она не ловится
notme
18
У меня есть функция где происходит это: write_bit(buffer, 1); write_bit(buffer, 0); write_bit(buffer, 1); write_bit(buffer, 1); write_bit(buffer, 1); w...
~
13
Недавно Google Project Zero нашёл багу в SQLite с помощью LLM, о чём достаточно было шумно в определённых интернетах, которые сопровождались рассказами, что скоро всех "ибешни...
Alex Sherbakov
5
в JclConsole объявлено так: function CtrlHandler(CtrlType: DWORD): BOOL; stdcall; - где ваше объявление с stdcall? у вас на картинке нет stdcall
Karagy
8
Как передать управляющий символ в открытую через CreateProcess консоль? Собсна, есть процедура: procedure TRedirectThread.WriteData(Data: OEMString); var Written: Cardinal;...
Serjone
6
Ребят в СИ можно реализовать ООП?
Николай
33
Вот еще странный косяк, подскажите как бороться. Я git clone сделал себе всего embassy и примеры там запускаю. Всё хорошо. Но вот решил в cargo.toml зависимости не как в приме...
Lukutin R2AJP
2
program test; {$mode delphi} procedure proc(v: int32); overload; begin end; procedure proc(v: int64); overload; begin end; var x: uint64; begin proc(x); end. Уж не знаю...
notme
6
Карта сайта