DevProTalk

DevProTalk (http://www.devprotalk.com/index.php)
-   PHP (http://www.devprotalk.com/forumdisplay.php?f=9)
-   -   Apsraktna klasa sa svim implementiranim metodama, kad koristiti ? (http://www.devprotalk.com/showthread.php?t=11443)

tasmaniski 23. 02. 2013. 23:53

Apsraktna klasa sa svim implementiranim metodama, kad koristiti ?
 
Pozdrav,

U magentovom coru postoji jako puno klasa koje su apstraktne, a imaju sve metode implementirane npr. a postoje takve klase i u javi npr.
Predpostavljam da je to posledica Template paterna sto je OK.

Medjutim, vidim da dosta developera proglasava klasu apstraktnom samo da bi zabranio njeno instanciranje (iako su sve metode implementirane), da li je to ispravno?
U kojim sve slucajevima treba imati apstraktnu klasu bez apstraktnih metoda i da li vi to koristite?

svlada 24. 02. 2013. 11:24

Jedina takva primena (barem u java svetu), na koju sam naišao do sada, je baš Template pattern koji navodiš.

Najpoznatiji primerak je verovatno nezaobilazna klasa HttpServlet http://www.docjar.com/html/api/javax...vlet.java.html

Ukoliko bih hteo da zabranim instanciranje neke klase, proglasio bih njen konstruktor privatnim.

tasmaniski 24. 02. 2013. 12:02

Iskreno prvi put sam se susreo sa ovim slucajem i tek sad vidim da dosta ljudi tako koristi abstrac class bez ijedne abstract metode, pa i u drugim paternima (npr. decoration).
Ali i pored toga u potpunosti mi je neprirodno da u tu svrhu koristim apstraktnu klasu.. C++ bi izbacio error ako bi pokusao da napravis abstract klasu sa svim konkretnim metodama ...


fina diskusija se razvila o tome i na:
http://www.linkedin.com/groups/We-ha...26.S.112043042

Samo mala napomena da konstruktor treba da bude protected - nije dovoljno private.. al tako bih i ja to uradio ...

svlada 28. 02. 2013. 20:46

Od kako si pokrenuo ovu temu, baš gledam hoću li naleteti u svakodnevnom radu na ovak slučaj.

I što je najgore nailazim.

Klasa iz OpenSAMLa => org.opensaml.saml2.binding.encoding.BaseSAML2Messa geEncoder

jablan 28. 02. 2013. 21:45

Nisam baš u skorije vreme radio sa PHP-om, u čemu je uopšte poenta toga da dinamički jezik ima apstraktne klase?

webarto 28. 02. 2013. 22:24

PHP nije Java.

I otkad je Magento primjer dobrog codea?

Je li želiš da budeš "Magento Expert" ili?

tasmaniski 01. 03. 2013. 10:55

Racunao sam da Magento core developeri ipak nesto znaju :)

Ne planiram da se bavim Magentom skorije, ali dosta ispitujem kakava je arhitektura ostalih open source resenja, ne bi li dobio inspiraciju i nesto upotrebio u svom sistemu/backendu.
Cesto nailazim na ovaj slucaj, pa bih voleo da cujem nekoga ko tako radi da mi objasni sto?


Jablane, mozes molimte biti malo precizniji, ti ne koristis apstraktne klase uopste ?

webarto 01. 03. 2013. 15:25

Zend Framework 2 @ Github
Kohana 3.3 @ Github

jablan 02. 03. 2013. 20:46

Citat:

Originalno napisao tasmaniski (Napišite 109970)
Jablane, mozes molimte biti malo precizniji, ti ne koristis apstraktne klase uopste ?

Pa koristim kad radim u npr. Javi, ali ne koristim kad radim u one-who-must-not-be-named jeziku, jer u istom nemaju smisla. Jezik mi ne brani da pozovem metodu koja će biti implementirana u potklasama, a ako želim da zabranim instanciranje klase, baciću exception u konstruktoru.

japan 03. 03. 2013. 13:52

Jedno pet puta već čitam pokušavajući da shvatim tvoj argument, ali mi ne uspeva. Daj, molim te, objasni mi šta hoćeš da kažeš...

Peca 03. 03. 2013. 16:38

ja sam baš skoro imao slučaj kada je za malo cela klasa mogla biti abstraktna (govorim naravno o PHP-u).
no, ispalo je da imam par funkcija koje mogu da delim sa potklasama.

trebao mi je dakle unikatan aplication interface - a potklase su bile tu jer su istu stvar implementirale preko dve različite PHP biblioteke - pa se kreirala potklasa u zavisnosti od toga koja je PHP biblioteka instalirana na sistemu.

svaki drugi koncept (koji ne bi išao preko abstrakcije) bi bio koncepcijski loš.

jablan 03. 03. 2013. 17:39

Citat:

Originalno napisao japan (Napišite 109983)
Jedno pet puta već čitam pokušavajući da shvatim tvoj argument, ali mi ne uspeva. Daj, molim te, objasni mi šta hoćeš da kažeš...

Hoću da mi neko objasni čemu služe apstraktne klase u dinamičkom jeziku kao što je PHP.

Primer:

Ti u PHP-u možeš da uradiš sledeće:

Kôd:

class Duck{
        function quack(){ echo "Quack\n";}
        function fly(){ echo "Flap, Flap\n";}
}
class Person{
        function __construct($name){$this->name=$name;}
        function quack(){echo "{$this->name} walks in the forest and imitates ducks to draw them\n";}
        function fly(){ echo "{$this->name} takes an airplane\n";}
}
 
function QuackAndFly($obj){$obj->quack(); $obj->fly();}
 
QuackAndFly(new Duck());
QuackAndFly(new Person("Jules Verne"));

Tj. ne postoji kompajler koji će da kaže koju klasu funkcija QuackAndFly mora da primi kao argument (isto važi i za npr. dodelu promenljivih, jedna ista promenljiva u jednom trenutku može držati instancu Duck, a u drugom instancu klase Person itd). Samim tim ne postoji obaveza programera da pravi klase u kojima kaže "e sad ovde će biti jedna metoda, ali neću sad da je implementiram, već će to morati da urade potklase", da bi zadovoljio kompajler, kao što postoji u statičkim jezicima tipa Jave. U Javi bi za gornji primer morao da napraviš parent apstraktnu klasu QuackableFlyableItem, koju bi onda Duck i Person nasleđivale, pa onda da kažeš da funkcija QuackAndFly prima argument tipa QuackableFlyableItem itd itd.

Dakle, interesuje me zašto je u PHP dodat feature koji je u statičkim jezicima tu samo kao nužno zlo, upravo zato što su statički?

Nadam se da sam jasniji.

japan 03. 03. 2013. 20:00

Iskreno, nisam nikad na apstraktne klase gledao kao na mehanizam za puko zadovoljenje kompajlera u ovakvim slučajevima, već više kao na pogodnost koja omogućava da se konstrukt "implemetnts Interface, extends Base" svede na "extends AbstractBase".

A što se tiče tvog primera, ako se ne varam, ni u Javi ti ne treba apstraktna roditeljska klasa, tj. dovoljno je da ona postoji, ne mora da bude apstraktna, i to će da radi, i kompajler se neće buniti, sve dok obe klase koje je nasleđuju sadrže potrebne metode. A ako hoćeš da se zaštitiš od "zloupotreba" tipa prosleđivanje ovoj QuackAndFly() f-ji objekta koji nema neki od potrebnih metoda, e tu u jednačinu ubacuješ apstraktnu klasu, i tu onda nema veze da li je jezik statički ili dinamički, i za jedne i za druge važi isto - moraju da implementiraju sve metode...

jablan 03. 03. 2013. 20:56

Citat:

Originalno napisao japan (Napišite 109988)
više kao na pogodnost koja omogućava da se konstrukt "implemetnts Interface, extends Base" svede na "extends AbstractBase".

Ali upravo to i pitam, zašto je potrebno da AbstractBase bude nešto specijalno, da zahteva specijalni keyword i specijalan thread na DPT, zašto ne može da bude obična PHP klasa koju ćeš nazvati AbstractBase ako ti baš toliko znači da to nešto bude "apstraktno".

Što se tiče primera, u Javi je neophodno da 1) postoji roditeljska klasa, i 2) da roditeljska klasa ima navedena dva metoda. Keyword abstract ti omogućava da te metode ne moraš da implementiraš (pišući prazne brejsove ili dižući exception), po cenu da samu parent klasu ne možeš da instanciraš.

