~ubuntu-branches/ubuntu/trusty/drizzle/trusty

« back to all changes in this revision

Viewing changes to plugin/memcached_query_cache/invalidator.h

  • Committer: Bazaar Package Importer
  • Author(s): Monty Taylor
  • Date: 2010-10-02 14:17:48 UTC
  • mfrom: (1.1.1 upstream)
  • mto: (2.1.17 sid)
  • mto: This revision was merged to the branch mainline in revision 3.
  • Revision ID: james.westby@ubuntu.com-20101002141748-m6vbfbfjhrw1153e
Tags: 2010.09.1802-1
* New upstream release.
* Removed pid-file argument hack.
* Updated GPL-2 address to be new address.
* Directly copy in drizzledump.1 since debian doesn't have sphinx 1.0 yet.
* Link to jquery from libjs-jquery. Add it as a depend.
* Add drizzled.8 symlink to the install files.

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
#ifndef PLUGIN_MEMCACHED_QUERY_CACHE_INVALIDATOR_H
 
31
#define PLUGIN_MEMCACHED_QUERY_CACHE_INVALIDATOR_H
 
32
 
 
33
#include <drizzled/replication_services.h>
 
34
 
 
35
#include <drizzled/plugin/transaction_replicator.h>
 
36
#include <drizzled/plugin/transaction_applier.h>
 
37
#include <drizzled/message/transaction.pb.h>
 
38
 
 
39
#include <string>
 
40
 
 
41
namespace drizzled
 
42
{
 
43
  class Session;
 
44
}
 
45
class Invalidator : public drizzled::plugin::TransactionApplier 
 
46
{
 
47
public:
 
48
 
 
49
  Invalidator(std::string name_arg);
 
50
 
 
51
  /** Destructor */
 
52
  ~Invalidator() {}
 
53
 
 
54
  /**
 
55
   * Does something with the transaction message
 
56
   *
 
57
   * @param transaction message to be invalidated if present in the cache
 
58
   */
 
59
  drizzled::plugin::ReplicationReturnCode
 
60
  apply(drizzled::Session &in_session,
 
61
        const drizzled::message::Transaction &to_apply);
 
62
  
 
63
 
 
64
private:
 
65
 
 
66
  /**
 
67
   * Given a supplied Statement message, parse out the table
 
68
   * and schema name from the various metadata and header 
 
69
   * pieces for the different Statement types.
 
70
   *
 
71
   * @param[in] Statement to parse
 
72
   * @param[out] Schema name
 
73
   * @param[out] Table name
 
74
   */
 
75
  void parseStatementTableMetadata(const drizzled::message::Statement &in_statement,
 
76
                                   std::string &in_schema_name,
 
77
                                   std::string &in_table_name) const;
 
78
 
 
79
  /**
 
80
   * Given a schema name and table name, delete all the entries
 
81
   * of the table from the cache.
 
82
   *
 
83
   * @param[in] stmt The statement message
 
84
   * @param[in] Schema name
 
85
   * @param[in] Table name
 
86
   */
 
87
  void invalidateByTableName(const std::string &in_schema_name,
 
88
                             const std::string &in_table_name) const;
 
89
 
 
90
 
 
91
};
 
92
 
 
93
#endif /* PLUGIN_MEMCACHED_QUERY_CACHE_INVALIDATOR_H */