-
Data: 2012-05-07 01:25:53
Temat: Re: [OT] Zarządzanie konfiguracją modułów kodu źródłowego
Od: mk <reverse_lp.pw@myzskm> szukaj wiadomości tego autora
[ pokaż wszystkie nagłówki ]W dniu 2012-05-06 22:05, Sebastian Biały pisze:
> On 2012-05-06 21:32, mk wrote:
>>> Uzywając def.
>>> Np. tak:
>>> default-config: #define UART_STOP_BITS 1
>>> project-config: #include "default.h", #define UART_STOP_BITS 2
>> Redefiniowanie makra nową wartością jest nielegalne!!!
>
> Masz rację, jak zwykle pisze skrótami i nie wszystko podaje. Oczywiscie
> że jest #undef ale tylko dlatego że nie da się zrobić wprost #define
> ponownie (w gcc da się). Samo undef jest wyłacznie wytrychem a nie
> sednem metody. Sendem metody jest ponowne zdefiniowanie symbolu
> nadpisując default.
GCC jest tu tolerancyjny, ale i tak daje warningna.
> Jak napisałem - dla mnie nie ma znaczenia którą metodą inkludowania
> wybierzesz - obydwie sa mizerne i sprwadzają się do tej samej sieczki w
> define.
Takie uroki tworzenia kodu uniwersalnego. Sieczki programowania
generycznego C++ często wcale nie wyglądają lepiej :-)
>> jest niezgodne np. z MISRA-C i w ogóle niepotrzebnie zaciemnia plik
>> konfiguracji użytkownika.
>
> Nie mam targetu na misra-c. Więc ich zalecenia nie są dla mnie kluczowe.
> Czy zaciemnia - to już inna sprawa. W odwrotnej konfiguracji zaciemnia
> #ifdef. Tak czy inaczej - to nie wygląda dobrze.
Ale to z plikiem konfiguracji użytkownika użytkownik będzie w pierwszej
kolejności pracować. Nadawanie konfiguracji domyślnej to już bebechy...
Nie ma co sobie obrzydzać, tak wygląda język C :-)
> Prawde mowiąc korzystam znacznie częściej ze statycznego polimorfizmu.
> #define to odprysk w kilku miejscach.
>
> Mam taki nieskończony projekcik (który strasznie zaniedbałem, ale
> obiecuje poprawę) na SF, możesz sobie zerknąć co mam na myśli:
>
> http://sourceforge.net/projects/microheap/
Inny język, inna bajka... Świecą mi się oczy jak widzę takie rzeczy,
choć C++ daleki jest w programowaniu generycznym od tego co można sobie
wymarzyć. W wolnej chwili nie omieszkam lepiej się przyjrzeć projektowi.
I dla odmiany (też jeśli chodzi o rozwiązania generyczne i też jeśli
chodzi o zarządców pamięci): mam ostatnio do czynienia z biblioteczką
lwIP (stos TCP/IP). Mam tu w szczególności na myśli pule pamięci z tego
projektu (pliki memp.c, memp_std.h).
Wygląda to mniej więcej tak:
const u16_t memp_sizes[MEMP_MAX] = {
#define LWIP_MEMPOOL(name,num,size,desc) LWIP_MEM_ALIGN_SIZE(size),
#include "lwip/memp_std.h"
};
i na końcu pliku memp_std.h odwołujemy makro LWIP_MEMPOOL.
Plik memp_std.h tworzy ciało listy inicjalizacyjnej tablicy memp_sizes.
następnie znowu:
static const u16_t memp_num[MEMP_MAX] = {
#define LWIP_MEMPOOL(name,num,size,desc) (num),
#include "lwip/memp_std.h"
};
itd...
W ten sposób dzięki podmienianiu definicji LWIP_MEMPOOL obskoczono
wytwarzania wszystkich struktur danych niezbędnych do pracy pól pamięci
:-) Grrrrrrrrrrrrrrr... No i teraz próbuj to człowieku debugować... Aż
się prosi o szablony i trejty (ale to nie C++).
Ale w boost też tą technikę (redefiniuj makro i włącz nagłówek) się
stosuje... Paskustwo!
>> sygnalizować już na wczesnym etapie rozpoznania konfiguracji użytkownika
>> np. zgodność wersji modułu bibliotecznego i jej użytkownika, czy wiele
>> innych parametrów o globalnym charakterze.
>
> W moim przypadku nie sposób w momencie inkludowania default wykryć czy
> dopuszczalne jest mieć uart o 2 bitach stopu. Przy czym "nie sposób" w
> sensie, że jakikolwiek sposób powoduje wyciek wiedzy o hardware do
> miejsca o innym poziomie abstrakcji. Im niej zależności tym lepiej dla
> projektu.
Oczywiście, że taki warunek jest związany ściśle z implementacją
hardware, więc warunek ten powinien być możliwie blisko tyłka drajwera
tego modułu.
pzdr
mk
Następne wpisy z tego wątku
- 07.05.12 02:21 Michoo
- 07.05.12 15:52 Nijak
- 07.05.12 21:23 Andrzej Ekiert
- 07.05.12 21:42 Paweł
- 07.05.12 22:46 RoMan Mandziejewicz
- 08.05.12 07:56 Paweł
- 08.05.12 08:50 RoMan Mandziejewicz
- 08.05.12 15:13 janusz_kk1
- 09.05.12 09:07 Artur M. Piwko
- 09.05.12 10:03 janusz_kk1
- 25.05.12 16:09 Artur M. Piwko
Najnowsze wątki z tej grupy
- Mierniki poziomu glukozy (CGM, FGM)
- A Szwajcarzy kombinują tak: FinalSpark grows human neurons from stem cells and connects them to electrode arrays
- Kontrola nad prądem - sprawdź jak działa [apka - przyp. JMJ] eLicznik
- NETIA i hasło logowania
- Modulacja FM
- Najgorszy język programowania
- Kol. sukces po polsku: firma Szumisie sp. z o.o.
- Chińska Telefonia 6G - Chcą Nas Sterować Elektrycznie - Jak Kukiełki w Teatrze Lalek!!!
- RS-485 ale automatycznie dwukierunkowy
- Leżakujące SSD gubią po roku dane
- kolorowy e-paper
- Sterownik kotła CO praca PWM
- Jakie baterie A23 i LR44?
- OLED SSD1306 - degradacja?
- Który symulator AVR jest ,,prawilny"?
Najnowsze wątki
- 2025-12-12 Białystok => Programista React ze znajomością C++ <=
- 2025-12-12 Warszawa => Microsoft Dynamics 365 Finance Consultant <=
- 2025-12-11 To już efekt Żurka czy coś jeszcze GORSZEGO?
- 2025-12-11 Policjanci w mieście Łodzi zmierzą ci prędkość z błędem mniejszym niż producent w laboratorium :-)
- 2025-12-11 Warszawa => Senior Java Developer <=
- 2025-12-11 Kolejny prezent
- 2025-12-10 hameryka
- 2025-12-10 Tak im zależy na wlasnym kraju. :-(
- 2025-12-10 Czy "hipoteka przymusowa" podpada (powinna podpadać) pod ochronę immunitetem poselskim? [Ziobro]
- 2025-12-10 Żurek po raz kolejny wykazał jaki poziom reprezentuje
- 2025-12-10 Gdańsk => Microsoft Dynamics AX/365 SCM Consultant - Service & Suppor
- 2025-12-10 Rzeszów => Konsultant ERP Microsoft Dynamics 365 Commerce <=
- 2025-12-10 Chrzanów => Spedytor Międzynarodowy (handel ładunkami/prowadzenie f
- 2025-12-10 Chiny => Koordynator Produkcji / Przedstawiciel ds. rozwoju produktu <
- 2025-12-10 Przekroczenie uprawnien




2035 rok coraz mniej realny? Europa traci tempo w wyścigu o elektromobilność