Sign Up

Sign Up to our social questions and Answers Engine to ask questions, answer people’s questions, and connect with other people.

Have an account? Sign In

Have an account? Sign In Now

Sign In

Login to our social questions & Answers Engine to ask questions answer people’s questions & connect with other people.

Sign Up Here

Forgot Password?

Don't have account, Sign Up Here

Forgot Password

Lost your password? Please enter your email address. You will receive a link and will create a new password via email.

Have an account? Sign In Now

You must login to ask a question.

Forgot Password?

Need An Account, Sign Up Here

Please briefly explain why you feel this question should be reported.

Please briefly explain why you feel this answer should be reported.

Please briefly explain why you feel this user should be reported.

Sign InSign Up

The Archive Base

The Archive Base Logo The Archive Base Logo

The Archive Base Navigation

  • SEARCH
  • Home
  • About Us
  • Blog
  • Contact Us
Search
Ask A Question

Mobile menu

Close
Ask a Question
  • Home
  • Add group
  • Groups page
  • Feed
  • User Profile
  • Communities
  • Questions
    • New Questions
    • Trending Questions
    • Must read Questions
    • Hot Questions
  • Polls
  • Tags
  • Badges
  • Buy Points
  • Users
  • Help
  • Buy Theme
  • SEARCH
Home/ Questions/Q 669343
In Process

The Archive Base Latest Questions

Editorial Team
  • 0
Editorial Team
Asked: May 14, 20262026-05-14T00:08:28+00:00 2026-05-14T00:08:28+00:00

i just got some more questions while learning PHP, does php implement any built

  • 0

i just got some more questions while learning PHP, does php implement any built in plugin system?

so the plugin would be able to change the behavior of the core component.

for example something like this works:

include 'core.class.php';
include 'plugin1.class.php';
include 'plugin2.class.php';
new plugin2;

where
core.class.php contains

class core {
  public function coremethod1(){
    echo 'coremethod1';
  }
  public function coremethod2(){
    echo 'coremethod2';
  }
}

plugin1.class.php contains

class plugin1 extends core {
  public function coremethod1(){
    echo 'plugin1method1';
  }
}

plugin2.class.php contains

class plugin2 extends plugin1 {
  public function coremethod2(){
    echo 'plugin2method2';
  }
}

This would be ideal, if not for the problem that now the plugins are dependable on each other, and removing one of the plugins:

include 'core.class.php';
//include 'plugin1.class.php';
include 'plugin2.class.php';
new plugin2;

breaks the whole thing…

are there any proper methods to doing this?
if there are not, them i might consider moving to a different langauge that supports this…

thanks for any help.

edit:
obviously it is my understanding that is lacking, so here is a
attempt at a clarification.

core.class.php contains anything…

plugin1.class.php contains anything…

plugin2.class.php contains anything…

include 'core.class.php';
include 'plugin1.class.php';
include 'plugin2.class.php';
$core = new core;
$core->coremethod1();//outputs plugin2method1

whereas:

include 'core.class.php';
include 'plugin2.class.php';
$core = new core;
$core->coremethod1();//outputs plugin1method1

I’m interested in any implementation, even one not involving classes
for example

include 'core.php';
//does core stuff

include 'core.php';
include 'plugin1';
//does extended core stuff

include 'core.php';
include 'plugin2';
//does extended core stuff


include 'core.php';
include 'plugin2';
include 'plugin1';
//does very extended core stuff

including a file needs to change the application behavior. for it to have any meaning.

I do not know what this is called either, so point me at the proper naming if there is any.

  • 1 1 Answer
  • 0 Views
  • 0 Followers
  • 0
Share
  • Facebook
  • Report

Leave an answer
Cancel reply

You must login to add an answer.

Forgot Password?

Need An Account, Sign Up Here

