Merge branch 'v0.20.x'
This commit is contained in:
commit
300a619991
4
NEWS
4
NEWS
@ -21,6 +21,10 @@ ver 0.21 (not yet released)
|
|||||||
ver 0.20.14 (not yet released)
|
ver 0.20.14 (not yet released)
|
||||||
* database
|
* database
|
||||||
- simple: fix file corruption in the presence of mount points
|
- simple: fix file corruption in the presence of mount points
|
||||||
|
* archive
|
||||||
|
- bz2: fix deadlock
|
||||||
|
- reduce lock contention, fixing lots of xrun problems
|
||||||
|
* fix Solaris build failure
|
||||||
|
|
||||||
ver 0.20.13 (2017/12/18)
|
ver 0.20.13 (2017/12/18)
|
||||||
* output
|
* output
|
||||||
|
@ -162,7 +162,7 @@ Bzip2InputStream::FillBuffer()
|
|||||||
if (bzstream.avail_in > 0)
|
if (bzstream.avail_in > 0)
|
||||||
return true;
|
return true;
|
||||||
|
|
||||||
size_t count = archive->istream->Read(buffer, sizeof(buffer));
|
size_t count = archive->istream->LockRead(buffer, sizeof(buffer));
|
||||||
if (count == 0)
|
if (count == 0)
|
||||||
return false;
|
return false;
|
||||||
|
|
||||||
@ -174,6 +174,8 @@ Bzip2InputStream::FillBuffer()
|
|||||||
size_t
|
size_t
|
||||||
Bzip2InputStream::Read(void *ptr, size_t length)
|
Bzip2InputStream::Read(void *ptr, size_t length)
|
||||||
{
|
{
|
||||||
|
const ScopeUnlock unlock(mutex);
|
||||||
|
|
||||||
int bz_result;
|
int bz_result;
|
||||||
size_t nbytes = 0;
|
size_t nbytes = 0;
|
||||||
|
|
||||||
@ -224,4 +226,3 @@ const ArchivePlugin bz2_archive_plugin = {
|
|||||||
bz2_open,
|
bz2_open,
|
||||||
bz2_extensions,
|
bz2_extensions,
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -182,6 +182,8 @@ Iso9660ArchiveFile::OpenStream(const char *pathname,
|
|||||||
size_t
|
size_t
|
||||||
Iso9660InputStream::Read(void *ptr, size_t read_size)
|
Iso9660InputStream::Read(void *ptr, size_t read_size)
|
||||||
{
|
{
|
||||||
|
const ScopeUnlock unlock(mutex);
|
||||||
|
|
||||||
int readed = 0;
|
int readed = 0;
|
||||||
int no_blocks, cur_block;
|
int no_blocks, cur_block;
|
||||||
size_t left_bytes = statbuf->size - offset;
|
size_t left_bytes = statbuf->size - offset;
|
||||||
|
@ -138,6 +138,8 @@ ZzipArchiveFile::OpenStream(const char *pathname,
|
|||||||
size_t
|
size_t
|
||||||
ZzipInputStream::Read(void *ptr, size_t read_size)
|
ZzipInputStream::Read(void *ptr, size_t read_size)
|
||||||
{
|
{
|
||||||
|
const ScopeUnlock unlock(mutex);
|
||||||
|
|
||||||
int ret = zzip_file_read(file, ptr, read_size);
|
int ret = zzip_file_read(file, ptr, read_size);
|
||||||
if (ret < 0)
|
if (ret < 0)
|
||||||
throw std::runtime_error("zzip_file_read() has failed");
|
throw std::runtime_error("zzip_file_read() has failed");
|
||||||
@ -155,6 +157,8 @@ ZzipInputStream::IsEOF() noexcept
|
|||||||
void
|
void
|
||||||
ZzipInputStream::Seek(offset_type new_offset)
|
ZzipInputStream::Seek(offset_type new_offset)
|
||||||
{
|
{
|
||||||
|
const ScopeUnlock unlock(mutex);
|
||||||
|
|
||||||
zzip_off_t ofs = zzip_seek(file, new_offset, SEEK_SET);
|
zzip_off_t ofs = zzip_seek(file, new_offset, SEEK_SET);
|
||||||
if (ofs < 0)
|
if (ofs < 0)
|
||||||
throw std::runtime_error("zzip_seek() has failed");
|
throw std::runtime_error("zzip_seek() has failed");
|
||||||
|
@ -103,11 +103,13 @@ UnsafeCopyStringP(wchar_t *dest, const wchar_t *src) noexcept
|
|||||||
{
|
{
|
||||||
#if defined(_WIN32) || defined(__BIONIC__) || defined(__OpenBSD__) || \
|
#if defined(_WIN32) || defined(__BIONIC__) || defined(__OpenBSD__) || \
|
||||||
defined(__NetBSD__)
|
defined(__NetBSD__)
|
||||||
/* emulate wcpcpy() */
|
/* emulate wcpcpy() */
|
||||||
UnsafeCopyString(dest, src);
|
UnsafeCopyString(dest, src);
|
||||||
return dest + StringLength(dest);
|
return dest + StringLength(dest);
|
||||||
|
#elif defined(__sun) && defined (__SVR4)
|
||||||
|
return std::wcpcpy(dest, src);
|
||||||
#else
|
#else
|
||||||
return wcpcpy(dest, src);
|
return wcpcpy(dest, src);
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -159,7 +161,11 @@ gcc_malloc gcc_returns_nonnull gcc_nonnull_all
|
|||||||
static inline wchar_t *
|
static inline wchar_t *
|
||||||
DuplicateString(const wchar_t *p)
|
DuplicateString(const wchar_t *p)
|
||||||
{
|
{
|
||||||
|
#if defined(__sun) && defined (__SVR4)
|
||||||
|
return std::wcsdup(p);
|
||||||
|
#else
|
||||||
return wcsdup(p);
|
return wcsdup(p);
|
||||||
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
Loading…
Reference in New Issue
Block a user