You are here

public static function Log::removeDatabaseEntries in Drupal 9

Removes database related calls from a backtrace array.

Parameters

array $backtrace: A standard PHP backtrace. Passed by reference.

string $driver_namespace: The PHP namespace of the database driver.

Return value

array The cleaned backtrace array.

2 calls to Log::removeDatabaseEntries()
Error::decodeException in core/lib/Drupal/Core/Utility/Error.php
Decodes an exception and retrieves the correct caller.
Log::findCaller in core/lib/Drupal/Core/Database/Log.php
Determine the routine that called this query.

File

core/lib/Drupal/Core/Database/Log.php, line 185

Class

Log
Database query logger.

Namespace

Drupal\Core\Database

Code

public static function removeDatabaseEntries(array $backtrace, string $driver_namespace) : array {

  // Starting from the very first entry processed during the request, find
  // the first function call that can be identified as a call to a
  // method/function in the database layer.
  for ($n = count($backtrace) - 1; $n >= 0; $n--) {

    // If the call was made from a function, 'class' will be empty. We give
    // it a default empty string value in that case.
    $class = $backtrace[$n]['class'] ?? '';
    if (strpos($class, __NAMESPACE__, 0) === 0 || strpos($class, $driver_namespace, 0) === 0) {
      break;
    }
  }
  return array_values(array_slice($backtrace, $n));
}