metaclass: (Default)
metaclass ([personal profile] metaclass) wrote2016-07-25 10:18 am

C, магия макросов и отладка

Судя по тому, что я наблюдаю в либах на Си (например, libuv), магия из макросов весьма популярна, в том числе и для реализации разного рода структур данных вроде списков, хэшей (https://troydhanson.github.io/uthash/) и прочего такого.

Вопрос вот в чем - как это нормально отлаживать то? Падает с access violation где-нибудь в кишках макроса на три страницы, отладчик указывает на строку с макросом и единственный способ понять происходящее - медитировать до бесконечности на содержимое переменных, используемых в макросе, потому что кода не видно. Ну или пытаться в уме разложить дизассемблированный код на исходники.

[identity profile] worm-ii.livejournal.com 2016-07-25 07:43 am (UTC)(link)
Дедовским методам — дедовскую отладку.
Всунуть в макросы отладочную печать.

[identity profile] swizard.livejournal.com 2016-07-25 10:39 am (UTC)(link)
+1, отладка printf-ами, а как ещё-то