summaryrefslogtreecommitdiff
path: root/libodb-mssql/odb/mssql/exceptions.cxx
diff options
context:
space:
mode:
Diffstat (limited to 'libodb-mssql/odb/mssql/exceptions.cxx')
-rw-r--r--libodb-mssql/odb/mssql/exceptions.cxx109
1 files changed, 109 insertions, 0 deletions
diff --git a/libodb-mssql/odb/mssql/exceptions.cxx b/libodb-mssql/odb/mssql/exceptions.cxx
new file mode 100644
index 0000000..606678d
--- /dev/null
+++ b/libodb-mssql/odb/mssql/exceptions.cxx
@@ -0,0 +1,109 @@
+// file : odb/mssql/exceptions.cxx
+// license : ODB NCUEL; see accompanying LICENSE file
+
+#include <sstream>
+
+#include <odb/mssql/exceptions.hxx>
+
+using namespace std;
+
+namespace odb
+{
+ namespace mssql
+ {
+ //
+ // database_exception
+ //
+
+ database_exception::record::
+ record (SQLINTEGER e, const string& s, const string& m)
+ : error_ (e), sqlstate_ (s), message_ (m)
+ {
+ }
+
+ database_exception::
+ ~database_exception () ODB_NOTHROW_NOEXCEPT
+ {
+ }
+
+ database_exception::
+ database_exception ()
+ {
+ }
+
+ database_exception::
+ database_exception (SQLINTEGER e, const string& s, const string& m)
+ {
+ append (e, s, m);
+ }
+
+ void database_exception::
+ append (SQLINTEGER e, const string& s, const string& m)
+ {
+ records_.push_back (record (e, s, m));
+
+ if (!what_.empty ())
+ what_ += '\n';
+
+ ostringstream ostr;
+ ostr << e << " (" << s << "): " << m;
+ what_ += ostr.str ();
+ }
+
+ const char* database_exception::
+ what () const ODB_NOTHROW_NOEXCEPT
+ {
+ return what_.c_str ();
+ }
+
+ database_exception* database_exception::
+ clone () const
+ {
+ return new database_exception (*this);
+ }
+
+ //
+ // cli_exception
+ //
+
+ cli_exception::
+ cli_exception (const string& what)
+ : what_ (what)
+ {
+ }
+
+ cli_exception::
+ ~cli_exception () ODB_NOTHROW_NOEXCEPT
+ {
+ }
+
+ const char* cli_exception::
+ what () const ODB_NOTHROW_NOEXCEPT
+ {
+ return what_.c_str ();
+ }
+
+ cli_exception* cli_exception::
+ clone () const
+ {
+ return new cli_exception (*this);
+ }
+
+ //
+ // long_data_reload
+ //
+
+ const char* long_data_reload::
+ what () const ODB_NOTHROW_NOEXCEPT
+ {
+ return "attempt to re-load object or view with long data "
+ "from query result";
+ }
+
+ long_data_reload* long_data_reload::
+ clone () const
+ {
+ return new long_data_reload (*this);
+ }
+ }
+}