file_unmanaged_delete

Versions
7
file_unmanaged_delete($path)

Delete a file without calling any hooks or making any changes to the database.

This function should be used when the file to be deleted does not have an entry recorded in the files table.

See also

file_delete()

@see file_unmanaged_delete_recursive()

Parameters

$path A string containing a file path or (streamwrapper) URI.

Return value

TRUE for success or path does not exist, or FALSE in the event of an error.

Related topics

▾ 7 functions call file_unmanaged_delete()

file_delete in includes/file.inc
Delete a file and its database record.
file_unmanaged_delete_recursive in includes/file.inc
Recursively delete all files and directories in the specified filepath.
file_unmanaged_move in includes/file.inc
Move a file to a new location without calling any hooks or making any changes to the database.
image_path_flush in modules/image/image.module
Clear cached versions of a specific file in all styles.
locale_uninstall in modules/locale/locale.install
Implement hook_uninstall().
simpletest_uninstall in modules/simpletest/simpletest.install
Implement hook_uninstall().
_locale_rebuild_js in includes/locale.inc
(Re-)Creates the JavaScript translation file for a language.

Code

includes/file.inc, line 965

<?php
function file_unmanaged_delete($path) {
  // Resolve streamwrapper URI to local path.
  $path = drupal_realpath($path);
  if (is_dir($path)) {
    watchdog('file', '%path is a directory and cannot be removed using file_unmanaged_delete().', array('%path' => $path), WATCHDOG_ERROR);
    return FALSE;
  }
  if (is_file($path)) {
    return unlink($path);
  }
  // Return TRUE for non-existent file, but log that nothing was actually
  // deleted, as the current state is the indended result.
  if (!file_exists($path)) {
    watchdog('file', 'The file %path was not deleted, because it does not exist.', array('%path' => $path), WATCHDOG_NOTICE);
    return TRUE;
  }
  // We cannot handle anything other than files and directories. Log an error
  // for everything else (sockets, symbolic links, etc).
  watchdog('file', 'The file %path is not of a recognized type so it was not deleted.', array('%path' => $path), WATCHDOG_ERROR);
  return FALSE;
}
?>
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.