PHP i drugi dinamički jezici već imaju tu pogodnost da 1) ne moraš da imaš parent klasu, a ako baš hoćeš da je imaš, 2) ne moraš da navodiš neimplementirane metode i 3) možeš da sprečiš njeno instanciranje na druge načine koji ne zahtevaju dodatno bloatovanje ionako već punačke sintakse.

japan 03. 03. 2013. 22:33

Pa šta znam, ja sam na to gledao kao na feature, kada imaš potrebu da za neku familiju odrediš zajedničku osnovu, a ne kao na bloat.

U tom slučaju jeste, ne mora da postoji, ali onda ne mora da postoji ni u statičkim jezicima, jer sve to može isto tako da se izvede upotrebom interfejsa, override-ovanja metoda, i nekom tehnikom za zabranu instanciranja.

webarto 04. 03. 2013. 00:31

@jablan
Kôd:

namespace Dpt;

abstract class Database
{
  protected $link;
  abstract public function query(string $query);
}

class Mysql extends Database
{
  public function query(string $query)
  {
    return mysql_query($query, $this->link);
  }
}

class Pdo extends Database
{
  public function query(string $query)
  {
    return $this->link->query($query);
  }
}

Kako misliš...

a.) zabraniti instanciranje?
b.) forsirati implementiranje metoda?

