annotate Orthanc/Core/SQLite/StatementReference.cpp @ 122:3809121c3290

2016
author Sebastien Jodogne <s.jodogne@gmail.com>
date Mon, 04 Jan 2016 13:30:43 +0100
parents d6da56f86e5a
children e8cfda4c8a2f
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
78
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
1 /**
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
2 * Orthanc - A Lightweight, RESTful DICOM Store
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
3 *
122
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 78
diff changeset
4 * Copyright (C) 2012-2016 Sebastien Jodogne <s.jodogne@gmail.com>,
78
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
5 * Medical Physics Department, CHU of Liege, Belgium
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
6 *
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
7 * Copyright (c) 2012 The Chromium Authors. All rights reserved.
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
8 *
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
9 * Redistribution and use in source and binary forms, with or without
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
10 * modification, are permitted provided that the following conditions are
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
11 * met:
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
12 *
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
13 * * Redistributions of source code must retain the above copyright
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
14 * notice, this list of conditions and the following disclaimer.
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
15 * * Redistributions in binary form must reproduce the above
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
16 * copyright notice, this list of conditions and the following disclaimer
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
17 * in the documentation and/or other materials provided with the
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
18 * distribution.
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
19 * * Neither the name of Google Inc., the name of the CHU of Liege,
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
20 * nor the names of its contributors may be used to endorse or promote
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
21 * products derived from this software without specific prior written
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
22 * permission.
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
23 *
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
24 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
25 * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
26 * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
27 * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
28 * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
29 * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
30 * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
31 * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
32 * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
33 * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
34 * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
35 **/
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
36
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
37
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
38 #if ORTHANC_SQLITE_STANDALONE != 1
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
39 #include "../PrecompiledHeaders.h"
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
40 #endif
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
41
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
42 #include "StatementReference.h"
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
43 #include "OrthancSQLiteException.h"
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
44
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
45 #if ORTHANC_SQLITE_STANDALONE != 1
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
46 #include "../Logging.h"
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
47 #endif
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
48
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
49 #include <string>
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
50 #include <cassert>
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
51 #include "sqlite3.h"
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
52
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
53 namespace Orthanc
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
54 {
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
55 namespace SQLite
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
56 {
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
57 bool StatementReference::IsRoot() const
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
58 {
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
59 return root_ == NULL;
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
60 }
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
61
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
62 StatementReference::StatementReference()
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
63 {
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
64 root_ = NULL;
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
65 refCount_ = 0;
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
66 statement_ = NULL;
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
67 assert(IsRoot());
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
68 }
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
69
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
70 StatementReference::StatementReference(sqlite3* database,
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
71 const char* sql)
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
72 {
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
73 if (database == NULL || sql == NULL)
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
74 {
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
75 throw OrthancSQLiteException(ErrorCode_ParameterOutOfRange);
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
76 }
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
77
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
78 root_ = NULL;
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
79 refCount_ = 0;
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
80
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
81 int error = sqlite3_prepare_v2(database, sql, -1, &statement_, NULL);
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
82 if (error != SQLITE_OK)
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
83 {
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
84 #if ORTHANC_SQLITE_STANDALONE != 1
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
85 LOG(ERROR) << "SQLite: " << sqlite3_errmsg(database);
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
86 #endif
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
87
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
88 throw OrthancSQLiteException(ErrorCode_SQLitePrepareStatement);
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
89 }
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
90
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
91 assert(IsRoot());
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
92 }
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
93
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
94 StatementReference::StatementReference(StatementReference& other)
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
95 {
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
96 refCount_ = 0;
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
97
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
98 if (other.IsRoot())
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
99 {
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
100 root_ = &other;
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
101 }
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
102 else
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
103 {
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
104 root_ = other.root_;
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
105 }
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
106
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
107 root_->refCount_++;
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
108 statement_ = root_->statement_;
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
109
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
110 assert(!IsRoot());
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
111 }
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
112
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
113 StatementReference::~StatementReference()
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
114 {
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
115 if (IsRoot())
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
116 {
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
117 if (refCount_ != 0)
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
118 {
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
119 // There remain references to this object. We cannot throw
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
120 // an exception because:
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
121 // http://www.parashift.com/c++-faq/dtors-shouldnt-throw.html
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
122
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
123 #if ORTHANC_SQLITE_STANDALONE != 1
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
124 LOG(ERROR) << "Bad value of the reference counter";
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
125 #endif
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
126 }
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
127 else if (statement_ != NULL)
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
128 {
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
129 sqlite3_finalize(statement_);
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
130 }
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
131 }
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
132 else
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
133 {
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
134 if (root_->refCount_ == 0)
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
135 {
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
136 // There remain references to this object. We cannot throw
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
137 // an exception because:
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
138 // http://www.parashift.com/c++-faq/dtors-shouldnt-throw.html
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
139
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
140 #if ORTHANC_SQLITE_STANDALONE != 1
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
141 LOG(ERROR) << "Bad value of the reference counter";
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
142 #endif
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
143 }
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
144 else
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
145 {
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
146 root_->refCount_--;
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
147 }
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
148 }
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
149 }
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
150
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
151 uint32_t StatementReference::GetReferenceCount() const
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
152 {
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
153 return refCount_;
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
154 }
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
155 }
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
156 }