~drizzle-trunk/drizzle/development

« back to all changes in this revision

Viewing changes to drizzled/plugin/null_client.h

  • Committer: lbieber
  • Date: 2010-10-01 13:06:31 UTC
  • mfrom: (1802.2.2 drizzle-bug-651948)
  • mto: This revision was merged to the branch mainline in revision 1805.
  • Revision ID: lbieber@orisndriz08-20101001130631-xubscnhmj7r5dn6g
Merge Andrew - Fix bug 651948 - Index lengths not retrieved using drizzledump

Show diffs side-by-side

added added

removed removed

Lines of Context:
1
1
/* -*- mode: c++; c-basic-offset: 2; indent-tabs-mode: nil; -*-
2
2
 *  vim:expandtab:shiftwidth=2:tabstop=2:smarttab:
3
3
 *
4
 
 *  Copyright (C) 2008 Sun Microsystems, Inc.
 
4
 *  Copyright (C) 2008 Sun Microsystems
5
5
 *
6
6
 *  This program is free software; you can redistribute it and/or modify
7
7
 *  it under the terms of the GNU General Public License as published by
21
21
#define DRIZZLED_PLUGIN_NULL_CLIENT_H
22
22
 
23
23
#include <drizzled/plugin/client.h>
24
 
#include<boost/tokenizer.hpp>
25
 
#include <vector>
26
 
#include <queue>
27
 
#include <string>
28
24
 
29
25
namespace drizzled
30
26
{
36
32
 */
37
33
class NullClient: public Client
38
34
{
39
 
  typedef std::vector<char> Bytes;
40
 
  typedef std::queue <Bytes> Queue;
41
 
  Queue to_execute;
42
 
  bool is_dead;
43
 
  Bytes packet_buffer;
44
 
 
45
35
public:
46
 
 
47
 
  NullClient() :
48
 
    is_dead(false)
49
 
  {
50
 
  }
51
 
 
52
36
  virtual int getFileDescriptor(void) { return -1; }
53
37
  virtual bool isConnected(void) { return true; }
54
38
  virtual bool isReading(void) { return false; }
56
40
  virtual bool flush(void) { return false; }
57
41
  virtual void close(void) {}
58
42
  virtual bool authenticate(void) { return true; }
59
 
 
60
 
  virtual bool readCommand(char **packet, uint32_t *packet_length)
61
 
  {
62
 
    while(not to_execute.empty())
63
 
    {
64
 
      Queue::value_type next= to_execute.front();
65
 
      packet_buffer.resize(next.size());
66
 
      memcpy(&packet_buffer[0], &next[0], next.size());
67
 
 
68
 
      *packet= &packet_buffer[0];
69
 
 
70
 
      *packet_length= next.size();
71
 
 
72
 
      to_execute.pop();
73
 
 
74
 
      return true;
75
 
    }
76
 
 
77
 
    if (not is_dead)
78
 
    {
79
 
      packet_buffer.resize(1);
80
 
      *packet_length= 1;
81
 
      *packet= &packet_buffer[0];
82
 
      is_dead= true;
83
 
 
84
 
      return true;
85
 
    }
86
 
 
87
 
    *packet_length= 0;
88
 
    return false;
89
 
  }
90
 
 
 
43
  virtual bool readCommand(char**, uint32_t*) { return false; }
91
44
  virtual void sendOK(void) {}
92
45
  virtual void sendEOF(void) {}
93
 
  virtual void sendError(const drizzled::error_t, const char*) {}
 
46
  virtual void sendError(uint32_t, const char*) {}
94
47
  virtual bool sendFields(List<Item>*) { return false; }
95
48
  virtual bool store(Field *) { return false; }
96
49
  virtual bool store(void) { return false; }
99
52
  virtual bool store(int64_t) { return false; }
100
53
  virtual bool store(uint64_t) { return false; }
101
54
  virtual bool store(double, uint32_t, String*) { return false; }
102
 
  virtual bool store(const type::Time*) { return false; }
 
55
  virtual bool store(const DRIZZLE_TIME*) { return false; }
103
56
  virtual bool store(const char*) { return false; }
104
57
  virtual bool store(const char*, size_t) { return false; }
105
58
  virtual bool store(const std::string &) { return false; }
106
 
  virtual bool haveMoreData(void) { return false;}
 
59
  virtual bool haveMoreData(void) { return false; }
107
60
  virtual bool haveError(void) { return false; }
108
61
  virtual bool wasAborted(void) { return false; }
109
 
 
110
 
  void pushSQL(const std::string &arg)
111
 
  {
112
 
    Bytes byte;
113
 
    typedef boost::tokenizer<boost::escaped_list_separator<char> > Tokenizer;
114
 
    Tokenizer tok(arg, boost::escaped_list_separator<char>("\\", ";", "\""));
115
 
 
116
 
    for (Tokenizer::iterator iter= tok.begin(); iter != tok.end(); ++iter)
117
 
    {
118
 
      byte.resize((*iter).size() +1); // +1 for the COM_QUERY
119
 
      byte[0]= COM_QUERY;
120
 
      memcpy(&byte[1], (*iter).c_str(), (*iter).size());
121
 
      to_execute.push(byte);
122
 
    }
123
 
  }
124
62
};
125
63
 
126
64
} /* namespace plugin */