Kôd:

namespace Dpt;

class Database
{
  public function __construct()
  {
    trigger_error('Not allowed', E_USER_ERROR);
  }
}

class Mysql extends Database
{
  public function __construct()
  {
   
  }
 
  function query()
  {
    var_dump(func_get_args());
  }
}

(new \Dpt\Mysql)->query('Hello');

Apstraktna klasa je klasa + interface, koja se uz to ne može instancirati, ima svoju svrhu, ali mislim da se mnogo puta koristi u pogrešne svrhe.

Tvoj mi primjer nije jasan, jesi li mislio na ovo:

Kôd:

function QuackAndFly(Duck $obj){$obj->quack(); $obj->fly();}
Možeš ti u recimo PHP da uradiš sve, ali ne mora da znači da trebaš, nije ni Java sjajan primjer.

jablan 04. 03. 2013. 08:02

Citat:

Originalno napisao japan (Napišite 109990)
ne mora da postoji ni u statičkim jezicima, jer sve to može isto tako da se izvede upotrebom interfejsa, override-ovanja metoda, i nekom tehnikom za zabranu instanciranja.

Kako ne mora da postoji ni u statičkim jezicima? Ti u interfejsu ne možeš da implementiraš nijednu metodu, dakle interfejsi nisu zamena za (apstraktne) klase. Možeš, kao što sam ranije rekao, da napraviš običnu klasu sa praznim metodama, ali je ružno, ima puno boilerplatea (praznih metoda ili dizanja exceptiona itd). Apstraktne klase itekako imaju smisla u statičkim jezicima.

Ono što mi nije jasno je šta ti njima dobijaš u dinamičkom jeziku. Obične parent klase bez deklarisanih metoda sasvim dobro rade posao, zar ne?

@webarto: Upravo tako. S tim što je bacanje exceptiona u Database konstruktoru skroz opciono, jer ti praktično ništa ne dobijaš time, jedino pišeš kod za nekog morona koji bi probao da instancira Database klasu. U statičkim jezicima to opet ima smisla, jer će se greška pojaviti u compile timeu, tj. neće moći da se program iskompajlira ako neko napiše "new Database". U PHPu (ako se ne varam, ispravite me ako grešim), čak i da koristiš apstraktnu klasu, greška bi iskočila u runtimeu, tako da i ta prednost apstraktne klase koju imaš u Javi ovde ne postoji.

Takođe je i sama svrha postojanja parent klase diskutabilna (u tvom primeru nema smisla, ali hajde da pretpostavimo da te dve klase zaista imaju neku zajedničku funkcionalnost).

Sve u svemu, PHP i ostali dinamički jezici su praktično srećni zato što programer nema potrebu da piše puno koda samo da bi zadovoljio kompajler. Zato me čudi što se veštački dodaju featuresi iz statičkih jezika iako nemaju smisla i praktično ukidaju prednosti koje dinamički jezici imaju. To bi bilo kao da atletičar navuče bocu s kiseonikom od 10 kila pre trke samo zato što je video da ronioci to rade. :)

Djuki 04. 03. 2013. 10:17

Citat:

Originalno napisao jablan (Napišite 109987)
Samim tim ne postoji obaveza programera da pravi klase u kojima kaže "e sad ovde će biti jedna metoda, ali neću sad da je implementiram, već će to morati da urade potklase", da bi zadovoljio kompajler, kao što postoji u statičkim jezicima tipa Jave.

