1 diff -ruN db-4.7.25.NC/sequence/sequence.c db-4.7.25.NC.new/sequence/sequence.c
2 --- db-4.7.25.NC/sequence/sequence.c 2008-05-05 22:25:09.000000000 +0200
3 +++ db-4.7.25.NC.new/sequence/sequence.c 2009-11-08 12:50:27.000000000 +0100
5 if ((ret = __db_get_flags(dbp, &tflags)) != 0)
8 - if (DB_IS_READONLY(dbp)) {
10 + * We can let replication clients open sequences, but must
11 + * check later that they do not update them.
13 + if (F_ISSET(dbp, DB_AM_RDONLY)) {
14 ret = __db_rdonly(dbp->env, "DB_SEQUENCE->open");
18 if ((ret != DB_NOTFOUND && ret != DB_KEYEMPTY) ||
21 + if (IS_REP_CLIENT(env) &&
22 + !F_ISSET(dbp, DB_AM_NOT_DURABLE)) {
23 + ret = __db_rdonly(env, "DB_SEQUENCE->open");
28 rp = &seq->seq_record;
31 rp = seq->seq_data.data;
32 if (rp->seq_version == DB_SEQUENCE_OLDVER) {
33 -oldver: rp->seq_version = DB_SEQUENCE_VERSION;
34 +oldver: if (IS_REP_CLIENT(env) &&
35 + !F_ISSET(dbp, DB_AM_NOT_DURABLE)) {
36 + ret = __db_rdonly(env, "DB_SEQUENCE->open");
39 + rp->seq_version = DB_SEQUENCE_VERSION;
40 if (!F_ISSET(env, ENV_LITTLEENDIAN)) {
41 if (IS_DB_AUTO_COMMIT(dbp, txn)) {
45 MUTEX_LOCK(env, seq->mtx_seq);
47 + if (handle_check && IS_REP_CLIENT(env) &&
48 + !F_ISSET(dbp, DB_AM_NOT_DURABLE)) {
49 + ret = __db_rdonly(env, "DB_SEQUENCE->get");
54 if (rp->seq_min + delta > rp->seq_max) {
55 __db_errx(env, "Sequence overflow");