summaryrefslogtreecommitdiff
path: root/libodb-mssql/odb/mssql/exceptions.cxx
diff options
context:
space:
mode:
authorKaren Arutyunov <karen@codesynthesis.com>2024-02-01 18:10:52 +0300
committerKaren Arutyunov <karen@codesynthesis.com>2024-02-01 18:10:52 +0300
commitae5a90db9df0cb9f4f2df8218bc1ee81556490ac (patch)
tree6446af3bdcf112f1687e59313a3ed4d698b7e1cf /libodb-mssql/odb/mssql/exceptions.cxx
parent3fa01c83a095f1f5be99189236ec348f5f2fa2c1 (diff)
parent2895ad78dbdb43e57fc34558b4530b4e105fc72d (diff)
Merge branch 'libodb-mssql' into multi-package
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);
+ }
+ }
+}