Postoji

PHP kôd:

class Vizija
{
    abstract function 
definisiViziju();
}

class 
Birokratija extends Vizija
{



Klasa Birokratija je u obavezi da implementira metodu definisiViziju inače će interpreter prijaviti grešku:

PHP kôd:

Fatal error: Class Vizija contains 1 abstract method and must therefore be declared abstract or implement the remaining methods (Vizija::definisiViziju

Što se tiče primera sa Patkom i Čovekom očigledno je da oni treba da implementiraju u najmanju ruku jedan isti interfejs (samo u tvom primeru, jer ako bismo sada išli do kraja rekli bismo da je potrebno primeniti adapter patern, jer je odličan za ovu imitaciju patke).

Webarto je krenuo u pravom smeru.
PHP kôd:

interface LeteciObjekat
{
    public function 
quack();

    public function 
fly();
}
function 
QuackAndFly(LeteciObjekat $obj){$obj->quack(); $obj->fly();} 


webarto 04. 03. 2013. 12:46

@djuki

Ako je i jedna metoda abstract onda i klasa mora biti abstract, za to je izbacilo grešku a ne za ono što si mislio.

Kôd:

abstract class Vizija
{
    abstract function definisiViziju();
}

class Birokratija extends Vizija
{

}

Citat:

Fatal error: Class Birokratija contains 1 abstract method and must therefore be declared abstract or implement the remaining methods (Vizija::definisiViziju)
@jablan mrsko mi je bilo pisati, ali zamisli da ima smisla :) Po meni ima smisla to što govoriš, i stvari kao goto i traits su implementirane, ali abstract ipak ima svoju funkciju.

Djuki 04. 03. 2013. 13:44

@webarto

U pravu si da mora biti abstraktna i klasa. Ipak važan je deo što jablan kaže da ne možemo "naterati" naslednike da implementiraju metode. Možemo naravno. Ovo što pišem radi u 5.2 verziji.

PHP kôd:

abstract class Vizija
{
    abstract function 
definisiViziju();
}

class 
Birokratija extends Vizija
{

}

$borokratija = new Birokratija(); 

ovde dobijamo grešku
PHP kôd:

Fatal error: Class Birokratija contains 1 abstract method and must therefore be declared abstract or implement the remaining methods (Vizija::definisiViziju


japan 04. 03. 2013. 16:04

PHP kôd:

abstract class Vozilo {
    
    abstract protected function 
potrebnaDozvolaZaUpravljanje ();
    abstract protected function 
brojTockova ();
    abstract protected function 
potrebnaRegistracija ();

    public function 
opis () {
        echo 
get_class($this) . " sam ja, ";
        echo 
$this->brojTockova() . " tocka imam... ";
        if (
$this->potrebnaDozvolaZaUpravljanje()) { echo "trebace ti dozvola... "; } else { echo "kakva dozvola? samo vozi!!! "; }
        if (
$this->potrebnaRegistracija()) { echo "mora da se registruje. "; } else { echo "kakva registracija, samo vozi... "; }
    }
}

abstract class 
MotornoVozilo extends Vozilo {

    public function 
potrebnaDozvolaZaUpravljanje () {
        return 
true;
    }

    public function 
potrebnaRegistracija () {
        return 
true;
    }

}

class 
Bicikl extends Vozilo {

    public function 
potrebnaDozvolaZaUpravljanje () {
        return 
false;
    }

    public function 
brojTockova () {
        return 
2;
    }

    public function 
potrebnaRegistracija () {
        return 
false;
    }

}

class 
Automobil extends MotornoVozilo {

    public function 
brojTockova () {
        return 
4;
    }

}

class 
Motorcikl extends MotornoVozilo {

    public function 
brojTockova () {
        return 
2;
    }



i po meni, jedini proper način da se to uradi bez apstraktne klase

PHP kôd:

interface iVozilo {

    public function 
potrebnaDozvolaZaUpravljanje ();
    public function 
brojTockova ();
    public function 
potrebnaRegistracija ();

}

class 
Vozilo implements iVozilo {

    public function 
__construct () {
        
trigger_error('Not allowed'E_USER_ERROR);
    }

    public function 
potrebnaDozvolaZaUpravljanje () {
        
trigger_error('Implement this'E_USER_ERROR);
    }

    public function 
brojTockova () {
        
trigger_error('Implement this'E_USER_ERROR);
    }

    public function 
potrebnaRegistracija () {
        
trigger_error('Implement this'E_USER_ERROR);
    }

    public function 
opis () {
        echo 
get_class($this) . " sam ja, ";
        echo 
$this->brojTockova() . " tocka imam... ";
        if (
$this->potrebnaDozvolaZaUpravljanje()) { echo "trebace ti dozvola... "; } else { echo "kakva dozvola? samo vozi!!! "; }
        if (
$this->potrebnaRegistracija()) { echo "mora da se registruje. "; } else { echo "kakva registracija, samo vozi... "; }
    }
}

class 
MotornoVozilo extends Vozilo {

    public function 
potrebnaDozvolaZaUpravljanje () {
        return 
true;
    }

    public function 
potrebnaRegistracija () {
        return 
true;
    }

}

class 
Bicikl extends Vozilo {
    
    public function 
__construct () {}

    public function 
potrebnaDozvolaZaUpravljanje () {
        return 
false;
    }

    public function 
brojTockova () {
        return 
2;
    }

    public function 
potrebnaRegistracija () {
        return 
false;
    }

}

class 
Automobil extends MotornoVozilo {

    public function 
__construct () {}

    public function 
brojTockova () {
        return 
4;
    }

}

class 
Motorcikl extends MotornoVozilo {

    public function 
__construct () {}

    public function 
brojTockova () {
        return 
2;
    }



e sad, istina da u dinamičkom jeziku mož da se uradi i ovako, kako ti zagovaraš:

PHP kôd:

interface iVozilo {

    public function 
potrebnaDozvolaZaUpravljanje ();
    public function 
brojTockova ();
    public function 
potrebnaRegistracija ();

}

class 
Vozilo {

    public function 
__construct () {
         
trigger_error('Not allowed'E_USER_ERROR);
    }

    public function 
opis () {
        echo 
get_class($this) . " sam ja, ";
        echo 
$this->brojTockova() . " tocka imam... ";
        if (
$this->potrebnaDozvolaZaUpravljanje()) { echo "trebace ti dozvola... "; } else { echo "kakva dozvola? samo vozi!!! "; }
        if (
$this->potrebnaRegistracija()) { echo "mora da se registruje. "; } else { echo "kakva registracija, samo vozi... "; }
    }
}

class 
MotornoVozilo extends Vozilo {

    public function 
potrebnaDozvolaZaUpravljanje () {
        return 
true;
    }

    public function 
potrebnaRegistracija () {
        return 
true;
    }

}

class 
Bicikl extends Vozilo implements iVozilo {
    
    public function 
__construct () {}

    public function 
potrebnaDozvolaZaUpravljanje () {
        return 
false;
    }

    public function 
brojTockova () {
        return 
2;
    }

    public function 
potrebnaRegistracija () {
        return 
false;
    }

}

class 
Automobil extends MotornoVozilo implements iVozilo {

    public function 
__construct () {}

    public function 
brojTockova () {
        return 
4;
    }

}

class 
Motorcikl extends MotornoVozilo implements iVozilo {

    public function 
__construct () {}

    public function 
brojTockova () {
        return 
2;
    }



ali priznaćeš da to i nije baš identična funkcionalnost, i da je moguće napisati klasu koja se ne bi obavezala na ovaj interfejs, i ostavila neku od potrebnih metoda neimplementiranu, pa onda dolazimo do onih situacija da je PHP skrndelj zato što dozvoljava takve stvari, dok je problem zapravo između stolice i tastature ;)

jablan 04. 03. 2013. 18:17

Baš naprotiv. PHP NIJE skrndelj jer dozvoljava takve stvari. PHP je dinamički jezik i tako treba i da ostane (i po meni, treba da se razvija u tom pravcu). Dinamički jezici imaju tu prednost da interfejsi i apstraktne klase ne moraju da postoje, da metode mogu da se kreiraju i skidaju u rantajmu, itd.

Nadovezujući se tvoj primer, zamisli sledeći kod (hajde da zamislimo da je u pitanju neki dinamički pseudojezik):

Kôd:

Motorcikl = MotornoVozilo.newSubclass(brojTockova: 4)
mojMotor = Motorcikl.new(marka: 'Yamaha')

Iskoristili smo prednost dinamičkog jezika (kreiranje klase u rantajmu), izbegavši sva kuckanja suvišnih keywordova class, abstract, interface, implements, extends itd. O tome Java može samo da sanja.

webarto 04. 03. 2013. 20:54

PHP > Java :D

jablan 09. 03. 2013. 15:57

Eh, evo danas link sa HN-a, jako dobro ilustruje ovo o čemu pričam (ima interfejsi, ima apstraktne klase, ima ženske, ima sve):

https://github.com/Herzult/SimplePHPEasyPlus

dejanr 11. 03. 2013. 01:37

Mislim da nije poenta u tome da li je dinamican ili nije. Vec da je objektno orijentisan i da je imperativan programski jezik. Zbog toga ima sve sto ima, i to ce definitivno uticati kakav ce i biti.

Tesko je dati kratak i jasam odgovor na pitanje. Dobio si vec i neke odgovore.

Mislim da se na kraju opet svodi sve na cistljivost i odrzavanje takvog koda. Kao sto si i video jablanov troll primer, koji je jako necitljiv i prilicno je tesko videti sta on radi i cemu sluzi.

Zato nema univerzalne formule, Magento je jako los primer po meni ako zelis da naucis nesto o dobrom dizajnu OO PHP-a i kuda to sve ide.

Ako te zanima nesto vise o ovoj temi, definitivno pogledaj malo naprednije frameworke tipa Symfony i Zend. Sigurno ces naci dobre primere i patterne tamo.

tasmaniski 11. 03. 2013. 16:28

Da vidim.. Hvala svima...


Vreme je GMT +2. Trenutno vreme je 14:02.

Powered by vBulletin® Verzija 3.6.8
Copyright ©2000 - 2024, Jelsoft Enterprises Ltd.
Copyright © DevProTalk. All Rights Reserved.

Mišljenja, saveti, izjave, ponude ili druge informacije ili sadržaji nastali na Sajtu su vlasništvo onoga ko ih je kreirao, a ne DevProTalk.com, tako da ne morate da se oslanjate na njih.
Autori poruka su jedini odgovorni za ovakve sadržaje. DevProTalk.com ne garantuje tačnost, kompletnost ili upotrebnu vrednost informacija, stavova, saveta ili datih izjava. Ne postoje uslovi pod kojima bi mi bili odgovorni za štetu ili gubitak koji je posledica bilo čijeg oslanjanja na nepouzdane informacije, ili bilo kakve informacije nastale kroz komunikaciju između registrovanih članova.
Web sajt može sadržavati linkove na druge web sajtove na Internetu ili neke druge sadržaje. Ne kontrolišemo niti podržavamo te druge web sajtove, niti smo pregledali bilo kakve sadržaje na takvim sajtovima. Mi nećemo biti odgovorni za legalnost, tačnost ili prikladnost bilo kog sadržaja, oglasa, proizvoda, usluga ili informacije lociranim na ili distribuiranih kroz druge web sajtove, niti za bilo kakvu štetu nastalu kao posledica takvih informacija. DevProTalk.com drži i čuva druga prava vlasništva na web sajtu. Web sajt sadrže materijale zaštićene copyright-om, zaštitne znakove i druge informacije o pravu vlasništva ili softver. Članovi mogu poslatu informacije zaštićene pravima vlasništva njihovih nosilaca i ona ostaju zaštićena bez obzira da li su oni koji prenose te informacije to naveli ili ne. Osim informacija koje su u javnom vlasništvu ili za koje dobijete dozvolu, nemate pravo da kopirate, modifikujete ili na bilo koji način menjate, objavljujete, prenosite, distribuirate, izvršavate, prikazujete ili prodajte bilo koju informaciju zaštićenu pravima vlasništva. Slanjem informacija ili sadržaja na bilo koji deo DevProTalk.com, Vi automatski dozvoljavate i predstavljate garanciju da imate pravo da dozvolite DevProTalk.com ili članovima DevProTalk.com bespovratnu, kontinualnu, neograničenu, globalnu dozvolu da koriste, kopiraju, izvršavaju, prikazuju i distribuiraju takve informacije i sadržaje i da iz takvih sadžaja koriste bilo koji deo u bilo koje svrhe, kao i pravo i dozvolu da koriste gore navedene sadržaje. Svi zaštitni znakovi (trademarks), logotipi, oznake usluga, firme ili imena proizvoda koji se pominju na ovom web sajtu su vlasništvo kojim raspolažu njihovi vlasnici.