summaryrefslogtreecommitdiff
path: root/libodbcpp/column.cpp
diff options
context:
space:
mode:
authorDan Goodliffe <dan@randomdan.homeip.net>2015-12-24 04:08:56 +0000
committerDan Goodliffe <dan@randomdan.homeip.net>2015-12-24 04:08:56 +0000
commit63d9cbb434ec4f6e828083b99d638127cfce7a95 (patch)
tree2dfcf95372467a9119147265fccfba058c617b8a /libodbcpp/column.cpp
parentUse parent glibmm (diff)
downloadlibdbpp-odbc-63d9cbb434ec4f6e828083b99d638127cfce7a95.tar.bz2
libdbpp-odbc-63d9cbb434ec4f6e828083b99d638127cfce7a95.tar.xz
libdbpp-odbc-63d9cbb434ec4f6e828083b99d638127cfce7a95.zip
ODBC files prefixed with odbc-
Diffstat (limited to 'libodbcpp/column.cpp')
-rw-r--r--libodbcpp/column.cpp106
1 files changed, 0 insertions, 106 deletions
diff --git a/libodbcpp/column.cpp b/libodbcpp/column.cpp
deleted file mode 100644
index da31ed0..0000000
--- a/libodbcpp/column.cpp
+++ /dev/null
@@ -1,106 +0,0 @@
-#include <sqlext.h>
-#include <stdio.h>
-#include <stdlib.h>
-#include "column.h"
-#include "command.h"
-#include "selectcommand.h"
-#include "error.h"
-
-ODBC::Column::Column(SelectCommand * sc, const Glib::ustring & s, unsigned int i) :
- DB::Column(s, i),
- selectCmd(sc)
-{
- bindLen = 0;
-}
-
-ODBC::Column::~Column()
-{
-}
-
-bool
-ODBC::Column::resize()
-{
- return false;
-}
-
-bool
-ODBC::CharArrayColumn::resize()
-{
- if (bindLen >= SQLLEN(data.size())) {
- data.resize(bindLen + 1);
- Column::bind();
- if (paramCmd) {
- paramBound = false;
- Param::bind();
- }
- return true;
- }
- return false;
-}
-
-bool
-ODBC::Column::isNull() const
-{
- return (bindLen == SQL_NULL_DATA);
-}
-
-void
-ODBC::Column::rebind(DB::Command * cmd, unsigned int idx) const
-{
- meAsAParam()->paramCmd = dynamic_cast<ODBC::Command *>(cmd);
- meAsAParam()->paramIdx = idx;
- meAsAParam()->bind();
-}
-
-void
-ODBC::Column::bind()
-{
- RETCODE rc = SQLBindCol(selectCmd->hStmt, colNo + 1, ctype(), rwDataAddress(), size(), &bindLen);
- if (!SQL_SUCCEEDED(rc)) {
- throw Error(rc, SQL_HANDLE_STMT, selectCmd->hStmt, "ODBC::Column::bind");
- }
-}
-
-ODBC::TimeStampColumn::operator boost::posix_time::ptime() const
-{
- return boost::posix_time::ptime(
- boost::gregorian::date(data.year, data.month, data.day),
- boost::posix_time::time_duration(data.hour, data.minute, data.second, data.fraction));
-}
-ODBC::IntervalColumn::operator boost::posix_time::time_duration() const
-{
- auto dur = boost::posix_time::time_duration(
- (24 * data.intval.day_second.day) + data.intval.day_second.hour,
- data.intval.day_second.minute, data.intval.day_second.second, data.intval.day_second.fraction);
- return (data.interval_sign ? -dur : dur);
-}
-void
-ODBC::SignedIntegerColumn::apply(DB::HandleField & h) const
-{
- if (isNull()) return h.null();
- h.integer(data);
-}
-void
-ODBC::FloatingPointColumn::apply(DB::HandleField & h) const
-{
- if (isNull()) return h.null();
- h.floatingpoint(data);
-}
-void
-ODBC::CharArrayColumn::apply(DB::HandleField & h) const
-{
- if (isNull()) return h.null();
- h.string(&data.front(), bindLen);
-}
-void
-ODBC::TimeStampColumn::apply(DB::HandleField & h) const
-{
- if (isNull()) return h.null();
- h.timestamp(*this);
-}
-void
-ODBC::IntervalColumn::apply(DB::HandleField & h) const
-{
- if (isNull()) return h.null();
- h.interval(*this);
-}