summaryrefslogtreecommitdiff
path: root/cpp/src/qpid/store/ms-sql
diff options
context:
space:
mode:
authorStephen D. Huston <shuston@apache.org>2009-10-28 23:47:03 +0000
committerStephen D. Huston <shuston@apache.org>2009-10-28 23:47:03 +0000
commite70a7bb7fbed5533690fa0fcea1e157867b2b1fa (patch)
tree7daf6f6a7aff694d937ca83a2bc690303b9badfb /cpp/src/qpid/store/ms-sql
parent891493f277f6a2895399a955a56bac8f4ef1379a (diff)
downloadqpid-python-e70a7bb7fbed5533690fa0fcea1e157867b2b1fa.tar.gz
Change StorageProvider::Exception to inherit from qpid::Exception instead of std::exception; allows the broker to catch them and do something other than die without a message.
Fixed exception handling around more ADO ops and correctly handle com exceptions without associated ErrorInfo. git-svn-id: https://svn.apache.org/repos/asf/qpid/trunk/qpid@830797 13f79535-47bb-0310-9956-ffa450edef68
Diffstat (limited to 'cpp/src/qpid/store/ms-sql')
-rw-r--r--cpp/src/qpid/store/ms-sql/Exception.h11
-rw-r--r--cpp/src/qpid/store/ms-sql/MSSqlProvider.cpp49
2 files changed, 36 insertions, 24 deletions
diff --git a/cpp/src/qpid/store/ms-sql/Exception.h b/cpp/src/qpid/store/ms-sql/Exception.h
index 34e401b068..84b7f62739 100644
--- a/cpp/src/qpid/store/ms-sql/Exception.h
+++ b/cpp/src/qpid/store/ms-sql/Exception.h
@@ -46,8 +46,15 @@ public:
ADOException(const std::string& _text, _com_error &e)
: Exception(_text) {
text += ": ";
- _bstr_t wmsg = e.Description();
- text += (const char *)wmsg;
+ IErrorInfo *i = e.ErrorInfo();
+ if (i != 0) {
+ _bstr_t wmsg = e.Description();
+ text += (const char *)wmsg;
+ i->Release();
+ }
+ else {
+ text += e.ErrorMessage();
+ }
}
};
diff --git a/cpp/src/qpid/store/ms-sql/MSSqlProvider.cpp b/cpp/src/qpid/store/ms-sql/MSSqlProvider.cpp
index cb92e2fd80..b8c020fabe 100644
--- a/cpp/src/qpid/store/ms-sql/MSSqlProvider.cpp
+++ b/cpp/src/qpid/store/ms-sql/MSSqlProvider.cpp
@@ -954,28 +954,33 @@ MSSqlProvider::createDb(_ConnectionPtr conn, const std::string &name)
" (messageId bigint REFERENCES tblMessage(persistenceId) NOT NULL,"
" queueId bigint REFERENCES tblQueue(persistenceId) NOT NULL)";
_variant_t unused;
- _bstr_t dbStr = dbCmd.c_str();
- conn->Execute(dbStr, &unused, adExecuteNoRecords);
- _bstr_t useStr = useCmd.c_str();
- conn->Execute(useStr, &unused, adExecuteNoRecords);
- std::string makeTable = tableCmd + TblQueue + colSpecs;
- _bstr_t makeTableStr = makeTable.c_str();
- conn->Execute(makeTableStr, &unused, adExecuteNoRecords);
- makeTable = tableCmd + TblExchange + colSpecs;
- makeTableStr = makeTable.c_str();
- conn->Execute(makeTableStr, &unused, adExecuteNoRecords);
- makeTable = tableCmd + TblConfig + colSpecs;
- makeTableStr = makeTable.c_str();
- conn->Execute(makeTableStr, &unused, adExecuteNoRecords);
- makeTable = tableCmd + TblMessage + colSpecs;
- makeTableStr = makeTable.c_str();
- conn->Execute(makeTableStr, &unused, adExecuteNoRecords);
- makeTable = tableCmd + TblBinding + bindingSpecs;
- makeTableStr = makeTable.c_str();
- conn->Execute(makeTableStr, &unused, adExecuteNoRecords);
- makeTable = tableCmd + TblMessageMap + messageMapSpecs;
- makeTableStr = makeTable.c_str();
- conn->Execute(makeTableStr, &unused, adExecuteNoRecords);
+ _bstr_t dbStr = dbCmd.c_str();
+ try {
+ conn->Execute(dbStr, &unused, adExecuteNoRecords);
+ _bstr_t useStr = useCmd.c_str();
+ conn->Execute(useStr, &unused, adExecuteNoRecords);
+ std::string makeTable = tableCmd + TblQueue + colSpecs;
+ _bstr_t makeTableStr = makeTable.c_str();
+ conn->Execute(makeTableStr, &unused, adExecuteNoRecords);
+ makeTable = tableCmd + TblExchange + colSpecs;
+ makeTableStr = makeTable.c_str();
+ conn->Execute(makeTableStr, &unused, adExecuteNoRecords);
+ makeTable = tableCmd + TblConfig + colSpecs;
+ makeTableStr = makeTable.c_str();
+ conn->Execute(makeTableStr, &unused, adExecuteNoRecords);
+ makeTable = tableCmd + TblMessage + colSpecs;
+ makeTableStr = makeTable.c_str();
+ conn->Execute(makeTableStr, &unused, adExecuteNoRecords);
+ makeTable = tableCmd + TblBinding + bindingSpecs;
+ makeTableStr = makeTable.c_str();
+ conn->Execute(makeTableStr, &unused, adExecuteNoRecords);
+ makeTable = tableCmd + TblMessageMap + messageMapSpecs;
+ makeTableStr = makeTable.c_str();
+ conn->Execute(makeTableStr, &unused, adExecuteNoRecords);
+ }
+ catch(_com_error &e) {
+ throw ADOException("MSSQL can't create " + name, e);
+ }
}
void