From 13953efe486154ca0dffbacc9f89c43155c9c3d2 Mon Sep 17 00:00:00 2001 From: Andy Maloney Date: Wed, 2 Nov 2022 16:31:56 -0400 Subject: [PATCH] Add extensionsLookupPrefix overload for more concise user code (#161) Users of the API probably don't care about the extension URI in general. Some don't even point to valid files online. --- include/E57Format.h | 1 + src/ImageFile.cpp | 20 ++++++++++++++++++++ src/ReaderImpl.cpp | 3 +-- src/WriterImpl.cpp | 6 ++---- 4 files changed, 24 insertions(+), 6 deletions(-) diff --git a/include/E57Format.h b/include/E57Format.h index 24928f1..6dee009 100644 --- a/include/E57Format.h +++ b/include/E57Format.h @@ -655,6 +655,7 @@ protected: // Manipulate registered extensions in the file void extensionsAdd( const ustring &prefix, const ustring &uri ); + bool extensionsLookupPrefix( const ustring &prefix ) const; bool extensionsLookupPrefix( const ustring &prefix, ustring &uri ) const; bool extensionsLookupUri( const ustring &uri, ustring &prefix ) const; size_t extensionsCount() const; diff --git a/src/ImageFile.cpp b/src/ImageFile.cpp index 8c2f9ef..6f44803 100644 --- a/src/ImageFile.cpp +++ b/src/ImageFile.cpp @@ -374,6 +374,26 @@ void ImageFile::extensionsAdd( const ustring &prefix, const ustring &uri ) impl_->extensionsAdd( prefix, uri ); } +/*! +@brief Look up an E57 extension prefix in the ImageFile. +@param [in] prefix The shorthand name of the extension to look up. +@details +If @a prefix = "" or @a prefix is declared in the ImageFile, then the function returns true. It is an error if @a prefix +contains an illegal character combination for E57 namespace prefixes. +@pre This ImageFile must be open (i.e. isOpen()). +@post No visible state is modified. +@return true if prefix is declared in the ImageFile. +@throw ::E57_ERROR_BAD_API_ARGUMENT +@throw ::E57_ERROR_IMAGEFILE_NOT_OPEN +@throw ::E57_ERROR_INTERNAL All objects in undocumented state +@see ImageFile::extensionsLookupUri +*/ +bool ImageFile::extensionsLookupPrefix( const ustring &prefix ) const +{ + ustring uri; + return impl_->extensionsLookupPrefix( prefix, uri ); +} + /*! @brief Get URI associated with an E57 extension prefix in the ImageFile. @param [in] prefix The shorthand name of the extension to look up. diff --git a/src/ReaderImpl.cpp b/src/ReaderImpl.cpp index df2f8eb..04127a9 100644 --- a/src/ReaderImpl.cpp +++ b/src/ReaderImpl.cpp @@ -1136,8 +1136,7 @@ namespace e57 // E57_EXT_surface_normals // See: http://www.libe57.org/E57_EXT_surface_normals.txt - ustring norExtUri; - if ( imf_.extensionsLookupPrefix( "nor", norExtUri ) ) + if ( imf_.extensionsLookupPrefix( "nor" ) ) { data3DHeader.pointFields.normalXField = proto.isDefined( "nor:normalX" ); data3DHeader.pointFields.normalYField = proto.isDefined( "nor:normalY" ); diff --git a/src/WriterImpl.cpp b/src/WriterImpl.cpp index 538ff39..2eb926a 100644 --- a/src/WriterImpl.cpp +++ b/src/WriterImpl.cpp @@ -941,8 +941,7 @@ namespace e57 data3DHeader.pointFields.normalZField ) { // make sure we declare the extension before using the fields with prefix - ustring norExtUri; - if ( !imf_.extensionsLookupPrefix( "nor", norExtUri ) ) + if ( !imf_.extensionsLookupPrefix( "nor" ) ) { imf_.extensionsAdd( "nor", "http://www.libe57.org/E57_EXT_surface_normals.txt" ); } @@ -1088,8 +1087,7 @@ namespace e57 } // E57_EXT_surface_normals - ustring norExtUri; - if ( imf_.extensionsLookupPrefix( "nor", norExtUri ) ) + if ( imf_.extensionsLookupPrefix( "nor" ) ) { if ( proto.isDefined( "nor:normalX" ) && ( buffers.normalX != nullptr ) ) {