|  | // Copyright (c) 2012 The Chromium Authors. All rights reserved. | 
|  | // Use of this source code is governed by a BSD-style license that can be | 
|  | // found in the LICENSE file. | 
|  |  | 
|  | #ifndef SQL_ERROR_DELEGATE_UTIL_H_ | 
|  | #define SQL_ERROR_DELEGATE_UTIL_H_ | 
|  |  | 
|  | #include "base/metrics/histogram.h" | 
|  | #include "sql/connection.h" | 
|  | #include "sql/sql_export.h" | 
|  |  | 
|  | namespace sql { | 
|  |  | 
|  | // Returns true if it is highly unlikely that the database can recover from | 
|  | // |error|. | 
|  | SQL_EXPORT bool IsErrorCatastrophic(int error); | 
|  |  | 
|  | // Log error in console in debug mode and generate a UMA histogram in release | 
|  | // mode for |error| for |UniqueT::name()|. | 
|  | // This function is templated because histograms need to be singletons. That is | 
|  | // why they are always static at the function scope. The template parameter | 
|  | // makes the compiler create unique functions that don't share the same static | 
|  | // variable. | 
|  | template <class UniqueT> | 
|  | void LogAndRecordErrorInHistogram(int error, | 
|  | sql::Connection* connection) { | 
|  | LOG(ERROR) << "sqlite error " << error | 
|  | << ", errno " << connection->GetLastErrno() | 
|  | << ": " << connection->GetErrorMessage(); | 
|  |  | 
|  | // Trim off the extended error codes. | 
|  | error &= 0xff; | 
|  |  | 
|  | // The histogram values from sqlite result codes currently go from 1 to 26 | 
|  | // but 50 gives them room to grow. | 
|  | UMA_HISTOGRAM_ENUMERATION(UniqueT::name(), error, 50); | 
|  | } | 
|  |  | 
|  | }  // namespace sql | 
|  |  | 
|  | #endif  // SQL_ERROR_DELEGATE_UTIL_H_ |