1 Answer

  • Voted
  • Oldest
  • Recent
  • Random
  1. Editorial Team
    Editorial Team
    2026-05-14T00:08:28+00:00Added an answer on May 14, 2026 at 12:08 am

    If your only concern is that not including plugin1 will create an error, then you can resort to autoloading to have plugin2 load plugin1 automatically:

    From the comments in the PHP Manual on spl_autoload

    // Your custom class dir
    define('CLASS_DIR', 'class/')
    
    // Add your class dir to include path
    set_include_path(get_include_path().PATH_SEPARATOR.CLASS_DIR);
    
    // You can use this trick to make autoloader look 
    // for commonly used "My.class.php" type filenames
    spl_autoload_extensions('.class.php');
    
    // Use default autoload implementation
    spl_autoload_register();
    

    If, however, you are looking for a traits/mixin-like feature, then the answer is no. PHP does not support this as of now. At least not without patching the core or resorting to these two APIs you do not want to use in production code.

    The proper way to change how an object behaves at runtime would be to use Decorators:

    $class = new BasicCache( new BasicValidators ( new Basic ) );
    

    or Strategy patterns:

    $class = new Basic;
    $class->setStrategy(function() { return 'foo'} );
    echo $class->callStrategy(); // foo
    $class->setStrategy(function() { return 'bar'} );
    echo $class->callStrategy(); // bar
    

    See http://sourcemaking.com/design_patterns for the most common patterns.


    EDIT Here is an example of how to create plugins with decorators. Assume, we have a game of some sort where some non-player characters walk around in a virtual space and greet the main character from time to time. That’s all they do right now. We want some variation on how they greet though, which is why we need our plugins/decorators in this scenario.

    First we create an interface that defines some methods any object able to greet should have. We don’t care about what it does when these methods are invoked on a specific object. We just want to make sure that the methods are available and that they are called with a clearly defined input:

    interface GreetInterface
    {
        public function greet($name);
        public function setGreeting($greeting);
    }
    

    An interface is basically a contract any implementing object must fulfill. In our case, the contract says, if you are an object that can greet, you have to have two methods. Implement them any way you like, but have these methods.

    Let’s build our non-player character classes now, implementing this interface

    class Dude implements GreetInterface
    {
        protected $greeting = 'hello';
        public function greet($name)
        {
            return sprintf('%s %s', $this->greeting, $name);
        }
        public function setGreeting($greeting)
        {
            $this->greeting = $greeting;
            return $this;
        }
    }
    

    That’s pretty straigtforward I guess. The Dude class just defines the two methods from the interface. When greet() is called, it will fetch the string stored in greeting and prepend to the param passed to the greet method. The setGreeting method allows us to change the greeting at runtime. Note: you could add a getter as well (I was just lazy)

    Now on to the plugins. We will create an abstract GreetPlugin class to contain some shared boilerplate code, simply because we don’t want to duplicate code in our actual plugins. The abstract plugin class will implement the GreetInterface, so we can make sure all subclasses implement the interface too.

    Since Dude already implements the interface as well, we could have the plugins extend Dude, but that would be conceptually wrong, because extending creates an is-a relationship, but a plugin is not a Dude.

    abstract class GreetPluginAbstract implements GreetInterface
    {
        protected $inner;
        public function __construct(GreetInterface $inner)
        {
             $this->inner = $inner;
        }
        public function setGreeting($greeting)
        {
            $this->inner->setGreeting($greeting);
            return $this;
        }
        public function greet($name)
        {
            return $this->inner->greet($name);
        }
    }
    

    The plugin class accepts one argument when initialized: any class implementing the GreetInterface. The TypeHint makes sure, the class fulfills the contract. That’s required, because, as you can see in the code, our plugins will need to call the methods in the interface on the class passed through the constructor. If we had extended from Dude, we would now be able to wrap dudes into dudes, which is a bit odd. Another reason for not doing it.

    Now on to the first plugin. We want some of our dudes to speak with a fancy french accent, which means they use âccénts all over the place, but cannot pronounce a proper h. Disclaimer: yes, I know that’s a cliche. Please bear with my examples

    class FrenchPlugin extends GreetPluginAbstract
    {
        public function greet($name) {
           return str_replace(array('h', 'e'), array('', 'é'),
                              $this->inner->greet($name));
        }
    }
    

    Since the Plugin extends the abstract plugin, we can now focus on the actual code that modifies how a regular dude would do his greeting. When greet() is called, we call greet() on the wrapped element and then remove all h characters and turn all es into és. Everything else is unmodified abstract behavior.

    In another plugin, we want to change the wording of the greeting, so we have some dudes say Heya, instead of just Hello. Just to add some variation.

    class EasyGoingPlugin extends GreetPluginAbstract
    {
        protected $inner;
        public function __construct(GreetInterface $inner) {
             $this->inner = $inner->setGreeting('heya');
             parent::__construct($inner);
        }
    }
    

    This way we only override the constructor, because the greet method should just return whatever it will be. So we call the setGreeting method on the object passed to this plugin. Because the object has to implement the GreetInterface, we can be sure this works.

    Note that I am assigning the return value of setGreeting as the inner object. This is possible because I return $this, whenever setMethod is called. This cannot be enforced through the interface, so you cannot rely on this form the interface. I just added it to show another technique: method chaining.

    With two plugins done, we feel we have enough variation. Now we only need a convenient way to create Dudes. For that we create a small class like this:

    class DudeBuilder
    {
         public static function build()
         {
             $dude = new Dude();
             $decorators = func_get_args();
             foreach($decorators as $decorator) {
                 $decorator .= "Plugin";
                 // require_once $decorator;
                 $dude = new $decorator($dude);
             }
             return $dude;
         }
    }
    

    Note: I always mix up Builder and AbstractFactory, so if the above is a Factory, well, then it’s a factory. Check out the design patterns links I gave earlier on 😉

    All this Builder does, is create a regular dude and then wrap/decorate it into/with whatever plugins we tell it to use and than return it. Because the builder encapsulates no own state, we make the build method static.

    For this example I assume you used the autoloading code I gave right on top. If not, you can include the plugin files in the foreach loop. Lazy loading them only when they are needed will give you a few microseconds faster load times over including them all on top. Hopefully, this also explains what I meant in the various comments when I argued the behavior should not be controlled by a file inclusion. The file inclusion is just a necessity. You cannot use a class that is not know to PHP. But that the class is actually used, is controlled by our code alone, by passing in the plugin names to the build method.

    Let’s do this now

    $regularDude         = DudeBuilder::build();
    $frenchDude          = DudeBuilder::build('French');
    $easygoingDude       = DudeBuilder::build('EasyGoing');
    $frenchEasyGoingDude = DudeBuilder::build('French', 'EasyGoing');
    

    This is effectively the same as doing:

    $regularDude         = new Dude;
    $frenchDude          = new FrenchPlugin(new Dude);
    $easygoingDude       = new EasyGoingPlugin(new Dude);
    $frenchEasyGoingDude = new FrenchPlugin(new EasyGoingPlugin(new Dude));
    

    With just two plugins, we can now create three types of Dudes. Let’s have them greet you:

    echo $regularDude->greet('Yuri'), PHP_EOL,
         $frenchDude->greet('Yuri'), PHP_EOL,
         $easygoingDude->greet('Yuri'), PHP_EOL,
         $frenchEasyGoingDude->greet('Yuri'), PHP_EOL;
    
    // gives
    
    hello Yuri
    éllo Yuri
    heya Yuri
    éya Yuri
    

    We can now create additional plugins to decorate our basic classes with. If for some reason, you decide your game should have talking horses or cars as well, you could also create a class Car or Horse and have it implement the greet interface too and add a Builder for them. You can then reuse the plugins to create French EasyGoing Cars or Horses.

    • 0
    • Reply
    • Share
      Share
      • Share on Facebook
      • Share on Twitter
      • Share on LinkedIn
      • Share on WhatsApp
      • Report

Sidebar

Related Questions

Basically I just got some results back for an assignment and my results were
I got some code off the Internet and now I just need help to
I have just installed Delphi 2010 and got some troubles with idHTTP component. If
I just got my ssl certificate to work for the first time. For some
I am new to programming but had some spare time and just got a
I've just installed django on my mac os x snow leopard and got some
I just started to learn about mod rewrite process. Now, I got some problems
I was just running style cop against some of my code and got a
Just like in the title. I got GridView control that displaying some data from
I just started with PHP and mySQL and I'm creating some kind of blog.

Explore

  • Home
  • Add group
  • Groups page
  • Communities
  • Questions
    • New Questions
    • Trending Questions
    • Must read Questions
    • Hot Questions
  • Polls
  • Tags
  • Badges
  • Users
  • Help
  • SEARCH

Footer

© 2021 The Archive Base. All Rights Reserved
With Love by The Archive Base

Insert/edit link

Enter the destination URL

Or link to existing content

    No search term specified. Showing recent items. Search or use up and down arrow keys to select an item.