Witaj Gościu! ( Zaloguj | Rejestruj )

Forum PHP.pl

 
Reply to this topicStart new topic
> PEAR - tak czy nie?, Plusy i minusy projektu PEAR
Fipaj
post
Post #1





Grupa: Zarejestrowani
Postów: 691
Pomógł: 0
Dołączył: 19.01.2005
Skąd: Warszawa

Ostrzeżenie: (0%)
-----


Cześć! (IMG:http://forum.php.pl/style_emoticons/default/smile.gif)

Ostatnio zainteresowałem się PEAR-em (z powodu kilku ciekawych pakietów). Do tej pory miałem o projekcie dobre zdanie - ogromna baza rozbudowanych, dobrze napisanych i zorganizowanych klas. Wiedziałem, że takie coś jest po prostu niezbędne, aby "zjednoczyć" świat programistów php ;-) Dziwiłem się też, dlaczego PEAR nie jest lubiany...

No, teraz już wiem (IMG:http://forum.php.pl/style_emoticons/default/smile.gif)

Wg. mnie pierwszym grzechem PEAR jest wykorzystanie PHP4. Rozumiem, że projekt powstał w dobie czwórki, ale mamy czasy piątki, która przecież nasz światek ździebko zrewolucjonizowała. A już na pewno otworzyła przed autorami klas PEAR nowe, ogromne możliwości. W obecnej chwili jedynym rozwiązaniem jest przepisanie wszystkich pakietów na PHP5.

Drugi grzech - instalator. Tak, bardzo fajne narzędzie, zwłaszcza, że od niedawna można stawiać własne serwery (czy jakoś tak to się nazywa...), no, wiecie o co chodzi (IMG:http://forum.php.pl/style_emoticons/default/smile.gif) Nie, trudno, że instalacja jednego pakietu trwa 10 minut - to jakoś przeżyjemy. Mnie najbardziej denerwują zależności.

Nie, to nie tak, że klasy muszą być niezależne. Ale powiedzmy, że mi starczy sam pakiet Services_Technorati. Ale nie, ja jeszcze muszę pobrać XML_Serializer (i to oczywiście nie wszystko!). Wydaje mi się, że już lepiej zaadoptować tylko te potrzebne funkcje XML_Serializera (bo to przecież ogromna klasa) w Services_Technorati. Nie, nie wydaje mi się. Ja jestem pewien (IMG:http://forum.php.pl/style_emoticons/default/smile.gif)

I tak dalej, i tak dalej... a więc co z tym PEAR-em? Warto wykorzystywać go we własnych projektach, a może pisać od zera? Zawsze pozostaje też wykorzystanie produktów konkurencji (eZ components) bądź... Zenda (ostatnio rozpoczęła się bitwa o Zend Frameworka - ponoć ten powiela klasy PEAR-a (IMG:http://forum.php.pl/style_emoticons/default/biggrin.gif) )... Co o tym sądzicie?
Go to the top of the page
+Quote Post
Ludvik
post
Post #2





Grupa: Przyjaciele php.pl
Postów: 698
Pomógł: 3
Dołączył: 28.03.2004
Skąd: Wrocław

Ostrzeżenie: (0%)
-----


Co do implementacji w php 4, to racja. Sama obsługa błędów jest tragiczna.

Zależności między pakietami muszą być, a powielanie rozwiązań nie jest najlepszym pomysłem. Sam w swoim frameworku mam zależności (czasami jeden pakiet wymaga trzech mniejszych), bo po prostu nie da się tego włączyć do jednego pakietu. Po to mamy programowanie obiektowe, żeby nie musieć kopiować kodu i powielać błędów, a potem się męczyć z ich znalezieniem. Tak czy innaczej klasy nie powinny być za duże...
Go to the top of the page
+Quote Post
Radarek
post
Post #3





Grupa: Zarejestrowani
Postów: 188
Pomógł: 0
Dołączył: 23.05.2005

Ostrzeżenie: (0%)
-----


Gdyby nie fakt, że php za każdym razem musi przemielić te x linii kodu to nie byłoby przejmowania się, czy implementacja klasy zajmuje tyle czy tyle. php powinien posiadać jakiś kod pośredni (bytecode), który po skompilowaniu zawierałby tylko tą część implementacji, która została użyta w programie (i tak jak napisałem, nikt nie przejmowałby się czy przypadkiem klasa nie jest zbyt duża).
Go to the top of the page
+Quote Post
Ludvik
post
Post #4





Grupa: Przyjaciele php.pl
Postów: 698
Pomógł: 3
Dołączył: 28.03.2004
Skąd: Wrocław

Ostrzeżenie: (0%)
-----


Ma, ale jeszcze w stadium eksperymentalnym. bcompiler" title="Zobacz w manualu php" target="_manual
Dodatkowo masz jeszcze optymalizatory, które przetrzymują kod zenda w pamięci, więc o parsowanie nie musisz się martwić specjalnie.

PEAR raczej nie z tego powodu jest mało popularny.

Ten post edytował Ludvik 27.06.2006, 22:10:43
Go to the top of the page
+Quote Post
splatch
post
Post #5





Grupa: Zarejestrowani
Postów: 487
Pomógł: 7
Dołączył: 7.01.2004
Skąd: Warszawa

Ostrzeżenie: (0%)
-----


Cytat(Fipaj @ 27.06.2006, 21:47 ) *
Cześć! (IMG:http://forum.php.pl/style_emoticons/default/smile.gif)

Ostatnio zainteresowałem się PEAR-em (z powodu kilku ciekawych pakietów). Do tej pory miałem o projekcie dobre zdanie - ogromna baza rozbudowanych, dobrze napisanych i zorganizowanych klas. Wiedziałem, że takie coś jest po prostu niezbędne, aby "zjednoczyć" świat programistów php ;-) Dziwiłem się też, dlaczego PEAR nie jest lubiany...

No, teraz już wiem (IMG:http://forum.php.pl/style_emoticons/default/smile.gif)

Wg. mnie pierwszym grzechem PEAR jest wykorzystanie PHP4. Rozumiem, że projekt powstał w dobie czwórki, ale mamy czasy piątki, która przecież nasz światek ździebko zrewolucjonizowała. A już na pewno otworzyła przed autorami klas PEAR nowe, ogromne możliwości. W obecnej chwili jedynym rozwiązaniem jest przepisanie wszystkich pakietów na PHP5.

Powstaje PEAR 2.0, który jest pisany pod php, ale we większości pakietów mamy "php 4 and 5" ale jest to jeden wielki znak zapytania, ponieważ teraz Zend tworzy ZF, który ma własne komponenty.. chyba, że z PEARa zostanie sam instalator?

Cytat(Fipaj @ 27.06.2006, 21:47 ) *
Drugi grzech - instalator. Tak, bardzo fajne narzędzie, zwłaszcza, że od niedawna można stawiać własne serwery (czy jakoś tak to się nazywa...), no, wiecie o co chodzi (IMG:http://forum.php.pl/style_emoticons/default/smile.gif) Nie, trudno, że instalacja jednego pakietu trwa 10 minut - to jakoś przeżyjemy. Mnie najbardziej denerwują zależności.

Nie, to nie tak, że klasy muszą być niezależne. Ale powiedzmy, że mi starczy sam pakiet Services_Technorati. Ale nie, ja jeszcze muszę pobrać XML_Serializer (i to oczywiście nie wszystko!). Wydaje mi się, że już lepiej zaadoptować tylko te potrzebne funkcje XML_Serializera (bo to przecież ogromna klasa) w Services_Technorati. Nie, nie wydaje mi się. Ja jestem pewien (IMG:http://forum.php.pl/style_emoticons/default/smile.gif)

Jeśli dobrze pamiętam instalacja trwa tak długo ponieważ PEAR ściąga paczkę, rozpakowywuje ją i przenosi pliki wg package.xml. U mnie rekordowa była instalacja php Documentatora na starym kompie - 30 minut i użycie procesora na 100%.
Co do zależności:
Kod
pear install --alldeps kanał/pakiet


Cytat(Fipaj @ 27.06.2006, 21:47 ) *
I tak dalej, i tak dalej... a więc co z tym PEAR-em? Warto wykorzystywać go we własnych projektach, a może pisać od zera? Zawsze pozostaje też wykorzystanie produktów konkurencji (eZ components) bądź... Zenda (ostatnio rozpoczęła się bitwa o Zend Frameworka - ponoć ten powiela klasy PEAR-a (IMG:http://forum.php.pl/style_emoticons/default/biggrin.gif) )... Co o tym sądzicie?

Z PEARa najlepszy jest instalator. (IMG:http://forum.php.pl/style_emoticons/default/winksmiley.jpg) Z klas, które są na necie nie korzystam - instaluje przez to symfony, agavi, propela, creole, phinga. Szybko i wygodnie, bez walonki i rzemiosła.
Na pewno części rzeczy nie warto pisać od nowa, odpowiedź na pytanie "kiedy" już zależy od konkretnej sytuacji.
Go to the top of the page
+Quote Post
Fipaj
post
Post #6





Grupa: Zarejestrowani
Postów: 691
Pomógł: 0
Dołączył: 19.01.2005
Skąd: Warszawa

Ostrzeżenie: (0%)
-----


splatch: nie chodzi mi o to, że nie umiem zależności pobrać (IMG:http://forum.php.pl/style_emoticons/default/smile.gif) Po prostu są projekty, w których liczy się każdy kilobajt kodu, a klasy PEAR-a są zwykle tak rozbudowane, że 5 czy 10 klas zajmuje... no, dużo zajmuje. Miejsca na dysku. (IMG:http://forum.php.pl/style_emoticons/default/smile.gif)

Dochodzę do wniosku, że warto używać Zend Frameworka, którego klasy napisane są w standardach PEAR, tylko dla PHP5, i mają dobrą dokumentację. (I są JESZCZE względnie proste.)

A jednak gdzieś w głowie rodzi mi się pomysł zebrania kilku osób i napisania takiej podstawowej namiastki PEAR-a - proste, potrzebne klasy, bez instalatora, etc... (IMG:http://forum.php.pl/style_emoticons/default/smile.gif)

@ActivePlayer: ale my i tak nie bylibyśmy w stanie zgromadzić ekipy dorównującej PEAR-owi, a więc "przeładowanie klas" nam nie grozi (IMG:http://forum.php.pl/style_emoticons/default/smile.gif)

Ten post edytował Fipaj 28.06.2006, 07:56:20
Go to the top of the page
+Quote Post
ActivePlayer
post
Post #7





Grupa: Przyjaciele php.pl
Postów: 1 224
Pomógł: 40
Dołączył: 6.07.2004
Skąd: Wuppertal

Ostrzeżenie: (0%)
-----


Cytat
A jednak gdzieś w głowie rodzi mi się pomysł zebrania kilku osób i napisania takiej podstawowej namiastki PEAR-a - proste, potrzebne klasy, bez instalatora, etc... smilingsmiley.gif


Moge sie mylić ale pear chyba kiedys tez mial zalozenie zgromadzis proste, potrzebne klasy w jednym miejscu (IMG:http://forum.php.pl/style_emoticons/default/smile.gif)
Go to the top of the page
+Quote Post
nasty
post
Post #8





Grupa: Zarejestrowani
Postów: 634
Pomógł: 14
Dołączył: 27.05.2006
Skąd: Berlin

Ostrzeżenie: (0%)
-----


Mi sie wydaje ze pear to jest chyba jak narazie najlepszy zbior klas php w internecie, a co do tego ze sa w php4, to chyba wlasnoreczne przeobienie jednej klasy na php5 nie powinno zajac ci wiecej nic 20 minut, a co do predkosci dzialania to :
Cytat
Ma, ale jeszcze w stadium eksperymentalnym. bcompiler
Dodatkowo masz jeszcze optymalizatory, które przetrzymują kod zenda w pamięci, więc o parsowanie nie musisz się martwić specjalnie.
Go to the top of the page
+Quote Post
Fipaj
post
Post #9





Grupa: Zarejestrowani
Postów: 691
Pomógł: 0
Dołączył: 19.01.2005
Skąd: Warszawa

Ostrzeżenie: (0%)
-----


nasty_psycho, no więc właśnie nie chodzi o przerobienie jednej klasy na PHP5, tylko jej wszystkich zależności... Ale to nie chodzi o przepisywanie klasy na PHP5.

PEAR pod PHP5 pójdzie, a zmiana PHP4 -> PHP5 to nie tylko zamiana wszystkich var na public. (IMG:http://forum.php.pl/style_emoticons/default/smile.gif) Już wolę od nowa napisać całą klasę niż przepisywać PEAR na php 5 (IMG:http://forum.php.pl/style_emoticons/default/winksmiley.jpg)
Go to the top of the page
+Quote Post
nasty
post
Post #10





Grupa: Zarejestrowani
Postów: 634
Pomógł: 14
Dołączył: 27.05.2006
Skąd: Berlin

Ostrzeżenie: (0%)
-----


Cytat
PEAR pod PHP5 pójdzie, a zmiana PHP4 -> PHP5 to nie tylko zamiana wszystkich var na public. smilingsmiley.gif Już wolę od nowa napisać całą klasę niż przepisywać PEAR na php 5 winksmiley.jpg

No wiec czmu sie przejmujesz ze to php4 ? (IMG:http://forum.php.pl/style_emoticons/default/winksmiley.jpg)
Ja pisze wlasnie cms-a w ktorym jest sporo PEAR-a caly projekt jest w php5, i wszystko bardzo ladnie chodzi...

Ten post edytował nasty_psycho 28.06.2006, 08:14:27
Go to the top of the page
+Quote Post
Fipaj
post
Post #11





Grupa: Zarejestrowani
Postów: 691
Pomógł: 0
Dołączył: 19.01.2005
Skąd: Warszawa

Ostrzeżenie: (0%)
-----


nasty_psycho: PHP5 oferuje ogromne możliwości jeśli chodzi o obiekty (oj, jak to czyta jakiś programista SmallTalk/Java, to mi się dostanie (IMG:http://forum.php.pl/style_emoticons/default/biggrin.gif) ), które aż proszą się o użycie w niektórych pakietach PEAR. PHP4 i obiekty to skrajna prowizorka...

OBECNIE pisanie aplikacji pod PHP4 (jeśli nie wymaga tego klient) jest głupie (IMG:http://forum.php.pl/style_emoticons/default/smile.gif)

BTW, najnowsze pakiety PEAR lecą już na PHP5...?
Go to the top of the page
+Quote Post
nasty
post
Post #12





Grupa: Zarejestrowani
Postów: 634
Pomógł: 14
Dołączył: 27.05.2006
Skąd: Berlin

Ostrzeżenie: (0%)
-----


Cytat
BTW, najnowsze pakiety PEAR lecą już na PHP5...?

Tak, sa juz pewne pakiety przerabiane na php 5 :
LINK

Ten post edytował nasty_psycho 28.06.2006, 08:36:20
Go to the top of the page
+Quote Post
br-design.pl
post
Post #13





Grupa: Zarejestrowani
Postów: 44
Pomógł: 1
Dołączył: 30.05.2006
Skąd: Gdańsk

Ostrzeżenie: (0%)
-----


Jak dla PEAR jest very Ok, a zależności to akurat wielki plus tego pakietu. Ma dobrą dokumentacje, dobre klasy "na każdy ból" i w sumie nie zaczeło mi jeszcze przeszkadzać że są napisane dla php4. ale jak kto mówi co kto woli, chociaż to własnie w php jest najgorsze, że jest tyle rozwiązań że każdy swój problem rozwiązuje na swój własny sposób kożystając z wielu różnych reporytoriów, lub tak jak ktoś wyżej napisał, piszę swoję własne repozytorium. No i na końcu się okaże że na jedno programiste przypadnie jedno repozytorium ;-)
Go to the top of the page
+Quote Post
bigZbig
post
Post #14





Grupa: Zarejestrowani
Postów: 740
Pomógł: 15
Dołączył: 23.08.2004
Skąd: Poznań

Ostrzeżenie: (0%)
-----


Jesli nie chcesz powielac kodu zaleznosci sa nieuniknione. Ludziska pisza klasy z zalozenia uniwersalne. Czesto niestety powstaja zaleznosci w ktorych do poprawnego dzialania jednej z klas potrzebna jest pojedyncza metoda innej klasy, ale musisz ja dolaczyc w calosci - jest to kompromis pomiedzy specjalizacja i optymalizacja a uniwersalnoscia i wygoda. Ja osobiscie jednak nie korzystam z dobrodziejstw "gruszki".
Go to the top of the page
+Quote Post
Cysiaczek
post
Post #15





Grupa: Moderatorzy
Postów: 4 465
Pomógł: 137
Dołączył: 26.03.2004
Skąd: Gorzów Wlkp.




To czy PEAR jest napisany w PHP4, czy PHP5 ma mniejsze znaczenie od jego użyteczności. Zasada użycia jest prosta - nie chcesz lub nie możesz pisac sam jakiegoś kodu? Użyj PEAR i po problemie. Jeśli chcesz natomiast się sprawdzić w programowaniu, to napisz wlasne pakiety. Proste - dla każdego coś dobrego (IMG:http://forum.php.pl/style_emoticons/default/laugh.gif)
Go to the top of the page
+Quote Post
acztery
post
Post #16





Grupa: Zarejestrowani
Postów: 945
Pomógł: 7
Dołączył: 15.03.2005
Skąd: katowice

Ostrzeżenie: (0%)
-----


PEAR to znakomity zbiór klass itp mi się bardzo podoba i nie wyobrażam sobie programowania bez tego.

prawie wszyscy z tego korzystają. No i nie ma nić lepszego ni Db_DataObject a to wchodzi w sklad pakietow pear
Go to the top of the page
+Quote Post
mike
post
Post #17





Grupa: Przyjaciele php.pl
Postów: 7 494
Pomógł: 302
Dołączył: 31.03.2004

Ostrzeżenie: (0%)
-----


Moim zdaniem PEAR śmietnik, dosłownie kilka klas jest napisanych w pożądku reszta to kmioty.
Kod tragiczny i bardzo stary.

Jedyne co dobre w PEAR to instalator i linia komend.
Go to the top of the page
+Quote Post
bigZbig
post
Post #18





Grupa: Zarejestrowani
Postów: 740
Pomógł: 15
Dołączył: 23.08.2004
Skąd: Poznań

Ostrzeżenie: (0%)
-----


Cytat(mike_mech @ 24.07.2006, 15:34 ) *
Jedyne co dobre w PEAR to instalator i linia komend.

Czyli mile dla admina nie dla programisty, a że ja raczej programuje niż administruje więc z PEAR nie korzystam bo dla mnie to kocioł.
Go to the top of the page
+Quote Post
nazihipi
post
Post #19





Grupa: Zarejestrowani
Postów: 139
Pomógł: 0
Dołączył: 14.07.2006

Ostrzeżenie: (10%)
X----


z PEAR'a korzystam jedynie z pakietu DB (teraz MDB2 bo wchłonął DB i to on jest dalej rozwijany). Od dawna z nim pracuje i nie miałem większych problemów, komatybilny z php5. Denerwującą rzeczą są jednak duże rozmiary pakietów, które jak tu już wspominają wynikają gł. z dość dużego kotła w kodzie, a więc modyfikacja jest trudna i mozolna.. Obecnie szukam zastępczych rozwiązań, ale póki co stary jary PEAR (IMG:http://forum.php.pl/style_emoticons/default/smile.gif)
Go to the top of the page
+Quote Post

Reply to this topicStart new topic
2 Użytkowników czyta ten temat (2 Gości i 0 Anonimowych użytkowników)
0 Zarejestrowanych:

 



RSS Aktualny czas: 23.08.2025 - 04:22