~drizzle-trunk/drizzle/development

« back to all changes in this revision

Viewing changes to mysys/definitions.h

  • Committer: Monty Taylor
  • Date: 2008-09-16 00:00:48 UTC
  • mto: This revision was merged to the branch mainline in revision 391.
  • Revision ID: monty@inaugust.com-20080916000048-3rvrv3gv9l0ad3gs
Fixed copyright headers in drizzled/

Show diffs side-by-side

added added

removed removed

Lines of Context:
1
 
/* -*- mode: c++; c-basic-offset: 2; indent-tabs-mode: nil; -*-
2
 
 *  vim:expandtab:shiftwidth=2:tabstop=2:smarttab:
3
 
 *
4
 
 *  Copyright (C) 2008 Sun Microsystems
5
 
 *
6
 
 *  This program is free software; you can redistribute it and/or modify
7
 
 *  it under the terms of the GNU General Public License as published by
8
 
 *  the Free Software Foundation; version 2 of the License.
9
 
 *
10
 
 *  This program is distributed in the hope that it will be useful,
11
 
 *  but WITHOUT ANY WARRANTY; without even the implied warranty of
12
 
 *  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
13
 
 *  GNU General Public License for more details.
14
 
 *
15
 
 *  You should have received a copy of the GNU General Public License
16
 
 *  along with this program; if not, write to the Free Software
17
 
 *  Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA  02110-1301  USA
18
 
 */
19
 
 
20
 
/**
21
 
 * @file
22
 
 *
23
 
 * Mostly constants and enums used by mysys
24
 
 */
25
 
 
26
 
#ifndef MYSYS_DEFINITIONS_H
27
 
#define MYSYS_DEFINITIONS_H
28
 
 
29
 
enum thr_lock_type { TL_IGNORE=-1,
30
 
                     /* UNLOCK ANY LOCK */
31
 
                     TL_UNLOCK,
32
 
                     /* Read lock */
33
 
                     TL_READ,
34
 
                     TL_READ_WITH_SHARED_LOCKS,
35
 
                     /* High prior. than TL_WRITE. Allow concurrent insert */
36
 
                     TL_READ_HIGH_PRIORITY,
37
 
                     /* READ, Don't allow concurrent insert */
38
 
                     TL_READ_NO_INSERT,
39
 
                     /*
40
 
                       Write lock, but allow other threads to read / write.
41
 
                       Used by BDB tables in MySQL to mark that someone is
42
 
                       reading/writing to the table.
43
 
                     */
44
 
                     TL_WRITE_ALLOW_WRITE,
45
 
                     /*
46
 
                       Write lock, but allow other threads to read.
47
 
                       Used by ALTER TABLE in MySQL to allow readers
48
 
                       to use the table until ALTER TABLE is finished.
49
 
                     */
50
 
                     TL_WRITE_ALLOW_READ,
51
 
                     /*
52
 
                       WRITE lock used by concurrent insert. Will allow
53
 
                       READ, if one could use concurrent insert on table.
54
 
                     */
55
 
                     TL_WRITE_CONCURRENT_INSERT,
56
 
                     /* Write used by INSERT DELAYED.  Allows READ locks */
57
 
                     TL_WRITE_DELAYED,
58
 
                     /*
59
 
                       parser only! Late bound low_priority flag.
60
 
                       At open_tables() becomes thd->update_lock_default.
61
 
                     */
62
 
                     TL_WRITE_DEFAULT,
63
 
                     /* WRITE lock that has lower priority than TL_READ */
64
 
                     TL_WRITE_LOW_PRIORITY,
65
 
                     /* Normal WRITE lock */
66
 
                     TL_WRITE,
67
 
                     /* Abort new lock request with an error */
68
 
                     TL_WRITE_ONLY};
69
 
 
70
 
enum enum_thr_lock_result { THR_LOCK_SUCCESS= 0, THR_LOCK_ABORTED= 1,
71
 
                            THR_LOCK_WAIT_TIMEOUT= 2, THR_LOCK_DEADLOCK= 3 };
72
 
 
73
 
 
74
 
#endif /* MYSYS_DEFINITIONS_H */