blob: 54bdbf6d3e86de73faa8380317e6024fb1c7b052 [file] [log] [blame]
[email protected]98b6f8b12012-02-10 13:31:591// Copyright (c) 2012 The Chromium Authors. All rights reserved.
[email protected]4cccc222010-04-02 22:12:562// Use of this source code is governed by a BSD-style license that can be
3// found in the LICENSE file.
4
[email protected]f0a54b22011-07-19 18:40:215#ifndef SQL_DIAGNOSTIC_ERROR_DELEGATE_H_
6#define SQL_DIAGNOSTIC_ERROR_DELEGATE_H_
[email protected]32b76ef2010-07-26 23:08:247#pragma once
[email protected]4cccc222010-04-02 22:12:568
[email protected]4cccc222010-04-02 22:12:569#include "base/logging.h"
[email protected]835d7c82010-10-14 04:38:3810#include "base/metrics/histogram.h"
[email protected]f0a54b22011-07-19 18:40:2111#include "sql/connection.h"
[email protected]d4526962011-11-10 21:40:2812#include "sql/sql_export.h"
[email protected]4cccc222010-04-02 22:12:5613
14namespace sql {
15
16// This class handles the exceptional sqlite errors that we might encounter
17// if for example the db is corrupted. Right now we just generate a UMA
18// histogram for release and an assert for debug builds.
19//
20// Why is it a template you ask? well, that is a funny story. The histograms
21// need to be singletons that is why they are always static at the function
22// scope, but we cannot use the Singleton class because they are not default
23// constructible. The template parameter makes the compiler to create unique
24// classes that don't share the same static variable.
25template <class UniqueT>
26class DiagnosticErrorDelegate : public ErrorDelegate {
27 public:
28
29 virtual int OnError(int error, Connection* connection,
30 Statement* stmt) {
[email protected]98b6f8b12012-02-10 13:31:5931 LOG(ERROR) << "sqlite error " << error
32 << ", errno " << connection->GetLastErrno()
33 << ": " << connection->GetErrorMessage();
[email protected]4cccc222010-04-02 22:12:5634 RecordErrorInHistogram(error);
35 return error;
36 }
37
38 private:
39 static void RecordErrorInHistogram(int error) {
[email protected]658f8332010-09-18 04:40:4340 // Trim off the extended error codes.
41 error &= 0xff;
42
[email protected]4cccc222010-04-02 22:12:5643 // The histogram values from sqlite result codes go currently from 1 to
44 // 26 currently but 50 gives them room to grow.
45 UMA_HISTOGRAM_ENUMERATION(UniqueT::name(), error, 50);
46 }
47};
48
49} // namespace sql
50
[email protected]f0a54b22011-07-19 18:40:2151#endif // SQL_DIAGNOSTIC_ERROR_DELEGATE_H_