field_attach_delete

Versions
7
field_attach_delete($obj_type, $object)

Delete field data for an existing object. This deletes all revisions of field data for the object.

Parameters

$obj_type The type of $object; e.g. 'node' or 'user'.

$object The object whose field data to delete.

Related topics

▾ 3 functions call field_attach_delete()

comment_delete_multiple in modules/comment/comment.module
Delete comments and all their replies.
node_delete_multiple in modules/node/node.module
Delete multiple nodes.
taxonomy_term_delete in modules/taxonomy/taxonomy.module
Delete a term.

Code

modules/field/field.attach.inc, line 918

<?php
function field_attach_delete($obj_type, $object) {
  _field_invoke('delete', $obj_type, $object);

  list($id, $vid, $bundle, $cacheable) = entity_extract_ids($obj_type, $object);

  // Collect the storage backends used by the fields in the objects.
  $storages = array();
  foreach (field_info_instances($obj_type, $bundle) as $instance) {
    $field = field_info_field_by_id($instance['field_id']);
    $field_id = $field['id'];
    $storages[$field['storage']['type']][$field_id] = $field_id;
  }

  // Field storage backends delete their data.
  foreach ($storages as $storage => $fields) {
    $storage_info = field_info_storage_types($storage);
    module_invoke($storage_info['module'], 'field_storage_delete', $obj_type, $object, $fields);
  }

  // Let other modules act on deleting the object.
  module_invoke_all('field_attach_delete', $obj_type, $object);

  if ($cacheable) {
    cache_clear_all("field:$obj_type:$id", 'cache_field');
  }
}
?>
Login or register to post comments
 
 

All source code and documentation on this site is released under the terms of the GNU General Public License, version 2 and later. Drupal is a registered trademark of Dries Buytaert.