-
X-Received: by 10.140.30.116 with SMTP id c107mr825qgc.20.1415538183102; Sun, 09 Nov
2014 05:03:03 -0800 (PST)
X-Received: by 10.140.30.116 with SMTP id c107mr825qgc.20.1415538183102; Sun, 09 Nov
2014 05:03:03 -0800 (PST)
Path: news-archive.icm.edu.pl!news.icm.edu.pl!newsfeed.pionier.net.pl!news.glorb.com!
u7no324057qaz.1!news-out.google.com!u1ni1qah.0!nntp.google.com!i13no324229qae.0
!postnews.google.com!glegroupsg2000goo.googlegroups.com!not-for-mail
Newsgroups: pl.comp.programming
Date: Sun, 9 Nov 2014 05:03:03 -0800 (PST)
Complaints-To: g...@g...com
Injection-Info: glegroupsg2000goo.googlegroups.com; posting-host=46.186.78.6;
posting-account=f7iIKQoAAAAkDKpUafc-4IXhmRAzdB5r
NNTP-Posting-Host: 46.186.78.6
User-Agent: G2/1.0
MIME-Version: 1.0
Message-ID: <c...@g...com>
Subject: Makra w jezyku Scheme
From: g...@g...com
Injection-Date: Sun, 09 Nov 2014 13:03:03 +0000
Content-Type: text/plain; charset=ISO-8859-1
Xref: news-archive.icm.edu.pl pl.comp.programming:206864
[ ukryj nagłówki ]W zeszle wakacje, sprowokowany przez firra i Edka, opowiedzialem nieco
o swoich doswiadczeniach z jezykiem Scheme i programowaniem funkcyjnym.
Poniewaz moje objasnienia spotkaly sie z dosc cieplym przyjeciem,
postanowilem tym razem opowiedziec co nieco o higienicznych makrach
w jezyku Scheme.
Struktura tekstu jest nastepujaca. W rozdziale pierwszym omawiam podstawowe
wyrazenia z jezyka Scheme, a nastepnie w rozdziale drugim opisuje potrzebe
zdefiniowania kilku nowych form specjalnych, oraz ogolna uzytecznosc mozliwosci
definiowania tych form.
W rozdziale trzecim omawiam system makr w stylu Common Lispa (define-macro)
i implementuje w nim wprowadzone we wczesniejszym rozdziale przyklady.
W rozdziale czwartym zamierzam omowic system makr higienicznych R5RS
(syntax-rules) opracowany przez Kenta Dybviga i zaimplementowac w nim
wczesniej zaimplementowane formy, wskazujac na wady i zalety tego systemu.
W rozdziale piatym chcialym podac rozne sposoby obchodzenia ograniczen
systemu syntax-rules, mianowicie (1) ogolniejszy system makr "syntax-case",
(2) zaproponowana przez Olega Kiselyova implementacje maszyny abstrakcyjnej
CK oraz (3) makra pisane "w stylu przekazywania kontynuacji" (continuation
-passing-style)
W rozdziale szostym chcialbym opowiedziec o kilku zastosowaniach makr, ktore
w innym przypadku bylyby trudne do uzyskania. W szczegolnosci zamierzam
zaprezentowac pattern-matcher Wrighta-Shinna.
Na poczatek przesylam pierwsze 3 rozdzialy, a to z dwoch powodow. Po pierwsze
dlatego, ze sa to jedyne rozdzialy, jakie do tej pory napisalem, a po drugie
tekst juz w tym momencie jest znacznie dluzszy, niz pierwotnie planowalem.
Kazdy rozdzial bede wysylal w osobnym poscie. Ponizej zalaczam spis tresci
odnoszacy sie do tego, co napisalem do tej pory:
1. JEZYK SCHEME -- KROTKIE OMOWIENIE
1.1 EWALUACJA WYRAZEN
1.2 FORMY SPECJALNE
1.2.1 FORMA "quote"
1.2.2 FORMA "lambda"
1.2.3 FORMA "define"
1.2.4 FORMA "if"
1.2.5 FORMA "set!"
1.2.6 FORMA "begin"
1.3 FUNKCJE WBUDOWANE
1.3.1 FUNKCJA "apply"
1.3.2 FUNKCJE "values" i "call-with-values"
1.3.3 FUNKCJE "cons", "car" i "cdr"
1.3.4 PREDYKATY POROWNUJACE: "=", "<", "<=", ">", ">=", "eq?"
1.3.5 UWAGI O FUNKCJI "call-with-current-continuation" ("call/cc")
2. POTRZEBA NOWYCH FORM SPECJALNYCH
2.1 UWAGI WSTEPNE
2.2 ZMIENNE LOKALNE -- FORMA "let"
2.3 LOGICZNE SPOJNIKI "and" i "or"
2.4 FORMA SPECJALNA "cond"
2.5 PETLA "while" ORAZ FUNKCJA "call/cc"
2.6 INNE FORMY SPECJALNE
3. MAKRA PROCEDURALNE (define-macro)
3.1 DEFINICJA FORMY "let"
3.1.1 PRELIMINARIA -- ZWYKLA FUNKCJA TRANSFORMUJACA LISTE
3.1.1.1 DEKONSTRUKCJA LISTY WEJSCIOWEJ
3.1.1.2 KONSTRUKCJA FORMY WYJSCIOWEJ
3.1.2 DEFINICJA MAKRA
3.1.2.1 SPECJALNA SKLADNIA DO BUDOWANIA LIST -- FORMA "quasiquote"
3.2 DEFINICJA SPOJNIKOW LOGICZNYCH "or" i "and"
3.3 DEFINICJA FORMY "cond"
3.4 DEFINICJA FORMY "while"
Tekst jest sformatowany zgodnie z wytycznymi trybu ORG dla emacsa.
Fragmenty kodu/ewaluacji rozpoczynam ciagiem znakow ": ", poniewaz
niektore programy usuwaja biale znaki na poczatku linii podczas wyswietlania.
Symbol "===>" nalezy czytac jako "ewaluuje sie do".
Po ukonczeniu wszystkich rozdzialow wrzuce linke do PDFa. Jezeli ktos
bylby zainteresowany, moge tez gdzies wrzucic wygenerowanego PDFa z tym,
co napisalem do tej pory.
Bede wdzieczny za wszelkie pytania, uwagi i komentarze.
Następne wpisy z tego wątku
- 09.11.14 14:12 g...@g...com
- 09.11.14 14:34 g...@g...com
- 09.11.14 14:38 g...@g...com
- 09.11.14 16:28 JDX
- 09.11.14 17:39 g...@g...com
- 09.11.14 19:04 JDX
- 09.11.14 19:52 firr
- 09.11.14 20:08 g...@g...com
- 09.11.14 20:28 g...@g...com
- 09.11.14 20:35 firr
- 09.11.14 20:52 A.L.
- 09.11.14 21:51 g...@g...com
- 09.11.14 22:05 g...@g...com
- 09.11.14 22:51 Jordan Szubert
- 09.11.14 22:58 g...@g...com
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-03-15 przegląd za mną
- 2025-03-15 Na co komu okna
- 2025-03-15 Mój elektryk
- 2025-03-15 Fejk muzyczny czy nie fejk
- 2025-03-15 China-Kraków => Senior PHP Symfony Developer <=
- 2025-03-15 Wrocław => Konsultant wdrożeniowy Comarch XL (Logistyka, WMS, Produk
- 2025-03-15 Błonie => Analityk Systemów Informatycznych (TMS SPEED) <=
- 2025-03-15 Warszawa => Senior Frontend Developer (React + React Native) <=
- 2025-03-15 Warszawa => Java Full Stack Developer (Angular2+ experience) <=
- 2025-03-15 Warszawa => Java Full Stack Developer (Angular2+) <=
- 2025-03-15 KOMU w RP3 pasuje "Rumuńska łatwość gmerania w wyborach" i dlaczego nie PO-Trzaskanym?
- 2025-03-15 China-Kraków => Key Account Manager IT <=
- 2025-03-14 Spalił się autobus :-)
- 2025-03-14 Policjanci z Piątku
- 2025-03-14 Lublin => JavaScript / Node / Fullstack Developer <=