-
Data: 2020-06-07 21:46:34
Temat: Re: Embedded HTTP Server
Od: Maciej Sobczak <s...@g...com> szukaj wiadomości tego autora
[ pokaż wszystkie nagłówki ]> Niby tak, ale już cooperative tak nie obskoczysz.
I naiwna abstrakcja wątków też by mi tego nie dała.
> Ponadto praktyka pozkauje że zmiana "jednej linijki" w biblitece nie
> jest prawidłową metodą dopasowania się do czegoś bo za chwile tej
> linijki nie będzie w wersji 0.9.3.
I tu płynnie przechodzimy do pytania o to, gdzie jest właściwy poziom abstrakcji. Bo
Ty chciałbyś, żeby w bibliotece HTTP była abstrakcja wątków na wypadek portowania na
inną platformę. A ja pytam, dlaczego cały serwer HTTP nie miałby być tą abstrakcją, z
różnymi implementacjami na różne platformy?
Cała ta biblioteka ma dokładnie 2 pliki .cpp. Słownie: dwa. Plus 2 headery do nich. I
działa na Lin/Mac/Win. Dołożenie do niej abstrakcji na okoliczność egzotycznych
platform wbudowanych z pół-wątkami i dziwacznymi stosami TCP spowodowałoby, że tych
plików byłoby 10. Albo 30.
I nawet nie wiem, jaka jest realna nisza rynkowa z takimi potrzebami i czy ona w
ogóle jest. Bo nisza na wersję 1.0 jest na pewno, bo w szczególności ja sam tego
użyję. Natomiast te abstrakcje rozwiązałyby problem ludzi o których nawet nie wiem,
czy istnieją.
A nie lepiej poczekać, aż ktoś *realnie* zgłosi taką potrzebę i wtedy zrobić port
tych dwóch plików z zachowaniem API całego serwera HTTP? I wtedy taki port też będzie
miał 2 pliki .cpp. I ani kawałka kodu więcej.
Tak, będzie parę linijek zduplikowanych. Ale przekonaj mnie teraz, że koszt tych
wszystkich abstrakcji jest mniejszy.
> To tylko łatwo w teorii, w normalnych systemach "podmienianie"
> std::whatever to jest *gruby* hacking...
Ale przecież nie pisałeś o normalnych systemach. :-)
Na normalnych to wszystko działa out-of-the-box i nie trzeba nic hacking.
> Niby tak, ale znowu: co dziwnego w tym że robisz własną abstrakcję do
> "ich" abstrakcji?
A co dziwnego w tym, że ich nie robię i zamiast tego proponuję minimalne rozwiązanie
dla 99.9% potencjalnych odbiorców?
> Piszesz rdzeń HTTP w oderwaniu kompletnym od tego jaki stos TCP używasz.
Przecież tak jest teraz. Dlatego są tam dwa pliki .cpp. Jeden to rdzeń HTTP a drugi
to IOStreams na "typowym" stosie TCP.
> *wszystkie* interfejsy GUI jakie istnieją w sensownym zastosowaniu są
> event-based czyli takie coroutines/cooperative.
To ciekawa uwaga. W tej bibliotece nie ma na wierzchu niczego podobnego do kolejki, a
co za tym idzie nie zmusza się użytkownika do kręcenia własną pętlą zdarzeń. Pod tym
względem ta biblioteka bardziej przypomina lekki framework komunikacyjny, niż typowy
framework GUI. Ale to dobry zbieg okoliczności, bo akurat HTTP jest protokołem
komunikacyjnym. A kolorowe jarmarki na display'u i tak zrobisz w JS.
Czyli zamiast odpowiadać na pytanie jak zrobić GUI, odpowiadamy na pytanie, jak
zrobić komunikację z tym czymś co robi GUI[*].
[*] I bez ograniczania się tylko do tego zastosowania (chociaż GUI było motywacją).
HTTP może służyć również do innych rzeczy, niż GUI. I dlatego też to się nazywa
"Embedded HTTP Server" a nie "GUI Framework".
--
Maciej Sobczak * http://www.inspirel.com
Następne wpisy z tego wątku
- 07.06.20 23:21 heby
- 08.06.20 09:49 Maciej Sobczak
- 08.06.20 10:32 Mateusz Viste
- 08.06.20 11:39 Wojciech Muła
- 08.06.20 11:52 heby
- 08.06.20 12:25 Wojciech Muła
- 08.06.20 20:33 Maciej Sobczak
- 08.06.20 21:20 Maciej Sobczak
- 08.06.20 21:32 heby
- 08.06.20 22:43 Maciej Sobczak
- 08.06.20 23:24 heby
- 08.06.20 23:44 Maciej Sobczak
- 08.06.20 23:52 Maciej Sobczak
- 09.06.20 00:08 heby
- 09.06.20 00:22 heby
Najnowsze wątki z tej grupy
- 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
- Ada 2022 Language Reference Manual to be Published by Springer
- Press Release - AEiC 2023, Ada-Europe Reliable Softw. Technol.
- Ada-Europe - AEiC 2023 early registration deadline approaching
- Ada-Europe Int.Conf. Reliable Software Technologies, AEiC 2023
- Ile cykli zajmuje mnożenie liczb 64-bitowych?
- Ideologia Polskiego Programisty wer.3
Najnowsze wątki
- 2024-04-27 Ryby i kawitacja
- 2024-04-27 Zabrze => Junior HelpDesk <=
- 2024-04-27 Katowice => Administrator IT - Wirtualizacja i Konteneryzacja <=
- 2024-04-27 Bażanowice => Inżynier Industrializacji - Elektronik <=
- 2024-04-27 Warszawa => Full Stack web developer (obszar .Net Core, Angular6+) <=
- 2024-04-27 Zadaszenie tarasu, a wymagany spadek
- 2024-04-27 Warszawa => Senior Account Manager <=
- 2024-04-27 Wrocław => Head of Sales (IT services/products field) <=
- 2024-04-27 Gdańsk => Head of International Freight Forwarding Department <=
- 2024-04-27 wymiana ekranu w laptopie
- 2024-04-27 DC blocker i buczące toroidy
- 2024-04-26 Warszawa => Kierownik Działu Spedycji Międzynarodowej <=
- 2024-04-26 Berlin => IT Network Engineer <=
- 2024-04-26 Warszawa => Starszy inżynier oprogramowania (Rust) <=
- 2024-04-26 Warszawa => Senior PHP Developer (Symfony) <=