Merge pull request #1178 from Exiv2/0.27_fileio_performance

Reduce system calls in FileIo::eof() (master -> 0.27)
v0.27.3
Robin Mills 5 years ago committed by GitHub
commit adef1fbd33
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23

@ -3,11 +3,12 @@
#include <exiv2/exiv2.hpp> #include <exiv2/exiv2.hpp>
#include <iostream>
#include <cassert> #include <cassert>
#include <iostream>
int main(int argc, char* const argv[]) int main(int argc, char* const argv[])
try { {
try {
Exiv2::XmpParser::initialize(); Exiv2::XmpParser::initialize();
::atexit(Exiv2::XmpParser::terminate); ::atexit(Exiv2::XmpParser::terminate);
@ -23,10 +24,12 @@ try {
if (io.open() != 0) { if (io.open() != 0) {
throw Exiv2::Error(Exiv2::kerDataSourceOpenFailed, io.path(), Exiv2::strError()); throw Exiv2::Error(Exiv2::kerDataSourceOpenFailed, io.path(), Exiv2::strError());
} }
Exiv2::DataBuf buf((long)io.size()); Exiv2::DataBuf buf(static_cast<long>(io.size()));
std::cout << "Reading " << buf.size_ << " bytes from " << data << "\n"; std::cout << "Reading " << buf.size_ << " bytes from " << data << "\n";
io.read(buf.pData_, buf.size_); long readBytes = io.read(buf.pData_, buf.size_);
if (io.error() || !io.eof()) throw Exiv2::Error(Exiv2::kerFailedToReadImageData); if (readBytes != buf.size_ || io.error() || io.eof()) {
throw Exiv2::Error(Exiv2::kerFailedToReadImageData);
}
// Read metadata from file // Read metadata from file
Exiv2::Image::AutoPtr image = Exiv2::ImageFactory::open(file); Exiv2::Image::AutoPtr image = Exiv2::ImageFactory::open(file);
@ -65,8 +68,8 @@ try {
image->writeMetadata(); image->writeMetadata();
return 0; return 0;
} } catch (Exiv2::AnyError& e) {
catch (Exiv2::AnyError& e) {
std::cout << "Caught Exiv2 exception '" << e << "'\n"; std::cout << "Caught Exiv2 exception '" << e << "'\n";
return -1; return -1;
}
} }

@ -1022,8 +1022,7 @@ namespace Exiv2 {
bool FileIo::eof() const bool FileIo::eof() const
{ {
assert(p_->fp_ != 0); return std::feof(p_->fp_) != 0;
return feof(p_->fp_) != 0 || tell() >= (long) size() ;
} }
std::string FileIo::path() const std::string FileIo::path() const

@ -13,19 +13,22 @@ class PngReadRawProfile(metaclass=system_tests.CaseMeta):
filenames = [ filenames = [
system_tests.path("$data_path/issue_428_poc1.png"), system_tests.path("$data_path/issue_428_poc1.png"),
system_tests.path("$data_path/issue_428_poc2.png"),
system_tests.path("$data_path/issue_428_poc3.png"), system_tests.path("$data_path/issue_428_poc3.png"),
system_tests.path("$data_path/issue_428_poc4.png"), system_tests.path("$data_path/issue_428_poc4.png"),
system_tests.path("$data_path/issue_428_poc5.png"), system_tests.path("$data_path/issue_428_poc5.png"),
system_tests.path("$data_path/issue_428_poc8.png"), system_tests.path("$data_path/issue_428_poc8.png"),
system_tests.path("$data_path/issue_428_poc2.png"),
system_tests.path("$data_path/issue_428_poc6.png"), system_tests.path("$data_path/issue_428_poc6.png"),
system_tests.path("$data_path/issue_428_poc7.png"), system_tests.path("$data_path/issue_428_poc7.png"),
] ]
commands = ["$exiv2 " + fname for fname in filenames] commands = ["$exiv2 " + fname for fname in filenames]
stdout = [""] * len(filenames) stdout = [""] * len(filenames)
stderr = [ stderr_exception(fname) for fname in filenames[0:6] ] stderr = [ stderr_exception(fname) for fname in filenames[0:5] ]
stderr.append("""$exiv2_exception_message """ + filenames[5] + """:
$kerInputDataReadFailed
""")
stderr.append("""Error: XMP Toolkit error 201: XML parsing failure stderr.append("""Error: XMP Toolkit error 201: XML parsing failure
Warning: Failed to decode XMP metadata. Warning: Failed to decode XMP metadata.
""" + stderr_exception(filenames[6])) """ + stderr_exception(filenames[6]))

@ -22,6 +22,7 @@ taglist: ${ENV:exiv2_path}/taglist${ENV:binary_extension}
[variables] [variables]
kerOffsetOutOfRange: Offset out of range kerOffsetOutOfRange: Offset out of range
kerFailedToReadImageData: Failed to read image data kerFailedToReadImageData: Failed to read image data
kerInputDataReadFailed: Failed to read input data
kerCorruptedMetadata: corrupted image metadata kerCorruptedMetadata: corrupted image metadata
kerInvalidMalloc: invalid memory allocation request kerInvalidMalloc: invalid memory allocation request
kerInvalidTypeValue: invalid type in tiff structure kerInvalidTypeValue: invalid type in tiff structure

@ -19,23 +19,28 @@ endforeach()
add_executable(unit_tests mainTestRunner.cpp add_executable(unit_tests mainTestRunner.cpp
gtestwrapper.h gtestwrapper.h
test_basicio.cpp
test_types.cpp
test_tiffheader.cpp
test_futils.cpp
test_enforce.cpp
test_safe_op.cpp
test_XmpKey.cpp
test_DateValue.cpp test_DateValue.cpp
test_TimeValue.cpp test_TimeValue.cpp
test_XmpKey.cpp
test_basicio.cpp
test_cr2header_int.cpp test_cr2header_int.cpp
test_enforce.cpp
test_FileIo.cpp
test_futils.cpp
test_helper_functions.cpp test_helper_functions.cpp
test_slice.cpp
test_image_int.cpp test_image_int.cpp
test_safe_op.cpp
test_slice.cpp
test_tiffheader.cpp
test_types.cpp
${unit_tests_exiv2lib_SOURCES} ${unit_tests_exiv2lib_SOURCES}
) )
target_compile_definitions(unit_tests PRIVATE exiv2lib_STATIC) target_compile_definitions(unit_tests
PRIVATE
exiv2lib_STATIC
TESTDATA_PATH="${PROJECT_SOURCE_DIR}/test/data"
)
if (exiv2lib_COMPILE_DEFINITIONS) if (exiv2lib_COMPILE_DEFINITIONS)
target_compile_definitions(unit_tests PRIVATE ${exiv2lib_COMPILE_DEFINITIONS}) target_compile_definitions(unit_tests PRIVATE ${exiv2lib_COMPILE_DEFINITIONS})

@ -0,0 +1,74 @@
#include "basicio.hpp"
#include <gtest/gtest.h>
using namespace Exiv2;
namespace
{
const std::string testData(TESTDATA_PATH);
const std::string imagePath(testData + "/DSC_3079.jpg");
} // namespace
TEST(AFileIO, canBeInstantiatedWithFilePath)
{
ASSERT_NO_THROW(FileIo file(imagePath));
}
TEST(AFileIO, canBeOpenInReadBinaryMode)
{
FileIo file(imagePath);
ASSERT_EQ(0, file.open());
}
TEST(AFileIO, isOpenDoItsJob)
{
FileIo file(imagePath);
ASSERT_FALSE(file.isopen());
file.open();
ASSERT_TRUE(file.isopen());
}
TEST(AFileIO, returnsFileSizeIfItsOpened)
{
FileIo file(imagePath);
file.open();
ASSERT_EQ(118685ul, file.size());
}
TEST(AFileIO, returnsFileSizeEvenWhenFileItIsNotOpened)
{
FileIo file(imagePath);
ASSERT_EQ(118685ul, file.size());
}
TEST(AFileIO, isOpenedAtPosition0)
{
FileIo file(imagePath);
file.open();
ASSERT_EQ(0, file.tell());
}
TEST(AFileIO, canSeekToExistingPositions)
{
FileIo file(imagePath);
file.open();
ASSERT_EQ(0, file.seek(100, BasicIo::beg));
ASSERT_EQ(0, file.seek(-50, BasicIo::cur));
ASSERT_EQ(0, file.seek(-50, BasicIo::end));
ASSERT_FALSE(file.error());
ASSERT_FALSE(file.eof());
}
TEST(AFileIO, canSeekBeyondEOF)
{
FileIo file(imagePath);
file.open();
// POSIX allows seeking beyond the existing end of file.
ASSERT_EQ(0, file.seek(200000, BasicIo::beg));
ASSERT_FALSE(file.error());
ASSERT_FALSE(file.eof());
}
Loading…
Cancel
Save