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

Static bool isReferencingMDNode(const Instruction &I) { if (const auto

*CI = dyn_cast<CallInst>(&I))
if (Function *F = CI->getCalledFunction())
if (F->isIntrinsic())
for (auto &Op : I.operands())
if (auto *V = dyn_cast_or_null<MetadataAsValue>(Op))
if (isa<MDNode>(V->getMetadata()))
return true;
return false;
}

Как бы вы отрефакторили этот кусок?🤔

8 ответов

11 просмотров

Например я бы писал так: if (smth) { return false; } return true; вместо if (!smth) { return true; } return false; Так как это сделает меньше вложенности в случае большого количества условий

В вашем случае вот так примерно: static bool isReferencingMDNode(const Instruction &I) { if ((const auto *CI = dyn_cast<CallInst>(&I)) == nullptr) { return false; } if ((Function *F = CI->getCalledFunction()) == nullptr) { return false; } ... return true; }

abc cba
Например я бы писал так: if (smth) { return false...

Ещё можно классический do-break-while(false)

abc cba
В вашем случае вот так примерно: static bool isRef...

if ((auto a = 1) == 2) - невалидная конструкция

abc cba
Например я бы писал так: if (smth) { return false...

return not smth; Ну или !smth если больше нравится :)

Alexander Karaev
if ((auto a = 1) == 2) - невалидная конструкция

Думал такая конструкция сработает. Жаль

abc cba
Думал такая конструкция сработает. Жаль

может тогда заменить на if (auto a = 1; a == 2) {} ?

Andrei Tokmakov
может тогда заменить на if (auto a = 1; a == 2) {...

Тогда скоуп для a будет меньше ожидаемого

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

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

Anyone here suffers from unexplained aural migraines, who would be up for talking for a bit? Doesn't *have* to be aural, but I am not asking about headaches, I mean actual mi...
Martin Rys
55
Я тут за тем, чтобы задать вопрос, так как не знаю ассемблер, учу с/с++. Короче, насколько дорога операция перехода в функцию при ее вызове? Дело в том, что в с++ есть макросы...
Максим Рябцев
12
А какие чаты вообще в ходу? Auto aim? И что еше
do you think you're better off alone? А
13
Привет, нужен совет старших товарищей. Есть глобальная переменная var DefaultDataFolder:string; инициализируем DefaultDataFolder:='a:\_OUT\'; есть примитивная процедур...
Max Otto
14
hello friends. Do you know how can I learn getx? I have a software project that I should deliver it up to 5 weeks later and I need to learn firebase too. I will be thankfull
AmirHossein Razavi
15
Доброе время суток! у меня тут иноды закончились. и понял почему по сути кстит, я периодически очищаю постгрес и сентри контайнер: postgres=# DELETE FROM nodestore_node WHER...
Юсиф Насиров
9
Вопрос. Теоретический. Есть список команд. Команды отправляю в обработку некой функции, по очереди. Разные команды могут давать разные результаты после обработки. В зависимос...
Serjone
7
lazarus-3.2.0/gtk, linux патч "имя проекта по умолчанию project1 -> prj" день добрый не нравится "именя проекта по умолчанию" (project1), к.раз приходится переименовывать (н...
livontiy
5
Какой дос блять?
007
9
Коллеги, а в чём сейчас хорошо писать на перле, в смысле ide? Пробовал в идее с плагином, подсветка есть, даже какие-то предупреждения есть, но рефакторинга считай нет. Перене...
Дмитрий Петров
9
Карта сайта