mirror of
https://github.com/isar/libmdbx.git
synced 2025-01-08 07:54:13 +08:00
mdbx: Merge branch 'devel' into 'pt' branch.
This commit is contained in:
commit
a866d8b6c2
5
lmdb.h
5
lmdb.h
@ -1150,8 +1150,9 @@ int mdb_txn_renew(MDB_txn *txn);
|
|||||||
* This flag may only be used in combination with #MDB_DUPSORT. This option
|
* This flag may only be used in combination with #MDB_DUPSORT. This option
|
||||||
* tells the library that the data items for this database are all the same
|
* tells the library that the data items for this database are all the same
|
||||||
* size, which allows further optimizations in storage and retrieval. When
|
* size, which allows further optimizations in storage and retrieval. When
|
||||||
* all data items are the same size, the #MDB_GET_MULTIPLE and #MDB_NEXT_MULTIPLE
|
* all data items are the same size, the #MDB_GET_MULTIPLE, #MDB_NEXT_MULTIPLE
|
||||||
* cursor operations may be used to retrieve multiple items at once.
|
* and #MDB_PREV_MULTIPLE cursor operations may be used to retrieve multiple
|
||||||
|
* items at once.
|
||||||
* <li>#MDB_INTEGERDUP
|
* <li>#MDB_INTEGERDUP
|
||||||
* This option specifies that duplicate data items are binary integers,
|
* This option specifies that duplicate data items are binary integers,
|
||||||
* similar to #MDB_INTEGERKEY keys.
|
* similar to #MDB_INTEGERKEY keys.
|
||||||
|
17
mdb.c
17
mdb.c
@ -9114,6 +9114,14 @@ mdb_env_copythr(void *arg)
|
|||||||
int toggle = 0, wsize, rc = 0;
|
int toggle = 0, wsize, rc = 0;
|
||||||
int len;
|
int len;
|
||||||
|
|
||||||
|
#ifdef SIGPIPE
|
||||||
|
sigset_t set;
|
||||||
|
sigemptyset(&set);
|
||||||
|
sigaddset(&set, SIGPIPE);
|
||||||
|
if ((rc = pthread_sigmask(SIG_BLOCK, &set, NULL)) != 0)
|
||||||
|
my->mc_error = rc;
|
||||||
|
#endif
|
||||||
|
|
||||||
pthread_mutex_lock(&my->mc_mutex);
|
pthread_mutex_lock(&my->mc_mutex);
|
||||||
for(;;) {
|
for(;;) {
|
||||||
while (!my->mc_new)
|
while (!my->mc_new)
|
||||||
@ -9128,6 +9136,15 @@ again:
|
|||||||
len = write(my->mc_fd, ptr, wsize);
|
len = write(my->mc_fd, ptr, wsize);
|
||||||
if (len < 0) {
|
if (len < 0) {
|
||||||
rc = errno;
|
rc = errno;
|
||||||
|
#ifdef SIGPIPE
|
||||||
|
if (rc == EPIPE) {
|
||||||
|
/* Collect the pending SIGPIPE, otherwise at least OS X
|
||||||
|
* gives it to the process on thread-exit (ITS#8504).
|
||||||
|
*/
|
||||||
|
int tmp;
|
||||||
|
sigwait(&set, &tmp);
|
||||||
|
}
|
||||||
|
#endif
|
||||||
break;
|
break;
|
||||||
} else if (len > 0) {
|
} else if (len > 0) {
|
||||||
rc = MDB_SUCCESS;
|
rc = MDB_SUCCESS;
|
||||||
|
Loading…
x
Reference in New Issue
Block a user