Overload Classes

From Achievo/ATK Wiki

Jump to: navigation, search

ATK Howto: Overload Classes

Complexity: Intermediate
Author: Thomas Holz <vhskids@gmx.de>

List of other Howto's

Contents

Intro

An overloader is a way of replacing one of the classes your app normally uses, with one of your own. A plain text example: "Use mymodule.mycustomprojectnode whereever the app normally uses the projects.project node". In other words, it is a way of modifying the app, without touching its code.

Note: This method is for overloading nodes only. for overloading base classes try atkClassLoader().

Example

To create an overloader, put this in your module.inc, near the top of the file (before the module definition):

$overloaders["project.project"] = "mymodule.mynode";

In your mymodule module, create the node mynode, like this:

  atkimport("module.project.project");
 
  class mynode extends project
  {
     public function action_admin()
     {
         echo "Hello World";
     }
  }

In this example, the project node is replaced by a mynode node, which derives from project, but overrides its action_admin behaviour.

Criticism

The disadvantage of node overloaders is that due to the restrictions of single inheritance, it's not possible to overload a node twice. If a node is overloaded twice, the first overloader will be ignored. This makes the feature less useful for Add-on Modules. It is therefore recommended to use overloaders sparingly, preferably only to create project-specific customisation modules. In almost all other cases, using Modifiers is a better, more flexible, solution.

Conclusion

It's not strictly necessary to derive from the original class, but this ensures that the overloader is compatible with the original. (The code in the application relies on the project node having certain attributes and behaviour, and by deriving from that class, we preserve this as much as possible.)

original from: http://forum.achievo.org/forum/viewtopic.php?t=1764

Personal tools
Navigation