Commit ee616a80 authored by unknown's avatar unknown

Merge rkalimullin@work.mysql.com:/home/bk/mysql-4.1

into mysql.r18.ru:/usr/home/ram/mysql-4.1
parents d8045112 d5c26385

Too many changes to show.

To preserve performance only 1000 of 1000+ files are displayed.

...@@ -1062,24 +1062,28 @@ AC_DEFUN([MYSQL_CHECK_BDB_VERSION], [ ...@@ -1062,24 +1062,28 @@ AC_DEFUN([MYSQL_CHECK_BDB_VERSION], [
test -z "$db_patch" && db_patch=0 test -z "$db_patch" && db_patch=0
# This is ugly, but about as good as it can get # This is ugly, but about as good as it can get
mysql_bdb= # mysql_bdb=
if test $db_major -eq 3 && test $db_minor -eq 2 && test $db_patch -eq 3 # if test $db_major -eq 3 && test $db_minor -eq 2 && test $db_patch -eq 3
then # then
mysql_bdb=h # mysql_bdb=h
elif test $db_major -eq 3 && test $db_minor -eq 2 && test $db_patch -eq 9 # elif test $db_major -eq 3 && test $db_minor -eq 2 && test $db_patch -eq 9
then # then
want_bdb_version="3.2.9a" # hopefully this will stay up-to-date # want_bdb_version="3.2.9a" # hopefully this will stay up-to-date
mysql_bdb=a # mysql_bdb=a
fi # fi
if test -n "$mysql_bdb" && \ dbl RAM:
grep "DB_VERSION_STRING.*:.*$mysql_bdb: " [$1] > /dev/null want_bdb_version="4.1.24"
then bdb_version_ok=yes
bdb_version_ok=yes
else # if test -n "$mysql_bdb" && \
bdb_version_ok="invalid version $db_major.$db_minor.$db_patch" # grep "DB_VERSION_STRING.*:.*$mysql_bdb: " [$1] > /dev/null
bdb_version_ok="$bdb_version_ok (must be version 3.2.3h or $want_bdb_version)" # then
fi # bdb_version_ok=yes
# else
# bdb_version_ok="invalid version $db_major.$db_minor.$db_patch"
# bdb_version_ok="$bdb_version_ok (must be version 3.2.3h or $want_bdb_version)"
# fi
]) ])
AC_DEFUN([MYSQL_TOP_BUILDDIR], [ AC_DEFUN([MYSQL_TOP_BUILDDIR], [
......
/*- /*-
* $Id: LICENSE,v 11.7 2000/11/01 20:35:49 bostic Exp $ * $Id: LICENSE,v 11.9 2002/01/11 15:51:10 bostic Exp $
*/ */
The following is the license that applies to this copy of the Berkeley DB The following is the license that applies to this copy of the Berkeley DB
...@@ -10,7 +10,7 @@ Web at http://www.sleepycat.com. ...@@ -10,7 +10,7 @@ Web at http://www.sleepycat.com.
=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-= =-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=
/* /*
* Copyright (c) 1990-2000 * Copyright (c) 1990-2002
* Sleepycat Software. All rights reserved. * Sleepycat Software. All rights reserved.
* *
* Redistribution and use in source and binary forms, with or without * Redistribution and use in source and binary forms, with or without
......
/*- /*-
* See the file LICENSE for redistribution information. * See the file LICENSE for redistribution information.
* *
* Copyright (c) 1996, 1997, 1998, 1999, 2000 * Copyright (c) 1996-2002
* Sleepycat Software. All rights reserved. * Sleepycat Software. All rights reserved.
*/ */
/* /*
...@@ -43,7 +43,7 @@ ...@@ -43,7 +43,7 @@
#include "db_config.h" #include "db_config.h"
#ifndef lint #ifndef lint
static const char revid[] = "$Id: bt_compare.c,v 11.12 2000/10/26 19:00:28 krinsky Exp $"; static const char revid[] = "$Id: bt_compare.c,v 11.17 2002/03/27 04:30:42 bostic Exp $";
#endif /* not lint */ #endif /* not lint */
#ifndef NO_SYSTEM_INCLUDES #ifndef NO_SYSTEM_INCLUDES
...@@ -51,8 +51,8 @@ static const char revid[] = "$Id: bt_compare.c,v 11.12 2000/10/26 19:00:28 krins ...@@ -51,8 +51,8 @@ static const char revid[] = "$Id: bt_compare.c,v 11.12 2000/10/26 19:00:28 krins
#endif #endif
#include "db_int.h" #include "db_int.h"
#include "db_page.h" #include "dbinc/db_page.h"
#include "btree.h" #include "dbinc/btree.h"
/* /*
* __bam_cmp -- * __bam_cmp --
...@@ -92,7 +92,7 @@ __bam_cmp(dbp, dbt, h, indx, func, cmpp) ...@@ -92,7 +92,7 @@ __bam_cmp(dbp, dbt, h, indx, func, cmpp)
case P_LBTREE: case P_LBTREE:
case P_LDUP: case P_LDUP:
case P_LRECNO: case P_LRECNO:
bk = GET_BKEYDATA(h, indx); bk = GET_BKEYDATA(dbp, h, indx);
if (B_TYPE(bk->type) == B_OVERFLOW) if (B_TYPE(bk->type) == B_OVERFLOW)
bo = (BOVERFLOW *)bk; bo = (BOVERFLOW *)bk;
else { else {
...@@ -125,7 +125,7 @@ __bam_cmp(dbp, dbt, h, indx, func, cmpp) ...@@ -125,7 +125,7 @@ __bam_cmp(dbp, dbt, h, indx, func, cmpp)
return (0); return (0);
} }
bi = GET_BINTERNAL(h, indx); bi = GET_BINTERNAL(dbp, h, indx);
if (B_TYPE(bi->type) == B_OVERFLOW) if (B_TYPE(bi->type) == B_OVERFLOW)
bo = (BOVERFLOW *)(bi->data); bo = (BOVERFLOW *)(bi->data);
else { else {
...@@ -136,7 +136,7 @@ __bam_cmp(dbp, dbt, h, indx, func, cmpp) ...@@ -136,7 +136,7 @@ __bam_cmp(dbp, dbt, h, indx, func, cmpp)
} }
break; break;
default: default:
return (__db_pgfmt(dbp, PGNO(h))); return (__db_pgfmt(dbp->dbenv, PGNO(h)));
} }
/* /*
......
/*- /*-
* See the file LICENSE for redistribution information. * See the file LICENSE for redistribution information.
* *
* Copyright (c) 1996, 1997, 1998, 1999, 2000 * Copyright (c) 1996-2002
* Sleepycat Software. All rights reserved. * Sleepycat Software. All rights reserved.
*/ */
#include "db_config.h" #include "db_config.h"
#ifndef lint #ifndef lint
static const char revid[] = "$Id: bt_conv.c,v 11.6 2000/03/31 00:30:26 ubell Exp $"; static const char revid[] = "$Id: bt_conv.c,v 11.13 2002/08/06 06:11:12 bostic Exp $";
#endif /* not lint */ #endif /* not lint */
#ifndef NO_SYSTEM_INCLUDES #ifndef NO_SYSTEM_INCLUDES
...@@ -16,20 +16,21 @@ static const char revid[] = "$Id: bt_conv.c,v 11.6 2000/03/31 00:30:26 ubell Exp ...@@ -16,20 +16,21 @@ static const char revid[] = "$Id: bt_conv.c,v 11.6 2000/03/31 00:30:26 ubell Exp
#endif #endif
#include "db_int.h" #include "db_int.h"
#include "db_page.h" #include "dbinc/db_page.h"
#include "db_swap.h" #include "dbinc/db_swap.h"
#include "btree.h" #include "dbinc/btree.h"
/* /*
* __bam_pgin -- * __bam_pgin --
* Convert host-specific page layout from the host-independent format * Convert host-specific page layout from the host-independent format
* stored on disk. * stored on disk.
* *
* PUBLIC: int __bam_pgin __P((DB_ENV *, db_pgno_t, void *, DBT *)); * PUBLIC: int __bam_pgin __P((DB_ENV *, DB *, db_pgno_t, void *, DBT *));
*/ */
int int
__bam_pgin(dbenv, pg, pp, cookie) __bam_pgin(dbenv, dummydbp, pg, pp, cookie)
DB_ENV *dbenv; DB_ENV *dbenv;
DB *dummydbp;
db_pgno_t pg; db_pgno_t pg;
void *pp; void *pp;
DBT *cookie; DBT *cookie;
...@@ -38,12 +39,12 @@ __bam_pgin(dbenv, pg, pp, cookie) ...@@ -38,12 +39,12 @@ __bam_pgin(dbenv, pg, pp, cookie)
PAGE *h; PAGE *h;
pginfo = (DB_PGINFO *)cookie->data; pginfo = (DB_PGINFO *)cookie->data;
if (!pginfo->needswap) if (!F_ISSET(pginfo, DB_AM_SWAP))
return (0); return (0);
h = pp; h = pp;
return (TYPE(h) == P_BTREEMETA ? __bam_mswap(pp) : return (TYPE(h) == P_BTREEMETA ? __bam_mswap(pp) :
__db_byteswap(dbenv, pg, pp, pginfo->db_pagesize, 1)); __db_byteswap(dbenv, dummydbp, pg, pp, pginfo->db_pagesize, 1));
} }
/* /*
...@@ -51,11 +52,12 @@ __bam_pgin(dbenv, pg, pp, cookie) ...@@ -51,11 +52,12 @@ __bam_pgin(dbenv, pg, pp, cookie)
* Convert host-specific page layout to the host-independent format * Convert host-specific page layout to the host-independent format
* stored on disk. * stored on disk.
* *
* PUBLIC: int __bam_pgout __P((DB_ENV *, db_pgno_t, void *, DBT *)); * PUBLIC: int __bam_pgout __P((DB_ENV *, DB *, db_pgno_t, void *, DBT *));
*/ */
int int
__bam_pgout(dbenv, pg, pp, cookie) __bam_pgout(dbenv, dummydbp, pg, pp, cookie)
DB_ENV *dbenv; DB_ENV *dbenv;
DB *dummydbp;
db_pgno_t pg; db_pgno_t pg;
void *pp; void *pp;
DBT *cookie; DBT *cookie;
...@@ -64,12 +66,12 @@ __bam_pgout(dbenv, pg, pp, cookie) ...@@ -64,12 +66,12 @@ __bam_pgout(dbenv, pg, pp, cookie)
PAGE *h; PAGE *h;
pginfo = (DB_PGINFO *)cookie->data; pginfo = (DB_PGINFO *)cookie->data;
if (!pginfo->needswap) if (!F_ISSET(pginfo, DB_AM_SWAP))
return (0); return (0);
h = pp; h = pp;
return (TYPE(h) == P_BTREEMETA ? __bam_mswap(pp) : return (TYPE(h) == P_BTREEMETA ? __bam_mswap(pp) :
__db_byteswap(dbenv, pg, pp, pginfo->db_pagesize, 0)); __db_byteswap(dbenv, dummydbp, pg, pp, pginfo->db_pagesize, 0));
} }
/* /*
...@@ -93,6 +95,8 @@ __bam_mswap(pg) ...@@ -93,6 +95,8 @@ __bam_mswap(pg)
SWAP32(p); /* re_len */ SWAP32(p); /* re_len */
SWAP32(p); /* re_pad */ SWAP32(p); /* re_pad */
SWAP32(p); /* root */ SWAP32(p); /* root */
p += 92 * sizeof(u_int32_t); /* unused */
SWAP32(p); /* crypto_magic */
return (0); return (0);
} }
/*- /*-
* See the file LICENSE for redistribution information. * See the file LICENSE for redistribution information.
* *
* Copyright (c) 1996, 1997, 1998, 1999, 2000 * Copyright (c) 1996-2002
* Sleepycat Software. All rights reserved. * Sleepycat Software. All rights reserved.
*/ */
#include "db_config.h" #include "db_config.h"
#ifndef lint #ifndef lint
static const char revid[] = "$Id: bt_curadj.c,v 11.20 2001/01/17 16:15:49 bostic Exp $"; static const char revid[] = "$Id: bt_curadj.c,v 11.30 2002/07/03 19:03:48 bostic Exp $";
#endif /* not lint */ #endif /* not lint */
#ifndef NO_SYSTEM_INCLUDES #ifndef NO_SYSTEM_INCLUDES
...@@ -16,9 +16,8 @@ static const char revid[] = "$Id: bt_curadj.c,v 11.20 2001/01/17 16:15:49 bostic ...@@ -16,9 +16,8 @@ static const char revid[] = "$Id: bt_curadj.c,v 11.20 2001/01/17 16:15:49 bostic
#endif #endif
#include "db_int.h" #include "db_int.h"
#include "db_page.h" #include "dbinc/db_page.h"
#include "btree.h" #include "dbinc/btree.h"
#include "txn.h"
static int __bam_opd_cursor __P((DB *, DBC *, db_pgno_t, u_int32_t, u_int32_t)); static int __bam_opd_cursor __P((DB *, DBC *, db_pgno_t, u_int32_t, u_int32_t));
...@@ -203,10 +202,9 @@ __bam_ca_di(my_dbc, pgno, indx, adjust) ...@@ -203,10 +202,9 @@ __bam_ca_di(my_dbc, pgno, indx, adjust)
} }
MUTEX_THREAD_UNLOCK(dbenv, dbenv->dblist_mutexp); MUTEX_THREAD_UNLOCK(dbenv, dbenv->dblist_mutexp);
if (found != 0 && DB_LOGGING(my_dbc)) { if (found != 0 && DBC_LOGGING(my_dbc)) {
if ((ret = __bam_curadj_log(dbenv, if ((ret = __bam_curadj_log(dbp, my_dbc->txn,
my_dbc->txn, &lsn, 0, dbp->log_fileid, &lsn, 0, DB_CA_DI, pgno, 0, 0, adjust, indx, 0)) != 0)
DB_CA_DI, pgno, 0, 0, adjust, indx, 0)) != 0)
return (ret); return (ret);
} }
...@@ -234,8 +232,13 @@ __bam_opd_cursor(dbp, dbc, first, tpgno, ti) ...@@ -234,8 +232,13 @@ __bam_opd_cursor(dbp, dbc, first, tpgno, ti)
* Allocate a new cursor and create the stack. If duplicates * Allocate a new cursor and create the stack. If duplicates
* are sorted, we've just created an off-page duplicate Btree. * are sorted, we've just created an off-page duplicate Btree.
* If duplicates aren't sorted, we've just created a Recno tree. * If duplicates aren't sorted, we've just created a Recno tree.
*
* Note that in order to get here at all, there shouldn't be
* an old off-page dup cursor--to augment the checking db_c_newopd
* will do, assert this.
*/ */
if ((ret = __db_c_newopd(dbc, tpgno, &dbc_nopd)) != 0) DB_ASSERT(orig_cp->opd == NULL);
if ((ret = __db_c_newopd(dbc, tpgno, orig_cp->opd, &dbc_nopd)) != 0)
return (ret); return (ret);
cp = (BTREE_CURSOR *)dbc_nopd->internal; cp = (BTREE_CURSOR *)dbc_nopd->internal;
...@@ -321,17 +324,16 @@ loop: MUTEX_THREAD_LOCK(dbenv, dbp->mutexp); ...@@ -321,17 +324,16 @@ loop: MUTEX_THREAD_LOCK(dbenv, dbp->mutexp);
return (ret); return (ret);
if (my_txn != NULL && dbc->txn != my_txn) if (my_txn != NULL && dbc->txn != my_txn)
found = 1; found = 1;
/* We released the MUTEX to get a cursor, start over. */ /* We released the mutex to get a cursor, start over. */
goto loop; goto loop;
} }
MUTEX_THREAD_UNLOCK(dbenv, dbp->mutexp); MUTEX_THREAD_UNLOCK(dbenv, dbp->mutexp);
} }
MUTEX_THREAD_UNLOCK(dbenv, dbenv->dblist_mutexp); MUTEX_THREAD_UNLOCK(dbenv, dbenv->dblist_mutexp);
if (found != 0 && DB_LOGGING(my_dbc)) { if (found != 0 && DBC_LOGGING(my_dbc)) {
if ((ret = __bam_curadj_log(dbenv, if ((ret = __bam_curadj_log(dbp, my_dbc->txn,
my_dbc->txn, &lsn, 0, dbp->log_fileid, &lsn, 0, DB_CA_DUP, fpgno, tpgno, 0, first, fi, ti)) != 0)
DB_CA_DUP, fpgno, tpgno, 0, first, fi, ti)) != 0)
return (ret); return (ret);
} }
return (0); return (0);
...@@ -372,8 +374,16 @@ loop: MUTEX_THREAD_LOCK(dbenv, dbp->mutexp); ...@@ -372,8 +374,16 @@ loop: MUTEX_THREAD_LOCK(dbenv, dbp->mutexp);
dbc != NULL; dbc = TAILQ_NEXT(dbc, links)) { dbc != NULL; dbc = TAILQ_NEXT(dbc, links)) {
orig_cp = (BTREE_CURSOR *)dbc->internal; orig_cp = (BTREE_CURSOR *)dbc->internal;
/*
* A note on the orig_cp->opd != NULL requirement here:
* it's possible that there's a cursor that refers to
* the same duplicate set, but which has no opd cursor,
* because it refers to a different item and we took
* care of it while processing a previous record.
*/
if (orig_cp->pgno != fpgno || if (orig_cp->pgno != fpgno ||
orig_cp->indx != first || orig_cp->indx != first ||
orig_cp->opd == NULL ||
((BTREE_CURSOR *)orig_cp->opd->internal)->indx ((BTREE_CURSOR *)orig_cp->opd->internal)->indx
!= ti) != ti)
continue; continue;
...@@ -383,7 +393,7 @@ loop: MUTEX_THREAD_LOCK(dbenv, dbp->mutexp); ...@@ -383,7 +393,7 @@ loop: MUTEX_THREAD_LOCK(dbenv, dbp->mutexp);
orig_cp->opd = NULL; orig_cp->opd = NULL;
orig_cp->indx = fi; orig_cp->indx = fi;
/* /*
* We released the MUTEX to free a cursor, * We released the mutex to free a cursor,
* start over. * start over.
*/ */
goto loop; goto loop;
...@@ -440,10 +450,9 @@ __bam_ca_rsplit(my_dbc, fpgno, tpgno) ...@@ -440,10 +450,9 @@ __bam_ca_rsplit(my_dbc, fpgno, tpgno)
} }
MUTEX_THREAD_UNLOCK(dbenv, dbenv->dblist_mutexp); MUTEX_THREAD_UNLOCK(dbenv, dbenv->dblist_mutexp);
if (found != 0 && DB_LOGGING(my_dbc)) { if (found != 0 && DBC_LOGGING(my_dbc)) {
if ((ret = __bam_curadj_log(dbenv, if ((ret = __bam_curadj_log(dbp, my_dbc->txn,
my_dbc->txn, &lsn, 0, dbp->log_fileid, &lsn, 0, DB_CA_RSPLIT, fpgno, tpgno, 0, 0, 0, 0)) != 0)
DB_CA_RSPLIT, fpgno, tpgno, 0, 0, 0, 0)) != 0)
return (ret); return (ret);
} }
return (0); return (0);
...@@ -512,9 +521,9 @@ __bam_ca_split(my_dbc, ppgno, lpgno, rpgno, split_indx, cleft) ...@@ -512,9 +521,9 @@ __bam_ca_split(my_dbc, ppgno, lpgno, rpgno, split_indx, cleft)
} }
MUTEX_THREAD_UNLOCK(dbenv, dbenv->dblist_mutexp); MUTEX_THREAD_UNLOCK(dbenv, dbenv->dblist_mutexp);
if (found != 0 && DB_LOGGING(my_dbc)) { if (found != 0 && DBC_LOGGING(my_dbc)) {
if ((ret = __bam_curadj_log(dbenv, my_dbc->txn, if ((ret = __bam_curadj_log(dbp,
&lsn, 0, dbp->log_fileid, DB_CA_SPLIT, ppgno, rpgno, my_dbc->txn, &lsn, 0, DB_CA_SPLIT, ppgno, rpgno,
cleft ? lpgno : PGNO_INVALID, 0, split_indx, 0)) != 0) cleft ? lpgno : PGNO_INVALID, 0, split_indx, 0)) != 0)
return (ret); return (ret);
} }
......
This diff is collapsed.
This diff is collapsed.
/*- /*-
* See the file LICENSE for redistribution information. * See the file LICENSE for redistribution information.
* *
* Copyright (c) 1999, 2000 * Copyright (c) 1999-2002
* Sleepycat Software. All rights reserved. * Sleepycat Software. All rights reserved.
*/ */
#include "db_config.h" #include "db_config.h"
#ifndef lint #ifndef lint
static const char revid[] = "$Id: bt_method.c,v 11.20 2000/11/30 00:58:28 ubell Exp $"; static const char revid[] = "$Id: bt_method.c,v 11.29 2002/04/21 13:17:04 margo Exp $";
#endif /* not lint */ #endif /* not lint */
#ifndef NO_SYSTEM_INCLUDES #ifndef NO_SYSTEM_INCLUDES
...@@ -16,9 +16,9 @@ static const char revid[] = "$Id: bt_method.c,v 11.20 2000/11/30 00:58:28 ubell ...@@ -16,9 +16,9 @@ static const char revid[] = "$Id: bt_method.c,v 11.20 2000/11/30 00:58:28 ubell
#endif #endif
#include "db_int.h" #include "db_int.h"
#include "db_page.h" #include "dbinc/db_page.h"
#include "btree.h" #include "dbinc/btree.h"
#include "qam.h" #include "dbinc/qam.h"
static int __bam_set_bt_compare static int __bam_set_bt_compare
__P((DB *, int (*)(DB *, const DBT *, const DBT *))); __P((DB *, int (*)(DB *, const DBT *, const DBT *)));
...@@ -82,7 +82,8 @@ __bam_db_close(dbp) ...@@ -82,7 +82,8 @@ __bam_db_close(dbp)
{ {
BTREE *t; BTREE *t;
t = dbp->bt_internal; if ((t = dbp->bt_internal) == NULL)
return (0);
/* Recno */ /* Recno */
/* Close any backing source file descriptor. */ /* Close any backing source file descriptor. */
if (t->re_fp != NULL) if (t->re_fp != NULL)
...@@ -90,9 +91,9 @@ __bam_db_close(dbp) ...@@ -90,9 +91,9 @@ __bam_db_close(dbp)
/* Free any backing source file name. */ /* Free any backing source file name. */
if (t->re_source != NULL) if (t->re_source != NULL)
__os_freestr(t->re_source); __os_free(dbp->dbenv, t->re_source);
__os_free(t, sizeof(BTREE)); __os_free(dbp->dbenv, t);
dbp->bt_internal = NULL; dbp->bt_internal = NULL;
return (0); return (0);
...@@ -127,7 +128,7 @@ __bam_set_flags(dbp, flagsp) ...@@ -127,7 +128,7 @@ __bam_set_flags(dbp, flagsp)
if (LF_ISSET(DB_DUP | DB_DUPSORT)) { if (LF_ISSET(DB_DUP | DB_DUPSORT)) {
/* DB_DUP/DB_DUPSORT is incompatible with DB_RECNUM. */ /* DB_DUP/DB_DUPSORT is incompatible with DB_RECNUM. */
if (F_ISSET(dbp, DB_BT_RECNUM)) if (F_ISSET(dbp, DB_AM_RECNUM))
goto incompat; goto incompat;
if (LF_ISSET(DB_DUPSORT)) { if (LF_ISSET(DB_DUPSORT)) {
...@@ -145,12 +146,12 @@ __bam_set_flags(dbp, flagsp) ...@@ -145,12 +146,12 @@ __bam_set_flags(dbp, flagsp)
if (F_ISSET(dbp, DB_AM_DUP)) if (F_ISSET(dbp, DB_AM_DUP))
goto incompat; goto incompat;
F_SET(dbp, DB_BT_RECNUM); F_SET(dbp, DB_AM_RECNUM);
LF_CLR(DB_RECNUM); LF_CLR(DB_RECNUM);
} }
if (LF_ISSET(DB_REVSPLITOFF)) { if (LF_ISSET(DB_REVSPLITOFF)) {
F_SET(dbp, DB_BT_REVSPLIT); F_SET(dbp, DB_AM_REVSPLITOFF);
LF_CLR(DB_REVSPLITOFF); LF_CLR(DB_REVSPLITOFF);
} }
...@@ -279,12 +280,12 @@ __ram_set_flags(dbp, flagsp) ...@@ -279,12 +280,12 @@ __ram_set_flags(dbp, flagsp)
DB_ILLEGAL_METHOD(dbp, DB_OK_RECNO); DB_ILLEGAL_METHOD(dbp, DB_OK_RECNO);
if (LF_ISSET(DB_RENUMBER)) { if (LF_ISSET(DB_RENUMBER)) {
F_SET(dbp, DB_RE_RENUMBER); F_SET(dbp, DB_AM_RENUMBER);
LF_CLR(DB_RENUMBER); LF_CLR(DB_RENUMBER);
} }
if (LF_ISSET(DB_SNAPSHOT)) { if (LF_ISSET(DB_SNAPSHOT)) {
F_SET(dbp, DB_RE_SNAPSHOT); F_SET(dbp, DB_AM_SNAPSHOT);
LF_CLR(DB_SNAPSHOT); LF_CLR(DB_SNAPSHOT);
} }
...@@ -310,7 +311,7 @@ __ram_set_re_delim(dbp, re_delim) ...@@ -310,7 +311,7 @@ __ram_set_re_delim(dbp, re_delim)
t = dbp->bt_internal; t = dbp->bt_internal;
t->re_delim = re_delim; t->re_delim = re_delim;
F_SET(dbp, DB_RE_DELIMITER); F_SET(dbp, DB_AM_DELIMITER);
return (0); return (0);
} }
...@@ -336,7 +337,7 @@ __ram_set_re_len(dbp, re_len) ...@@ -336,7 +337,7 @@ __ram_set_re_len(dbp, re_len)
q = dbp->q_internal; q = dbp->q_internal;
q->re_len = re_len; q->re_len = re_len;
F_SET(dbp, DB_RE_FIXEDLEN); F_SET(dbp, DB_AM_FIXEDLEN);
return (0); return (0);
} }
...@@ -362,7 +363,7 @@ __ram_set_re_pad(dbp, re_pad) ...@@ -362,7 +363,7 @@ __ram_set_re_pad(dbp, re_pad)
q = dbp->q_internal; q = dbp->q_internal;
q->re_pad = re_pad; q->re_pad = re_pad;
F_SET(dbp, DB_RE_PAD); F_SET(dbp, DB_AM_PAD);
return (0); return (0);
} }
......
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
/*- /*-
* See the file LICENSE for redistribution information. * See the file LICENSE for redistribution information.
* *
* Copyright (c) 1998, 1999, 2000 * Copyright (c) 1998-2002
* Sleepycat Software. All rights reserved. * Sleepycat Software. All rights reserved.
*/ */
#include "db_config.h" #include "db_config.h"
#ifndef lint #ifndef lint
static const char revid[] = "$Id: bt_reclaim.c,v 11.5 2000/03/22 04:21:01 ubell Exp $"; static const char revid[] = "$Id: bt_reclaim.c,v 11.11 2002/03/29 20:46:26 bostic Exp $";
#endif /* not lint */ #endif /* not lint */
#ifndef NO_SYSTEM_INCLUDES #ifndef NO_SYSTEM_INCLUDES
...@@ -18,10 +18,8 @@ static const char revid[] = "$Id: bt_reclaim.c,v 11.5 2000/03/22 04:21:01 ubell ...@@ -18,10 +18,8 @@ static const char revid[] = "$Id: bt_reclaim.c,v 11.5 2000/03/22 04:21:01 ubell
#endif #endif
#include "db_int.h" #include "db_int.h"
#include "db_page.h" #include "dbinc/db_page.h"
#include "db_shash.h" #include "dbinc/btree.h"
#include "lock.h"
#include "btree.h"
/* /*
* __bam_reclaim -- * __bam_reclaim --
...@@ -51,3 +49,38 @@ __bam_reclaim(dbp, txn) ...@@ -51,3 +49,38 @@ __bam_reclaim(dbp, txn)
return (ret); return (ret);
} }
/*
* __bam_truncate --
* Truncate a database.
*
* PUBLIC: int __bam_truncate __P((DB *, DB_TXN *, u_int32_t *));
*/
int
__bam_truncate(dbp, txn, countp)
DB *dbp;
DB_TXN *txn;
u_int32_t *countp;
{
DBC *dbc;
db_trunc_param trunc;
int ret, t_ret;
/* Acquire a cursor. */
if ((ret = dbp->cursor(dbp, txn, &dbc, 0)) != 0)
return (ret);
trunc.count = 0;
trunc.dbc = dbc;
/* Walk the tree, freeing pages. */
ret = __bam_traverse(dbc,
DB_LOCK_WRITE, dbc->internal->root, __db_truncate_callback, &trunc);
/* Discard the cursor. */
if ((t_ret = dbc->c_close(dbc)) != 0 && ret == 0)
ret = t_ret;
*countp = trunc.count;
return (ret);
}
This diff is collapsed.
/*- /*-
* See the file LICENSE for redistribution information. * See the file LICENSE for redistribution information.
* *
* Copyright (c) 1996, 1997, 1998, 1999, 2000 * Copyright (c) 1996-2002
* Sleepycat Software. All rights reserved. * Sleepycat Software. All rights reserved.
*/ */
/* /*
...@@ -40,7 +40,7 @@ ...@@ -40,7 +40,7 @@
#include "db_config.h" #include "db_config.h"
#ifndef lint #ifndef lint
static const char revid[] = "$Id: bt_rsearch.c,v 11.21 2000/03/28 21:50:04 ubell Exp $"; static const char revid[] = "$Id: bt_rsearch.c,v 11.34 2002/07/03 19:03:50 bostic Exp $";
#endif /* not lint */ #endif /* not lint */
#ifndef NO_SYSTEM_INCLUDES #ifndef NO_SYSTEM_INCLUDES
...@@ -48,10 +48,10 @@ static const char revid[] = "$Id: bt_rsearch.c,v 11.21 2000/03/28 21:50:04 ubell ...@@ -48,10 +48,10 @@ static const char revid[] = "$Id: bt_rsearch.c,v 11.21 2000/03/28 21:50:04 ubell
#endif #endif
#include "db_int.h" #include "db_int.h"
#include "db_page.h" #include "dbinc/db_page.h"
#include "btree.h" #include "dbinc/btree.h"
#include "db_shash.h" #include "dbinc/db_shash.h"
#include "lock.h" #include "dbinc/lock.h"
/* /*
* __bam_rsearch -- * __bam_rsearch --
...@@ -70,6 +70,7 @@ __bam_rsearch(dbc, recnop, flags, stop, exactp) ...@@ -70,6 +70,7 @@ __bam_rsearch(dbc, recnop, flags, stop, exactp)
BTREE_CURSOR *cp; BTREE_CURSOR *cp;
DB *dbp; DB *dbp;
DB_LOCK lock; DB_LOCK lock;
DB_MPOOLFILE *mpf;
PAGE *h; PAGE *h;
RINTERNAL *ri; RINTERNAL *ri;
db_indx_t adjust, deloffset, indx, top; db_indx_t adjust, deloffset, indx, top;
...@@ -79,6 +80,7 @@ __bam_rsearch(dbc, recnop, flags, stop, exactp) ...@@ -79,6 +80,7 @@ __bam_rsearch(dbc, recnop, flags, stop, exactp)
int ret, stack; int ret, stack;
dbp = dbc->dbp; dbp = dbc->dbp;
mpf = dbp->mpf;
cp = (BTREE_CURSOR *)dbc->internal; cp = (BTREE_CURSOR *)dbc->internal;
BT_STK_CLR(cp); BT_STK_CLR(cp);
...@@ -99,11 +101,11 @@ __bam_rsearch(dbc, recnop, flags, stop, exactp) ...@@ -99,11 +101,11 @@ __bam_rsearch(dbc, recnop, flags, stop, exactp)
* Retrieve the root page. * Retrieve the root page.
*/ */
pg = cp->root; pg = cp->root;
stack = LF_ISSET(S_STACK); stack = LF_ISSET(S_STACK) ? 1 : 0;
lock_mode = stack ? DB_LOCK_WRITE : DB_LOCK_READ; lock_mode = stack ? DB_LOCK_WRITE : DB_LOCK_READ;
if ((ret = __db_lget(dbc, 0, pg, lock_mode, 0, &lock)) != 0) if ((ret = __db_lget(dbc, 0, pg, lock_mode, 0, &lock)) != 0)
return (ret); return (ret);
if ((ret = memp_fget(dbp->mpf, &pg, 0, &h)) != 0) { if ((ret = mpf->get(mpf, &pg, 0, &h)) != 0) {
/* Did not read it, so we can release the lock */ /* Did not read it, so we can release the lock */
(void)__LPUT(dbc, lock); (void)__LPUT(dbc, lock);
return (ret); return (ret);
...@@ -120,12 +122,12 @@ __bam_rsearch(dbc, recnop, flags, stop, exactp) ...@@ -120,12 +122,12 @@ __bam_rsearch(dbc, recnop, flags, stop, exactp)
if (!stack && if (!stack &&
((LF_ISSET(S_PARENT) && (u_int8_t)(stop + 1) >= h->level) || ((LF_ISSET(S_PARENT) && (u_int8_t)(stop + 1) >= h->level) ||
(LF_ISSET(S_WRITE) && h->level == LEAFLEVEL))) { (LF_ISSET(S_WRITE) && h->level == LEAFLEVEL))) {
(void)memp_fput(dbp->mpf, h, 0); (void)mpf->put(mpf, h, 0);
(void)__LPUT(dbc, lock); (void)__LPUT(dbc, lock);
lock_mode = DB_LOCK_WRITE; lock_mode = DB_LOCK_WRITE;
if ((ret = __db_lget(dbc, 0, pg, lock_mode, 0, &lock)) != 0) if ((ret = __db_lget(dbc, 0, pg, lock_mode, 0, &lock)) != 0)
return (ret); return (ret);
if ((ret = memp_fget(dbp->mpf, &pg, 0, &h)) != 0) { if ((ret = mpf->get(mpf, &pg, 0, &h)) != 0) {
/* Did not read it, so we can release the lock */ /* Did not read it, so we can release the lock */
(void)__LPUT(dbc, lock); (void)__LPUT(dbc, lock);
return (ret); return (ret);
...@@ -164,7 +166,7 @@ __bam_rsearch(dbc, recnop, flags, stop, exactp) ...@@ -164,7 +166,7 @@ __bam_rsearch(dbc, recnop, flags, stop, exactp)
* eliminate any concurrency. A possible fix * eliminate any concurrency. A possible fix
* would be to lock the last leaf page instead. * would be to lock the last leaf page instead.
*/ */
(void)memp_fput(dbp->mpf, h, 0); (void)mpf->put(mpf, h, 0);
(void)__TLPUT(dbc, lock); (void)__TLPUT(dbc, lock);
return (DB_NOTFOUND); return (DB_NOTFOUND);
} }
...@@ -202,8 +204,8 @@ __bam_rsearch(dbc, recnop, flags, stop, exactp) ...@@ -202,8 +204,8 @@ __bam_rsearch(dbc, recnop, flags, stop, exactp)
goto err; goto err;
} }
} }
if (!B_DISSET( if (!B_DISSET(GET_BKEYDATA(dbp, h,
GET_BKEYDATA(h, indx + deloffset)->type) && indx + deloffset)->type) &&
++t_recno == recno) ++t_recno == recno)
break; break;
} }
...@@ -216,7 +218,7 @@ __bam_rsearch(dbc, recnop, flags, stop, exactp) ...@@ -216,7 +218,7 @@ __bam_rsearch(dbc, recnop, flags, stop, exactp)
return (0); return (0);
case P_IBTREE: case P_IBTREE:
for (indx = 0, top = NUM_ENT(h);;) { for (indx = 0, top = NUM_ENT(h);;) {
bi = GET_BINTERNAL(h, indx); bi = GET_BINTERNAL(dbp, h, indx);
if (++indx == top || total + bi->nrecs >= recno) if (++indx == top || total + bi->nrecs >= recno)
break; break;
total += bi->nrecs; total += bi->nrecs;
...@@ -235,7 +237,7 @@ __bam_rsearch(dbc, recnop, flags, stop, exactp) ...@@ -235,7 +237,7 @@ __bam_rsearch(dbc, recnop, flags, stop, exactp)
return (0); return (0);
case P_IRECNO: case P_IRECNO:
for (indx = 0, top = NUM_ENT(h);;) { for (indx = 0, top = NUM_ENT(h);;) {
ri = GET_RINTERNAL(h, indx); ri = GET_RINTERNAL(dbp, h, indx);
if (++indx == top || total + ri->nrecs >= recno) if (++indx == top || total + ri->nrecs >= recno)
break; break;
total += ri->nrecs; total += ri->nrecs;
...@@ -243,7 +245,7 @@ __bam_rsearch(dbc, recnop, flags, stop, exactp) ...@@ -243,7 +245,7 @@ __bam_rsearch(dbc, recnop, flags, stop, exactp)
pg = ri->pgno; pg = ri->pgno;
break; break;
default: default:
return (__db_pgfmt(dbp, h->pgno)); return (__db_pgfmt(dbp->dbenv, h->pgno));
} }
--indx; --indx;
...@@ -276,12 +278,12 @@ __bam_rsearch(dbc, recnop, flags, stop, exactp) ...@@ -276,12 +278,12 @@ __bam_rsearch(dbc, recnop, flags, stop, exactp)
(h->level - 1) == LEAFLEVEL) (h->level - 1) == LEAFLEVEL)
stack = 1; stack = 1;
(void)memp_fput(dbp->mpf, h, 0); (void)mpf->put(mpf, h, 0);
lock_mode = stack && lock_mode = stack &&
LF_ISSET(S_WRITE) ? DB_LOCK_WRITE : DB_LOCK_READ; LF_ISSET(S_WRITE) ? DB_LOCK_WRITE : DB_LOCK_READ;
if ((ret = __db_lget(dbc, if ((ret = __db_lget(dbc,
LCK_COUPLE, pg, lock_mode, 0, &lock)) != 0) { LCK_COUPLE_ALWAYS, pg, lock_mode, 0, &lock)) != 0) {
/* /*
* If we fail, discard the lock we held. This * If we fail, discard the lock we held. This
* is OK because this only happens when we are * is OK because this only happens when we are
...@@ -292,7 +294,7 @@ __bam_rsearch(dbc, recnop, flags, stop, exactp) ...@@ -292,7 +294,7 @@ __bam_rsearch(dbc, recnop, flags, stop, exactp)
} }
} }
if ((ret = memp_fget(dbp->mpf, &pg, 0, &h)) != 0) if ((ret = mpf->get(mpf, &pg, 0, &h)) != 0)
goto err; goto err;
} }
/* NOTREACHED */ /* NOTREACHED */
...@@ -315,12 +317,14 @@ __bam_adjust(dbc, adjust) ...@@ -315,12 +317,14 @@ __bam_adjust(dbc, adjust)
{ {
BTREE_CURSOR *cp; BTREE_CURSOR *cp;
DB *dbp; DB *dbp;
DB_MPOOLFILE *mpf;
EPG *epg; EPG *epg;
PAGE *h; PAGE *h;
db_pgno_t root_pgno; db_pgno_t root_pgno;
int ret; int ret;
dbp = dbc->dbp; dbp = dbc->dbp;
mpf = dbp->mpf;
cp = (BTREE_CURSOR *)dbc->internal; cp = (BTREE_CURSOR *)dbc->internal;
root_pgno = cp->root; root_pgno = cp->root;
...@@ -328,22 +332,27 @@ __bam_adjust(dbc, adjust) ...@@ -328,22 +332,27 @@ __bam_adjust(dbc, adjust)
for (epg = cp->sp; epg <= cp->csp; ++epg) { for (epg = cp->sp; epg <= cp->csp; ++epg) {
h = epg->page; h = epg->page;
if (TYPE(h) == P_IBTREE || TYPE(h) == P_IRECNO) { if (TYPE(h) == P_IBTREE || TYPE(h) == P_IRECNO) {
if (DB_LOGGING(dbc) && if (DBC_LOGGING(dbc)) {
(ret = __bam_cadjust_log(dbp->dbenv, if ((ret = __bam_cadjust_log(dbp, dbc->txn,
dbc->txn, &LSN(h), 0, dbp->log_fileid, &LSN(h), 0, PGNO(h), &LSN(h),
PGNO(h), &LSN(h), (u_int32_t)epg->indx, adjust, (u_int32_t)epg->indx, adjust,
PGNO(h) == root_pgno ? CAD_UPDATEROOT : 0)) != 0) PGNO(h) == root_pgno ?
return (ret); CAD_UPDATEROOT : 0)) != 0)
return (ret);
} else
LSN_NOT_LOGGED(LSN(h));
if (TYPE(h) == P_IBTREE) if (TYPE(h) == P_IBTREE)
GET_BINTERNAL(h, epg->indx)->nrecs += adjust; GET_BINTERNAL(dbp, h, epg->indx)->nrecs +=
adjust;
else else
GET_RINTERNAL(h, epg->indx)->nrecs += adjust; GET_RINTERNAL(dbp, h, epg->indx)->nrecs +=
adjust;
if (PGNO(h) == root_pgno) if (PGNO(h) == root_pgno)
RE_NREC_ADJ(h, adjust); RE_NREC_ADJ(h, adjust);
if ((ret = memp_fset(dbp->mpf, h, DB_MPOOL_DIRTY)) != 0) if ((ret = mpf->set(mpf, h, DB_MPOOL_DIRTY)) != 0)
return (ret); return (ret);
} }
} }
...@@ -363,21 +372,23 @@ __bam_nrecs(dbc, rep) ...@@ -363,21 +372,23 @@ __bam_nrecs(dbc, rep)
{ {
DB *dbp; DB *dbp;
DB_LOCK lock; DB_LOCK lock;
DB_MPOOLFILE *mpf;
PAGE *h; PAGE *h;
db_pgno_t pgno; db_pgno_t pgno;
int ret; int ret;
dbp = dbc->dbp; dbp = dbc->dbp;
mpf = dbp->mpf;
pgno = dbc->internal->root; pgno = dbc->internal->root;
if ((ret = __db_lget(dbc, 0, pgno, DB_LOCK_READ, 0, &lock)) != 0) if ((ret = __db_lget(dbc, 0, pgno, DB_LOCK_READ, 0, &lock)) != 0)
return (ret); return (ret);
if ((ret = memp_fget(dbp->mpf, &pgno, 0, &h)) != 0) if ((ret = mpf->get(mpf, &pgno, 0, &h)) != 0)
return (ret); return (ret);
*rep = RE_NREC(h); *rep = RE_NREC(h);
(void)memp_fput(dbp->mpf, h, 0); (void)mpf->put(mpf, h, 0);
(void)__TLPUT(dbc, lock); (void)__TLPUT(dbc, lock);
return (0); return (0);
...@@ -387,10 +398,11 @@ __bam_nrecs(dbc, rep) ...@@ -387,10 +398,11 @@ __bam_nrecs(dbc, rep)
* __bam_total -- * __bam_total --
* Return the number of records below a page. * Return the number of records below a page.
* *
* PUBLIC: db_recno_t __bam_total __P((PAGE *)); * PUBLIC: db_recno_t __bam_total __P((DB *, PAGE *));
*/ */
db_recno_t db_recno_t
__bam_total(h) __bam_total(dbp, h)
DB *dbp;
PAGE *h; PAGE *h;
{ {
db_recno_t nrecs; db_recno_t nrecs;
...@@ -403,25 +415,26 @@ __bam_total(h) ...@@ -403,25 +415,26 @@ __bam_total(h)
case P_LBTREE: case P_LBTREE:
/* Check for logically deleted records. */ /* Check for logically deleted records. */
for (indx = 0; indx < top; indx += P_INDX) for (indx = 0; indx < top; indx += P_INDX)
if (!B_DISSET(GET_BKEYDATA(h, indx + O_INDX)->type)) if (!B_DISSET(
GET_BKEYDATA(dbp, h, indx + O_INDX)->type))
++nrecs; ++nrecs;
break; break;
case P_LDUP: case P_LDUP:
/* Check for logically deleted records. */ /* Check for logically deleted records. */
for (indx = 0; indx < top; indx += O_INDX) for (indx = 0; indx < top; indx += O_INDX)
if (!B_DISSET(GET_BKEYDATA(h, indx)->type)) if (!B_DISSET(GET_BKEYDATA(dbp, h, indx)->type))
++nrecs; ++nrecs;
break; break;
case P_IBTREE: case P_IBTREE:
for (indx = 0; indx < top; indx += O_INDX) for (indx = 0; indx < top; indx += O_INDX)
nrecs += GET_BINTERNAL(h, indx)->nrecs; nrecs += GET_BINTERNAL(dbp, h, indx)->nrecs;
break; break;
case P_LRECNO: case P_LRECNO:
nrecs = NUM_ENT(h); nrecs = NUM_ENT(h);
break; break;
case P_IRECNO: case P_IRECNO:
for (indx = 0; indx < top; indx += O_INDX) for (indx = 0; indx < top; indx += O_INDX)
nrecs += GET_RINTERNAL(h, indx)->nrecs; nrecs += GET_RINTERNAL(dbp, h, indx)->nrecs;
break; break;
} }
......
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
...@@ -20,7 +20,7 @@ BEGIN ...@@ -20,7 +20,7 @@ BEGIN
VALUE "FileDescription", "Berkeley DB 3.0 DLL\0" VALUE "FileDescription", "Berkeley DB 3.0 DLL\0"
VALUE "FileVersion", "%MAJOR%.%MINOR%.%PATCH%\0" VALUE "FileVersion", "%MAJOR%.%MINOR%.%PATCH%\0"
VALUE "InternalName", "libdb.dll\0" VALUE "InternalName", "libdb.dll\0"
VALUE "LegalCopyright", "Copyright Sleepycat Software Inc. 1997, 1998, 1999, 2000\0" VALUE "LegalCopyright", "Copyright Sleepycat Software Inc. 1997-2002\0"
VALUE "OriginalFilename", "libdb.dll\0" VALUE "OriginalFilename", "libdb.dll\0"
VALUE "ProductName", "Sleepycat Software libdb\0" VALUE "ProductName", "Sleepycat Software libdb\0"
VALUE "ProductVersion", "%MAJOR%.%MINOR%.%PATCH%\0" VALUE "ProductVersion", "%MAJOR%.%MINOR%.%PATCH%\0"
......
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment