~drizzle-trunk/drizzle/development

« back to all changes in this revision

Viewing changes to plugin/memcached_query_cache/data_dictionary_schema.h

  • Committer: Monty Taylor
  • Date: 2011-04-07 16:51:38 UTC
  • mfrom: (2263.6.2 remove_memcached_qc)
  • Revision ID: mordred@inaugust.com-20110407165138-4mbpizlwlwt5hbl1
Merge David: Remove memcached query cache

Show diffs side-by-side

added added

removed removed

Lines of Context:
1
 
/* 
2
 
 * Copyright (C) 2010 Djellel Eddine Difallah
3
 
 * All rights reserved.
4
 
 *
5
 
 * Redistribution and use in source and binary forms, with or without
6
 
 * modification, are permitted provided that the following conditions are met:
7
 
 *
8
 
 *   * Redistributions of source code must retain the above copyright notice,
9
 
 *     this list of conditions and the following disclaimer.
10
 
 *   * Redistributions in binary form must reproduce the above copyright notice,
11
 
 *     this list of conditions and the following disclaimer in the documentation
12
 
 *     and/or other materials provided with the distribution.
13
 
 *   * Neither the name of Djellel Eddine Difallah nor the names of its contributors
14
 
 *     may be used to endorse or promote products derived from this software
15
 
 *     without specific prior written permission.
16
 
 *
17
 
 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
18
 
 * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
19
 
 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
20
 
 * ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE
21
 
 * LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
22
 
 * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
23
 
 * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
24
 
 * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
25
 
 * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
26
 
 * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF
27
 
 * THE POSSIBILITY OF SUCH DAMAGE.
28
 
 */
29
 
 
30
 
#pragma once
31
 
 
32
 
#include <drizzled/plugin/table_function.h>
33
 
#include <drizzled/field.h>
34
 
 
35
 
namespace drizzled
36
 
{
37
 
class QueryCacheService;
38
 
 
39
 
class QueryCacheTool : public drizzled::plugin::TableFunction
40
 
{
41
 
public:
42
 
 
43
 
  QueryCacheTool();
44
 
 
45
 
  class Generator : public drizzled::plugin::TableFunction::Generator
46
 
  {
47
 
  public:
48
 
    Generator(drizzled::Field **arg);
49
 
    bool populate();
50
 
  private:
51
 
    QueryCacheService::CacheEntries::iterator it;
52
 
    QueryCacheService::CacheEntries::iterator end;
53
 
  };
54
 
 
55
 
  Generator *generator(drizzled::Field **arg)
56
 
  {
57
 
    return new Generator(arg);
58
 
  }
59
 
};
60
 
 
61
 
class CachedTables : public drizzled::plugin::TableFunction
62
 
{
63
 
public:
64
 
 
65
 
  CachedTables();
66
 
 
67
 
  class Generator : public drizzled::plugin::TableFunction::Generator
68
 
  {
69
 
  public:
70
 
    Generator(drizzled::Field **arg);
71
 
    bool populate();
72
 
  private:
73
 
    QueryCacheService::CachedTablesEntries::iterator it;
74
 
    QueryCacheService::CachedTablesEntries::iterator end;
75
 
  };
76
 
 
77
 
  Generator *generator(drizzled::Field **arg)
78
 
  {
79
 
    return new Generator(arg);
80
 
  }
81
 
};
82
 
 
83
 
class QueryCacheStatusTool : public drizzled::plugin::TableFunction
84
 
{
85
 
public:
86
 
  QueryCacheStatusTool() :
87
 
    plugin::TableFunction("DATA_DICTIONARY", "QUERY_CACHE_STATUS")
88
 
  {
89
 
    add_field("VARIABLE_NAME");
90
 
    add_field("VARIABLE_VALUE");
91
 
  }
92
 
 
93
 
  class Generator : public drizzled::plugin::TableFunction::Generator 
94
 
  {
95
 
    drizzled::drizzle_sys_var **status_var_ptr;
96
 
 
97
 
  public:
98
 
    Generator(drizzled::Field **fields);
99
 
 
100
 
    bool populate();
101
 
  };
102
 
 
103
 
  Generator *generator(drizzled::Field **arg)
104
 
  {
105
 
    return new Generator(arg);
106
 
  }
107
 
};
108
 
}