Panopoly Override
The General Thrust of Things
We are using this method to override and extend panopoly features without introducing "overridden" statuses. This will allow us to keep "overriden" settings in code and version controlled thus trackable and deployable. The core principle at work here is using "default_hook_alter" to change the default statuses of components defined in other features before they are diffed against the settings in the database. For more information about default hooks read below. In order to implement these default hook alters we are "hijacking" the functional namespaces of the features to be extended. This means that we also need to check to see whether these functions have been defined yet otherwise there is a fatal error possibility. You might not want to use this method in combination with features override and you should only try to implement these hooks using a EXTENDEDMODULE_override namespacing. If you want to provide an override of an override you should be able to continue this procedure indefinitely.
Example:
Overriding panopoly_wysiwyg variables
module name : panopoly_override/panopoly_wysiwyg_override
include file : panopoly_override/features/panopoly_wysiwyg.inc
hook name : panopoly_wysiwyg_strongarm_alter()
Example: Overriding panopoly_wysiqyg_override
variables: module name : panopoly_override_override
include file : panopoly_override_override/features/ panopoly_wysiwyg_override.inc
hook name : panopoly_wysiwyg_strongarm_alter()
To be honest I haven't actually tried this beyond the first level yet so its possible it just doesn't even work. You also definitely need to make sure that the default hook alters in panopoly_override_override run after those in panopoly_override. This should be the default behavior but you may want to look at hook_module_implements_alter to get the right ordering.
Global Overrides vs Site Specific Overrides
We think it is a good idea to have seperate conventions for extending/overriding components that have either "universal" or local scope. For example if you are a large University using a panopoly sub-distribution and you override certain panopoly features on EVERY site you probably want to put these overrides into a seperate "panopoly_override" module. This way you can easily identify and deploy these changes.
However, if you have a override that is applicable to a single site. You might want to bundle in an override to a feature that makes sense. For example:
example_admin.module
example_admin/overrides/panopoly_admin.inc
We think that it is a good to try and mimic the feature seperation used in panopoly in other features so there is a consistent way to group funtionality. Here is a list of panopoly features and a hypothetical list of additional features
panopoly_admin => example_admin
panopoly_core => example_core
panopoly_images => example_images
panopoly_magic => example_magic
panopoly_pages => example_pages
panopoly_theme => example_theme
panopoly_users => example_users
panopoly_widgets => example_widgets
panopoly_wysiwyg => example_wysiywg
=> example_some_new_functionality_that_doesnt_fit_above
Default Hooks
Generally a component can be altered by calling HOOK_DEFAULT_HOOK_ALTER. In this method we are using the feature that is being overriden as the hook instead of the module calling the hook. It is also important to note that you cannot alter the "dependency" component or the components listed in a features include file the same way as the other components. In order to "override" a dependency you need to invoke EXTENDEDMODULE_system_info_alter.
This module only contains a brief list of hooks to override exportable components. For a more complete list of hooks please check out: Default Hooks=
Example Code
We have posted a code skeleton that contains some example code and is the basis for a couple of override schemes we currently have in production.
https://github.com/kalamuna/panopoly_override