blob: 6b90ccf8b4f16738f24992e002d2c755f55fda35 [file] [log] [blame]
// 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.
#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