You are here

function _drupal_schema_initialize in Drupal 7

Same name and namespace in other branches
  1. 8 core/includes/schema.inc \_drupal_schema_initialize()
  2. 9 core/includes/schema.inc \_drupal_schema_initialize()

Fills in required default values for table definitions from hook_schema().

Parameters

$schema: The schema definition array as it was returned by the module's hook_schema().

$module: The module for which hook_schema() was invoked.

$remove_descriptions: (optional) Whether to additionally remove 'description' keys of all tables and fields to improve performance of serialize() and unserialize(). Defaults to TRUE.

Related topics

3 calls to _drupal_schema_initialize()
drupal_get_complete_schema in includes/bootstrap.inc
Gets the whole database schema.
drupal_install_schema in includes/common.inc
Creates all tables defined in a module's hook_schema().
drupal_uninstall_schema in includes/common.inc
Removes all tables defined in a module's hook_schema().

File

includes/common.inc, line 7308
Common functions that many Drupal modules will need to reference.

Code

function _drupal_schema_initialize(&$schema, $module, $remove_descriptions = TRUE) {

  // Set the name and module key for all tables.
  foreach ($schema as $name => &$table) {
    if (empty($table['module'])) {
      $table['module'] = $module;
    }
    if (!isset($table['name'])) {
      $table['name'] = $name;
    }
    if ($remove_descriptions) {
      unset($table['description']);
      foreach ($table['fields'] as &$field) {
        unset($field['description']);
      }
    }
  }
}