-
Data: 2011-07-30 12:52:25
Temat: Re: Odp: Re: Prosty preprocesor wielojęzykowy
Od: Spec <m...@g...com> szukaj wiadomości tego autora
[ pokaż wszystkie nagłówki ]On 27 Lip, 18:03, "godek.maciek" <g...@g...com> wrote:
> W dniu środa, 27 lipca 2011, 15:39:27 UTC+2 użytkownik Mariusz Marszałkowski
napisał:
>
> > Nie wiem co to ma na celu... Mnie czasami nie chcialo sie wpisywac
> > recznie
> > wiele podobnego/specyficznego kodu. Wtedy pisalem po prostu w C taki
> > generator.
>
> Moim zdaniem C nie jest najlepszym językiem do tworzenia generatora kodu, bo
zazwyczaj nie wymaga się od takich programów wydajności, ale raczej tego, żeby dało
się je szybko pisać i łatwo edytować, a nade wszystko -- żeby dobrze operowały na
łańcuchach tekstu. Ale nawet gdyby ktoś chciał zrobić coś takiego, to mógłby napisać
>
> kod.c:
> ...
> @begin "cc -x c $< -o gen; ./gen > $>; rm gen"
> /* kod w C, który generuje inny kod w C */
> ...
Przychylam się do opinii że C to kiepski język do pisania generatorów.
Proponowałbym coś wyższego poziomu, oszczędności na pewno byłyby
większe.
>Czy może słyszał ktoś, żeby podobne narzędzie już wcześniej istniało, albo żeby
realizowanie tego typu pomysłów było radykalnie odradzane przez jakieś
>programistyczne autorytety?
Takie narzędzie, wbudowane w język programowania istnieje od ponad 50
lat - a język to Lisp.
Kod programu w Lispie przypomina AST, możemy więc mieszać kod i dane
bez ograniczeń. Najprostszy przykład:
`(a b c ,@(loop for i to 3 collect i))
"," wymusza wykonanie w danym miejscu tak więc od razu powstaje nam
lista elementów: (a b c 0 1 2 3).
Bardziej skomplikowane rzeczy możemy tworzyć z użyciem lispowych makr,
szybkie pokazanie możliwości: http://www.gigamonkeys.com/book/macros-defining-your
-own.html
Następne wpisy z tego wątku
- 02.08.11 04:43 Mariusz Marszałkowski
- 03.08.11 01:01 godek.maciek
- 03.08.11 02:00 A.L.
Najnowsze wątki z tej grupy
- Alg. kompresji LZW
- Popr. 14. Nauka i Praca Programisty C++ w III Rzeczy (pospolitej)
- Arch. Prog. Nieuprzywilejowanych w pełnej wer. na nowej s. WWW energokod.pl
- 7. Raport Totaliztyczny: Sprawa Qt Group wer. 424
- TCL - problem z escape ostatniego \ w nawiasach {}
- Nauka i Praca Programisty C++ w III Rzeczy (pospolitej)
- testy-wyd-sort - Podsumowanie
- Tworzenie Programów Nieuprzywilejowanych Opartych Na Wtyczkach
- Do czego nadaje się QDockWidget z bibl. Qt?
- Bibl. Qt jest sztucznie ograniczona - jest nieprzydatna do celów komercyjnych
- Co sciaga kretynow
- AEiC 2024 - Ada-Europe conference - Deadlines Approaching
- Jakie są dobre zasady programowania programów opartych na wtyczkach?
- sprawdzanie słów kluczowych dot. zła
- Re: W czym sie teraz pisze programy??
Najnowsze wątki
- 2025-02-25 Tak wiem.... To oczywiste ale jak oni dzisiaj dziadują na materiale
- 2025-02-25 rozliczenia policji
- 2025-02-25 Echhhhhh. Marzy mi się SWAP Audi A2 z 1.8 T ;-)
- 2025-02-25 Warszawa => Analityk Biznesowo-Systemowy <=
- 2025-02-25 Warszawa => SQL Developer <=
- 2025-02-25 Zbigniew Ziobro śmie sugerować "niedostatki niezawisłości" sędzi (wątpliwości co do bezstronności)
- 2025-02-25 Kraków => DevOps Engineer (Junior/Regular) <=
- 2025-02-25 Kraków => Front-end Developer <=
- 2025-02-25 Szpital
- 2025-02-24 Gniazdo + wtyk
- 2025-02-24 Dyrektor Toyoty miał rację. Elektryki to ślepa uliczka
- 2025-02-24 Białystok => System Architect (Java background) <=
- 2025-02-24 Białystok => System Architect (background deweloperski w Java) <=
- 2025-02-24 Białystok => Solution Architect (Java background) <=
- 2025-02-24 Warszawa => Data Engineer (Tech Leader) <=