-
Path: news-archive.icm.edu.pl!news.gazeta.pl!not-for-mail
From: Edek Pienkowski <e...@g...com>
Newsgroups: pl.comp.programming
Subject: Re: jezyki z definiowaniem operatorow
Date: Wed, 16 May 2012 18:12:14 +0000 (UTC)
Organization: "Portal Gazeta.pl -> http://www.gazeta.pl"
Lines: 127
Message-ID: <jp0qlu$mfe$9@inews.gazeta.pl>
References: <jou2mq$cm2$1@inews.gazeta.pl> <joueua$ja8$1@inews.gazeta.pl>
<joun6e$mfe$7@inews.gazeta.pl> <jour3i$f3d$1@inews.gazeta.pl>
<jovtou$mfe$8@inews.gazeta.pl>
<8...@s...googlegroups.com>
NNTP-Posting-Host: static-81-219-27-34.devs.futuro.pl
Mime-Version: 1.0
Content-Type: text/plain; charset=UTF-8
Content-Transfer-Encoding: 8bit
X-Trace: inews.gazeta.pl 1337191934 23022 81.219.27.34 (16 May 2012 18:12:14 GMT)
X-Complaints-To: u...@a...pl
NNTP-Posting-Date: Wed, 16 May 2012 18:12:14 +0000 (UTC)
X-User: pieniekusenet
User-Agent: Pan/0.135 (Tomorrow I'll Wake Up and Scald Myself with Tea; GIT 30dc37b
master)
Xref: news-archive.icm.edu.pl pl.comp.programming:197277
[ ukryj nagłówki ]Dnia Wed, 16 May 2012 09:18:30 -0700, Andrzej Jarzabek napisal:
> On May 16, 10:58 am, Edek Pienkowski <e...@g...com>
> wrote:
>> Dnia Wed, 16 May 2012 01:07:12 +0100, Andrzej Jarzabek napisal:
>>
>> > On 16/05/2012 00:00, Edek Pienkowski wrote:
>> >> Dnia Tue, 15 May 2012 21:39:36 +0100, Andrzej Jarzabek napisal:
>>
>> >> Tak więc w językach znanych przez kolegę "pierwszeństwo i stronność... "
>> >> - no, mądre słowo - "są określane przez gramatykę". Ale kolega ma świadomość
>> >> istnienia języków funkcyjnych. Hmm.
>>
>> > I?
>>
>> >> A gdyby tak powiedzieć, że nie musi tego określać gramatyka i że to byt
>> >> określa świadomość?
>>
>> > Jeśli kolega ma do npisania coś konkretnego, to może kolega napisać, nie
>> > wykluczam nawet, że z ciekawości przeczytam.
>>
>> Jakiś konkret do którego można się odnieść by się przydał, nie wiem co
>> miałoby być konkretem.
>
> No proszę bardzo: chcę sobie zdefiniować operatory, powiedzmy, @ i #,
> powiedzmy w ten sposób, żeby (a @ b # c) parsowało się jako a @ (b #
> c), (a @ b @ c) jako (a @ b) @ c, a (a # b # c) jako a # (b # c).
> Oczywiście mam też szczegółowe wymagania co do tego, jak powinny się
> parsowac (a + b @ c), (a # b * c) i tak dalej. Niech kolega da
> konkretny przykład języka, w którym można to zrobić i napisze jak jest
> to rozwiązane w kwestii gramatyki języka i budowy kompilatora.
Przykładem takiego języka jest Ocaml, mozna tam defniować własne operatory
a pierwszeństwo zależy od pierwszej litery operatora a chyba w innej
wersji od deklaracji ze specjalną składnią. Ale to nie jest najlepszy
przykład; może lepsza byłaby Scala, ale nie pamiętam czy da się
definiować własne operatory right-associative.
Jakikolwiek język homoikoniczny pozwoliłby na to, o ile dałoby się
nie używać eval a mieć Listener przed wykonaniem, ale na etapie kompilacji
nie byłoby to rozwiązanie silnie typowane.
Teoretycznie:
powiedzmy że chcemy mieć język silnie typowany i mamy wyrażenie
a ble b ble c bli (d ble c)
Mamy też tablicę symboli a parser stworzy coś takiego
<expr>
/
[a,ble,b,ble,c,bli,<parenthised-expr>]
/
[d,ble,c]
gdzie [a,b,c] jest listą a to co pominąłem to fakt że wszystko w tych
listach jest akurat tutaj symbolami poza <parenthised-expr> potrzebną
do odrzuconej później ewentualności potraktowania bli jako funkcji
jednego argumentu.
Z tablicy symboli wiemy że a, b i c to dane typu BleInt, a ble i bli
(może po Koenig lookup) są czymś takiego rodzaju:
infix ble @right @prec(4) (BleInt a, BleInt b) -> BleInt = a * 2 + b;
infix bli @left @prec(3) (BleInt a, BleInt b) -> BleInt = a * 3 + b;
...gdzie wnioskując ze Scali słówko 'infix' można w ogóle pominąć
lub zastąpić jak w Scali przez 'def', czyli dowolną funkcję lub metodę.
Wtedy przekształca się drzewo, [d,ble,c] staje się
<call>(returns BleInt)
/ \
ble <params>
/ \
d c
i po przkształceniach drzewa wyrażenie staje się zwykłym:
ble(a, ble(b, bli(c, ble(d,c))))
na zupełnie jednoznaczych regułach, gdzie niższy @prec ma wyższy priorytet
i stosowane są reguły left i right. Mamy też silne typowanie.
Jakiś problem, tak konkretnie?
Zostają jeszcze bardziej skomplikowane reguły dot. promocji typów,
ale istnieją języki, gdzie można reguły promocji definiować wprost.
>
>> >>> Ze swobodnym definiowaniem operatorów problem jest taki, że ich
>> >>> pierwszeństwo i stronność są określone gramatyką języka. Zmienianie tego
>> >>> na bieżąco przy pomocy samego programu w tym języku wydaje się
>> >>> problematyczne - być może, że wręcz prowadzi do nierozwiązywalnych
>> >>> problemów, a na pewno standardowy model skaner-parser-translacja trafiłby
>> >>> szlag.
>>
>> Z OO ma to dwa rodzaje związku. Pierwszy: tak jest w większości popularnych
>> języków obiektowych, ale nie wynika to z niczego, jest szczegółem
>> implementacyjnym.
>
> Jest tak chyba również w większości popularnych języków
> nieobiektowych, przynajmniej tych, w których w ogóle są operatory
> infiksowe? Statystyki nie prowadziłem, ale na dzień dobry tak ma C,
> Pascal, Perl, PHP, SQL, Fortranie, Lua i czym tam jeszcze.
Nic nie wiem o tym, żeby w C czy SQL można było przeciążać operatory.
>
>> Parser gcc zamienia niektóre (x-x) na odpowiedniego typu
>> zero, ale to nie znaczy że musi to robić akurat parser, późniejsze stadia
>> mogą implementować taki folding. Podobnie jest z operatorami, można już po
>> parsowaniu przekształcić graf składni.
>
> Pewnie że można, pytanie - jak i na podstawie czego?
>
> BTW przypomniało mi się: W Groovym oprócz normalnego definiowania
> operatorów, można również wprowadzić lokalne i globalne transformacje
> drzew składniowych, które potencjalnie mogą właśnie przekształcić
> sparsowane drzewko. Teoretycznie możnaby się zastanawiać nad użyciem
> tego do zmiany pierwszeństwa i stronności operatorów, a nawet
> wprowadzania nowych, ale wydaje mi się, że byłoby to raczej trudne.
Transformacje drzewa - o ile drzewo jest wyrażeniem - można przeprowadzić
nawet w C++ podczas kompilacji, oczywiście używając programowania
generycznego. Również zamieniając pierwszeństwo operatorów i/lub
stronność, z tym że trywialne to to nie jest.
Edek
Następne wpisy z tego wątku
- 16.05.12 22:10 Michał Politowski
- 16.05.12 22:32 Andrzej Jarzabek
- 17.05.12 09:35 Maciej Sobczak
- 17.05.12 10:00 Roman W
- 17.05.12 10:09 Stachu 'Dozzie' K.
- 17.05.12 11:46
- 17.05.12 11:51
- 18.05.12 09:55 Maciej Sobczak
- 18.05.12 10:00 Roman W
- 18.05.12 12:36 KO
- 18.05.12 14:54
- 18.05.12 18:34
Najnowsze wątki z tej grupy
- 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??
- Re: (PDF) Surgical Pathology of Non-neoplastic Gastrointestinal Diseases by Lizhi Zhang
- CfC 28th Ada-Europe Int. Conf. Reliable Software Technologies
- Młodzi programiści i tajna policja
Najnowsze wątki
- 2024-12-18 Wrocław => Application Security Engineer <=
- 2024-12-18 Warszawa => Key Account Manager <=
- 2024-12-18 Alternatywny nośnik do monitoringu zamiast HDD?
- 2024-12-17 Rodzaj przekładni planetarnej z
- 2024-12-17 Z instrukcji do kitu
- 2024-12-17 Re: W telefonie brak szufladki na drugą kartę SIM
- 2024-12-17 nie wyrzucaj starych opon
- 2024-12-17 znów elektryk:P
- 2024-12-17 "Ręczny" a przegląd.
- 2024-12-17 Warszawa => Senior Frontend Developer (React + React Native) <=
- 2024-12-17 Warszawa => Fullstack Developer <=
- 2024-12-17 Warszawa => Starszy Konsultant AWS <=
- 2024-12-17 Kraków => Full Stack .Net Engineer <=
- 2024-12-17 Kraków => Programista Full Stack (.Net Core) <=
- 2024-12-17 Kraków => Software .Net Developer <=