This repository has been archived on 2025-01-19. You can view files and clone it, but cannot push or open issues or pull requests.
oliverdavies.uk-old-sculpin/source/_posts/dividing-drupals-process-and-preprocess-functions-separate-files.md

98 lines
2.9 KiB
Markdown
Raw Normal View History

2015-03-16 21:18:03 +00:00
---
title: Dividing Drupal's process and preprocess functions into separate files
2020-03-08 14:32:13 +00:00
date: 2012-05-24
excerpt:
If you use a lot of process and preprocess functions within your Drupal theme,
then your template.php can get very long and it can become difficult to find a
certain piece of code. Following the example of the Omega theme, I've started
separating my process and preprocess functions into their own files.
2015-03-16 21:18:03 +00:00
tags:
2015-06-14 02:27:41 +00:00
- drupal
- code
- theming
- preprocessing
2015-03-16 21:18:03 +00:00
---
If you use a lot of process and preprocess functions within your Drupal theme,
then your template.php can get very long and it can become difficult to find a
certain piece of code. Following the example of the
[Omega theme](http://drupal.org/project/omega 'The Omega theme on Drupal.org'),
I've started separating my process and preprocess functions into their own
files. For example, mytheme_preprocess_node can be placed within a
preprocess/node.inc file, and mytheme_process_page can be placed within
process/page.inc.
The first step is to use the default mytheme_process() and mytheme_preprocess()
functions to utilise my custom function. So within my template.php file:
2015-03-16 21:18:03 +00:00
2017-03-16 08:09:52 +00:00
```language-php
2015-03-16 21:18:03 +00:00
<?php
/**
* Implements hook_preprocess().
*
2015-03-16 21:18:03 +00:00
* Initialises the mytheme_invoke() function for the preprocess hook.
*/
function mytheme_preprocess(&$variables, $hook) {
2015-06-14 02:27:41 +00:00
mytheme_invoke('preprocess', $hook, $variables);
2015-03-16 21:18:03 +00:00
}
/**
* Implements hook_process().
*
2015-03-16 21:18:03 +00:00
* Initialises the mytheme_invoke() function for the process hook.
*/
function mytheme_process(&$variables, $hook) {
2015-06-14 02:27:41 +00:00
mytheme_invoke('process', $hook, $variables);
2015-03-16 21:18:03 +00:00
}
2017-03-16 08:09:52 +00:00
```
2015-03-16 21:18:03 +00:00
Now, to write the `mytheme_invoke()` function:
2017-03-16 08:09:52 +00:00
```language-php
2015-03-16 21:18:03 +00:00
<?php
/**
* Invokes custom process and preprocess functions.
*
* @param string $type
2015-06-14 02:27:41 +00:00
* The type of function we are trying to include (i.e. process or preprocess).
2015-03-16 21:18:03 +00:00
*
* @param array $variables
2015-06-14 02:27:41 +00:00
* The variables array.
2015-03-16 21:18:03 +00:00
*
* @param string $hook
2015-06-14 02:27:41 +00:00
* The name of the hook.
*
* @see mytheme_preprocess()
2015-03-16 21:18:03 +00:00
* @see mytheme_process()
*/
function mytheme_invoke($type, $hook, &$variables) {
2015-06-14 02:27:41 +00:00
global $theme_key;
2015-06-14 02:27:41 +00:00
// The name of the function to look for (e.g. mytheme_process_node).
$function = $theme_key . '_' . $type . '_' . $hook;
2015-03-16 21:18:03 +00:00
// If the function doesn't exist within template.php, look for the
2015-06-14 02:27:41 +00:00
// appropriate include file.
if (!function_exists($function)) {
// The file to search for (e.g. process/node.inc).
$file = drupal_get_path('theme', $theme_key) . '/' . $type . '/' . $type . '-' . str_replace('_', '-', $hook) . '.inc';
2015-03-16 21:18:03 +00:00
2015-06-14 02:27:41 +00:00
// If the file exists, include it.
if (is_file($file)) {
include($file);
2015-03-16 21:18:03 +00:00
}
2015-06-14 02:27:41 +00:00
}
2015-03-16 21:18:03 +00:00
2015-06-14 02:27:41 +00:00
// Try to call the function again.
if (function_exists($function)) {
$function($variables);
}
2015-03-16 21:18:03 +00:00
}
2017-03-16 08:09:52 +00:00
```
2015-03-16 21:18:03 +00:00
As `mytheme_invoke()` checks to see if the function already exists before
searching for checking the include files, I could still add the functions into
template.php as normal and this would override any corresponding include file.