manip1.hh
上传用户:clovervx
上传日期:2010-03-30
资源大小:787k
文件大小:9k
- #ifndef __manip1_hh__
- #define __manip1_hh__
- #include <mysql.h>
- #include <iostream>
- using namespace std;
- #include "define_short.h"
- #include "sql_string1.hh"
- #include "sql_query1.hh"
- #include "datetime1.hh"
- #include "set1.hh"
- //quote manipulaor
- extern bool dont_quote_auto;
- class SQLQueryParms;
- enum quote_type0 {mysql_quote};
- struct quote_type1
- {
- ostream *ostr;
- quote_type1(ostream *o) : ostr(o) {}
- };
- inline quote_type1 operator << (ostream &o, quote_type0 esc) {
- return quote_type1(&o);
- }
- struct quote_type2
- {
- SQLQueryParms *qparms;
- quote_type2(SQLQueryParms *p) : qparms(p) {}
- };
- inline quote_type2 operator << (SQLQueryParms &p, quote_type0 esc)
- {
- return quote_type2(&p);
- }
- SQLQueryParms& operator << (quote_type2 p, SQLString &in);
- template <class T>
- inline ostream& operator << (quote_type1 o, const T &in)
- {
- return *o.ostr << in;
- }
- ostream& operator << (ostream& o,const mysql_ColData<string>& in);
- ostream& operator << (ostream& o, const mysql_ColData<const_string>& in);
- SQLQuery& operator << (SQLQuery& o, const mysql_ColData<string>& in);
- SQLQuery& operator << (SQLQuery& o, const mysql_ColData<const_string>& in);
- // FIX: the implementation of this function is moved to manip.cpp
- // to avoid VC++ linker errors
- SQLQuery& operator << (SQLQuery& o, const char* txt);
- template <class T>
- ostream& operator << (quote_type1 o, const string &in) {
- char* s = new char[in.size()*2+1];
- mysql_escape_string(s, const_cast<char *>(in.c_str()), in.size() );
- *o.ostr << "'" << s << "'";
- delete[] s;
- return *o.ostr;
- }
- template <class T>
- ostream& operator << (quote_type1 o, const char* const &in) {
- unsigned int size;
- for (size=0; in[size]; size++);
- char* s = new char[size*2+1];
- mysql_escape_string(s, const_cast<char *>(in), size);
- *o.ostr << "'" << s << "'";
- delete[] s;
- return *o.ostr;
- }
- template <class T>
- ostream& operator << (quote_type1 o, const mysql_ColData<string>& in) {
- return _manip(o,in);
- }
- template <class T>
- ostream& operator << (quote_type1 o, const mysql_ColData<const_string>& in) {
- return _manip(o,in);
- }
- template <class T>
- inline ostream& operator << (quote_type1 o, char* const &in) {
- return operator << (o, const_cast<const char* const &>(in));
- }
- template <class T>
- inline ostream& operator << (quote_type1 o, const Date &in) {
- return *o.ostr << "'" << in << "'";
- }
- template <class T>
- inline ostream& operator << (quote_type1 o, const Time &in) {
- return *o.ostr << "'" << in << "'";
- }
- template <class T>
- inline ostream& operator << (quote_type1 o, const DateTime &in) {
- return *o.ostr << "'" << in << "'";
- }
- template <class ST>
- inline ostream& operator << (quote_type1 o, const MysqlSet<ST> &in) {
- return *o.ostr << "'" << in << "'";
- }
- // quote only manipulator
- enum quote_only_type0 {mysql_quote_only};
- struct quote_only_type1 {
- ostream *ostr;
- quote_only_type1(ostream *o) : ostr(o) {}
- };
- inline quote_only_type1 operator << (ostream &o, quote_only_type0 esc) {
- return quote_only_type1(&o);
- }
- struct quote_only_type2 {
- SQLQueryParms *qparms;
- quote_only_type2(SQLQueryParms *p) : qparms(p) {}
- };
- inline quote_only_type2 operator << (SQLQueryParms &p, quote_only_type0 esc) {
- return quote_only_type2(&p);
- }
- SQLQueryParms & operator << (quote_only_type2 p, SQLString &in);
- template <class T>
- inline ostream& operator << (quote_only_type1 o, const T &in) {
- return *o.ostr << in;
- }
- template <class T>
- inline ostream& operator << (quote_only_type1 o, const string &in) {
- return *o.ostr << "'" << in << "'";
- }
- template <class T>
- ostream& operator << (quote_only_type1 o, const mysql_ColData<string>& in) {
- if (in.quote_q()) {
- *o.ostr << "'" << in << "'";
- } else {
- *o.ostr << in;
- }
- return *o.ostr;
- }
- template <class T>
- ostream& operator << (quote_only_type1 o, const mysql_ColData<const_string>& in) {
- if (in.quote_q()) {
- *o.ostr << "'" << in << "'";
- } else {
- *o.ostr << in;
- }
- return *o.ostr;
- }
- template <class T>
- inline ostream& operator << (quote_only_type1 o, const Date &in) {
- return *o.ostr << "'" << in << "'";
- }
- template <class T>
- inline ostream& operator << (quote_only_type1 o, const Time &in) {
- return *o.ostr << "'" << in << "'";
- }
- template <class T>
- inline ostream& operator << (quote_only_type1 o, const DateTime &in) {
- return *o.ostr << "'" << in << "'";
- }
- template <class ST>
- inline ostream& operator << (quote_only_type1 o, const MysqlSet<ST> &in) {
- return *o.ostr << "'" << in << "'";
- }
- // quote double (") only manipulator
- enum quote_double_only_type0 {mysql_quote_double_only};
- struct quote_double_only_type1 {
- ostream *ostr;
- quote_double_only_type1(ostream *o) : ostr(o) {}
- };
- inline quote_double_only_type1 operator << (ostream &o,
- quote_double_only_type0 esc) {
- return quote_double_only_type1(&o);
- }
- struct quote_double_only_type2 {
- SQLQueryParms *qparms;
- quote_double_only_type2(SQLQueryParms *p) : qparms(p) {}
- };
- inline quote_double_only_type2 operator << (SQLQueryParms &p,
- quote_double_only_type0 esc) {
- return quote_double_only_type2(&p);
- }
- SQLQueryParms & operator << (quote_double_only_type2 p, SQLString &in);
- template <class T>
- inline ostream& operator << (quote_double_only_type1 o, const T &in) {
- return *o.ostr << in;
- }
- template <class T>
- inline ostream& operator << (quote_double_only_type1 o, const string &in) {
- return *o.ostr << """ << in << """;
- }
- template <class T>
- ostream& operator << (quote_double_only_type1 o, const mysql_ColData<string>& in) {
- if (in.quote_q()) {
- *o.ostr << "'" << in << "'";
- } else {
- *o.ostr << in;
- }
- return *o.ostr;
- }
- template <class T>
- ostream& operator << (quote_double_only_type1 o, const mysql_ColData<const_string>& in) {
- if (in.quote_q()) {
- *o.ostr << "'" << in << "'";
- } else {
- *o.ostr << in;
- }
- return *o.ostr;
- }
- template <class T>
- inline ostream& operator << (quote_double_only_type1 o, const Date &in) {
- return *o.ostr << """ << in << """;
- }
- template <class T>
- inline ostream& operator << (quote_double_only_type1 o, const Time &in) {
- return *o.ostr << """ << in << """;
- }
- template <class T>
- inline ostream& operator << (quote_double_only_type1 o,
- const DateTime &in) {
- return *o.ostr << """ << in << """;
- }
- template <class ST>
- inline ostream& operator << (quote_double_only_type1 o,
- const MysqlSet<ST> &in) {
- return *o.ostr << """ << in << """;
- }
- // escape manipulator
- enum escape_type0 {mysql_escape};
- struct escape_type1 {
- ostream *ostr;
- escape_type1(ostream *o) : ostr(o) {}
- };
- inline escape_type1 operator << (ostream &o, escape_type0 esc) {
- return escape_type1(&o);
- }
- struct escape_type2 {
- SQLQueryParms *qparms;
- escape_type2(SQLQueryParms *p) : qparms(p) {}
- };
- inline escape_type2 operator << (SQLQueryParms &p, escape_type0 esc) {
- return escape_type2(&p);
- }
- SQLQueryParms & operator << (escape_type2 p, SQLString &in);
- template <class T>
- inline ostream& operator << (escape_type1 o, const T &in) {
- return *o.ostr << in;
- }
- template <class T>
- ostream& operator << (escape_type1 o, const string &in) {
- char* s = new char[in.size()*2+1];
- mysql_escape_string(s, const_cast<char *>(in.c_str()), in.size());
- *o.ostr << s;
- delete[] s;
- return *o.ostr;
- }
- template <class T>
- ostream& operator << (escape_type1 o, const char* const &in) {
- unsigned int size;
- for (size=0; in[size]; size++);
- char* s = new char[size*2+1];
- mysql_escape_string(s, const_cast<char *>(in), size);
- *o.ostr << s;
- delete[] s;
- return *o.ostr;
- }
- template <class T>
- ostream& operator << (escape_type1 o, const mysql_ColData<string>& in) {
- return _manip(o,in);
- }
- template <class T>
- ostream& operator << (escape_type1 o, const mysql_ColData<const_string>& in) {
- return _manip(o,in);
- }
- template <class T>
- inline ostream& operator << (escape_type1 o, char* const &in) {
- return operator << (o, const_cast<const char* const &>(in));
- }
- //do nothing manipulator
- enum do_nothing_type0 {mysql_do_nothing};
- struct do_nothing_type1 {
- ostream *ostr;
- do_nothing_type1(ostream *o) : ostr(o) {}
- };
- inline do_nothing_type1 operator << (ostream &o, do_nothing_type0 esc) {
- return do_nothing_type1(&o);
- }
- template <class T>
- inline ostream& operator << (do_nothing_type1 o, const T &in) {
- return *o.ostr << in;
- }
- struct do_nothing_type2 {
- SQLQueryParms *qparms;
- do_nothing_type2(SQLQueryParms *p) : qparms(p) {}
- };
- inline do_nothing_type2 operator << (SQLQueryParms &p, do_nothing_type0 esc) {
- return do_nothing_type2(&p);
- }
- inline SQLQueryParms & operator << (do_nothing_type2 p, SQLString &in) {
- in.processed = true;
- return *p.qparms << in;
- }
- enum ignore_type0 {mysql_ignore};
- struct ignore_type2 {
- SQLQueryParms *qparms;
- ignore_type2(SQLQueryParms *p) : qparms(p) {}
- };
- inline ignore_type2 operator << (SQLQueryParms &p, ignore_type0 esc) {
- return ignore_type2(&p);
- }
- inline SQLQueryParms & operator << (ignore_type2 p, SQLString &in) {
- return *p.qparms << in;
- }
- #endif