I must thank you for your amazing efforts in taking PHP to general people and creating lots of awareness. 🎉🎉🎉
@GaryClarkeTech8 ай бұрын
Love the kind words!
@jorditrigo95698 ай бұрын
Many thanks for sharing your knowledge, Gary!
@GaryClarkeTech8 ай бұрын
My pleasure! Thanks for watching!
@Kogemate8 ай бұрын
Great video!!! Everybody who want more durable code should understand these concept.
@GaryClarkeTech8 ай бұрын
Thanks very much!
@astev528 ай бұрын
Love your work!
@GaryClarkeTech8 ай бұрын
Glad you enjoy it!
@commanderbensisko8 ай бұрын
Hi Gary. I'm just curious why you didn't make SmsDispatcher and Mailer inherit from Notifier and then use a type of Notifier in your code ?
@GaryClarkeTech8 ай бұрын
A Notifier interface or abstract Notifier class would be the best solution but I didn't want to start delving into dependency inversion in the SRP example...it might have become a distraction.
@thenightwolf2248 ай бұрын
Amazing Video Buddy Keep Going ❤🔥
@GaryClarkeTech8 ай бұрын
Thanks a lot...appreaciated!
@dandan-js2ir7 ай бұрын
Hi. Great video! One question though regarding Open/Close principle. How to deal with vendor/ directory classes that does not implement an interface? Let's say there is a x package in vendor directory, and that package has a regular class that performs some task (without implementing any interface nor extending an abstract class). How to add Decorator pattern in such case? Thank you and cheers!
@GaryClarkeTech7 ай бұрын
That gets a bit more complex. If you need its functionality you can inject it as a dependency into your own class which does implement the interface. But try to avoid putting square pegs in round holes if it's going to cause more problems than it solves.
@dandan-js2ir7 ай бұрын
@@GaryClarkeTech Thank you for response!
@ta-mas7 ай бұрын
Hello Gary, Great video, it was really really helpful! At the ISP part, let's say not just the archiver needs to read the file to do an operation on it. How should I handle that? Maybe break the interface into even smaller parts, so I have a FileReaderInterface a FileArchiverInterface and an Interface for my other operation that I want to imeplement? Thank you for the amazing content!!
@GaryClarkeTech7 ай бұрын
Cheers for the kind words... Yes just break it up and implement as many interfaces as you need
@kokokodev3 ай бұрын
Coooll❤❤
@Kogemate8 ай бұрын
For the first example, instead of encapsulation, I would use an interface. And only if the class that I am trying to inject does not implements the interface (like an open source class), I would create this class. Actually, it is a classic design pattern. Globally, it is better to rely on interface which is better than abstraction which is better than concrete class. :)
@GaryClarkeTech8 ай бұрын
You're right..but I didn't want to delve into dependency inversion before I got to it..it might have become a distraction.
@Kogemate8 ай бұрын
@@GaryClarkeTech You were actually right not to do it, too much complexity for nothing. BTW, I learned everything about these concept from Miško Hevery (he was Mr Writing-testable-code evangelist at Google). If you google his name, you will find amazing pdfs and yt videos. Lots of tips. As it is a little old, we can see what aged well (almost everything). Take care.