~drizzle-trunk/drizzle/development

« back to all changes in this revision

Viewing changes to plugin/myisam/my_handler.cc

* Fixes drizzled's atomics:

- fetch_and_add() was actually add_and_fetch() - fixed to have both methods correct
- compare_and_swap() was incorrect for all traits classes.  Fixed to return a bool
true only when the supplied value is actually swapped
- fixes increment() and decrement() methods and operator+=() in outer atomics class
template to call proper add_and_fetch() methods on traits classes
- Now that above are fixed, removed the hacks in Query_id and TransactionLog to
have query ID and the new transactoin ID start properly at 1.

* Transaction messages sent over replication stream now use
a real transaction ID, managed by drizzled::TransactionServices.  Previously, 
the Query_id was being used, resulting in SELECT statements incrementing the
transaction ID.

* Added a test case to ensure that DDL ops are given a transaction ID and SELECT
ops do not increment the transaction ID.

The transaction ID will be paired with a channel ID to become the global
transaction identifier.  ReplicationServices will manage the pairing of
channel and transaction ID and understand how far a particular subscriber
node has applied.

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
17
17
 *  Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA  02110-1301  USA
18
18
 */
19
19
 
20
 
#include <config.h>
 
20
#include "config.h"
21
21
 
22
 
#include <drizzled/charset_info.h>
 
22
#include "drizzled/charset_info.h"
23
23
#include <drizzled/base.h>
24
24
#include <plugin/myisam/my_handler.h>
25
 
#include <drizzled/internal/my_sys.h>
 
25
#include "drizzled/internal/my_sys.h"
26
26
 
27
27
#include <cassert>
28
28
#include <algorithm>
297
297
      a=  end;
298
298
      b+= 4; /* sizeof(long int); */
299
299
      break;
 
300
    case HA_KEYTYPE_UINT24:
 
301
      l_1=mi_uint3korr(a);
 
302
      l_2=mi_uint3korr(b);
 
303
      if (piks && (flag = CMP_NUM(l_1,l_2)))
 
304
        return ((keyseg->flag & HA_REVERSE_SORT) ? -flag : flag);
 
305
      a=  end;
 
306
      b+= 3;
 
307
      break;
300
308
    case HA_KEYTYPE_DOUBLE:
301
309
      mi_float8get(d_1,a);
302
310
      mi_float8get(d_2,b);
420
428
      }
421
429
    case HA_KEYTYPE_LONG_INT:
422
430
    case HA_KEYTYPE_ULONG_INT:
 
431
    case HA_KEYTYPE_UINT24:
423
432
    case HA_KEYTYPE_LONGLONG:
424
433
    case HA_KEYTYPE_ULONGLONG:
425
434
    case HA_KEYTYPE_DOUBLE: