From b6ad2128f3f2cd8cf21adce2fc866e953b0d85f9 Mon Sep 17 00:00:00 2001 From: "J. Daniel Smith" Date: Fri, 8 Sep 2023 12:30:21 -0400 Subject: [PATCH] Be more explicit about the CPHD version (#695) MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit * cphd::Version enum * Squashed commit of the following: commit 67d0bc78b1a93d02fc496ec755fc794060ab5bb5 Merge: 42f479813 a2cb168ce Author: Dan Smith Date: Fri Jun 16 10:37:57 2023 -0400 Merge branch 'develop/complex_short' of github.com:ngageoint/six-library into develop/complex_short commit 42f479813d7b2d431753028cab5ff5c4874bb62c Author: Dan Smith Date: Fri Jun 16 10:37:43 2023 -0400 Parameter::operator==() must a member function for existing SWIG bindings commit a2cb168cebbf0b89348d106be8a878fb6746f155 Author: Dan Smith Date: Fri Jun 16 10:32:22 2023 -0400 renames from CODA-OSS commit 68d184a89f899a709c6c7e54f858e4a8a4ed2955 Author: Dan Smith Date: Fri Jun 16 10:15:28 2023 -0400 figure out ComplexInteger in SIX rather than CODA-OSS commit 802087c892ecc653c0cd0086ec888d622c9192f8 Author: Dan Smith Date: Fri Jun 16 10:01:05 2023 -0400 separate .H file for complex commit 4d24ae394a290e21f074614ee95f46a182c43e33 Author: Dan Smith Date: Fri Jun 16 09:54:05 2023 -0400 remove unneeded #include of types/Complex.h commit e021d71c2d25641afbfe7d6741f60b2c745bd12d Author: Dan Smith Date: Fri Jun 16 09:49:48 2023 -0400 zinteger -> ComplexInteger commit 91599f83e4a8d1e3e8fe77d54bca4cb6f85ea692 Author: Dan Smith Date: Fri Jun 16 09:38:53 2023 -0400 complex.h -> Complex.h from CODA-OSS commit b3653cc75b07fb0415e2a18303058e57c31718b8 Merge: 786223e8c 6e34e8717 Author: Dan Smith Date: Thu Jun 15 16:11:31 2023 -0400 Merge branch 'main' into develop/complex_short commit 786223e8c0ebc05ca46e7c55eac8a26678ff2bff Author: Dan Smith Date: Thu Jun 15 16:04:31 2023 -0400 use CODA_OSS_types_unique_zinteger commit f143d3a53c4cdce580958fae0ef5588bb12cbda5 Author: Dan Smith Date: Thu Jun 15 15:54:40 2023 -0400 Squashed commit of the following: commit 011ba83af6202c4a5358c366ac0e88edcbfd6986 Merge: 7390b8b19 4a21b2db5 Author: Dan Smith Date: Thu Jun 15 15:37:33 2023 -0400 Merge branch 'main' into develop/sync_externals commit 7390b8b19f4f9d21d0ffc34ae9906cea2227936d Merge: 7f79e6d6f b902f6c17 Author: Dan Smith Date: Thu Jun 15 14:21:10 2023 -0400 Merge commit 'b902f6c1743778d8fceeee5b3209ebca2370312a' into develop/sync_externals commit b902f6c1743778d8fceeee5b3209ebca2370312a Author: Dan Smith Date: Thu Jun 15 14:21:10 2023 -0400 Squashed 'externals/coda-oss/' changes from f4d42005f..704d6867f 704d6867f beef-up our complex type (#687) 47c1c1cd6 check is_absolute() for URLs (#686) c042373e1 be sure our Path::isAbolute() matches std::filesystem::path::absolute() (#684) ad10286bc volatile is about "special" memory, not threading (#685) git-subtree-dir: externals/coda-oss git-subtree-split: 704d6867f959f60e3e62c44681a3fb1f7abc99bf commit 7f79e6d6fb8972e5074e582aa4c3214e9a524459 Author: Dan Smith Date: Thu Jun 15 14:21:06 2023 -0400 latest from CODA-OSS commit 24678b33f4aab533af0d807d6706f8587bd1c103 Merge: 9eb95e3aa 35b59b9a0 Author: Dan Smith Date: Thu Jun 15 14:20:30 2023 -0400 Merge branch 'main' into develop/sync_externals commit 9eb95e3aad1562b0d7915cf48db1b61a337a3878 Author: Dan Smith Date: Tue Jun 13 17:51:55 2023 -0400 latest from CODA-OSS and NITRO commit 1bd99042ef18b76df9da27d946b5616d9dd254b1 Merge: ec161c5b3 c59d69c06 Author: Dan Smith Date: Tue Jun 13 17:51:40 2023 -0400 sync_externals commit c59d69c06eda40c7295ab607fdc8a5dad7d2c1b1 Author: Dan Smith Date: Tue Jun 13 17:51:34 2023 -0400 Squashed 'externals/nitro/' changes from c8ecbe9ae..3f01809fa 3f01809fa latest from coda-oss (#557) 471fb3fc1 Update test_j2k_loading++.cpp b12caf2fc latest from CODA-OSS (#556) 0cd432624 use sys::make_span (#555) 05dae18a3 patch to build other projects 8f974e995 NITRO-2.11.3 (#554) 870aa6afd update to coda-oss 2023-06-05 (#553) 2fd7a0bfa latest from coda-oss (#552) 0eecce004 invoke() utility to reduce code duplication (#550) 59fb02fe9 latest from coda-oss (#551) 9fbf2b7b8 Fill out adapter free block which is used for nitf decompression (#549) 089ba0b5b latest from coda-oss 3b52f0025 latest from coda-oss (#547) 90c6263e2 latest from coda-oss (#544) 90d513ac5 latest from coda-oss (#543) git-subtree-dir: externals/nitro git-subtree-split: 3f01809fae7d471aa0f1594fc5eec1e3111cd710 commit 272cae451cbe3ad6820d1221aafe375d77b1ba04 Author: Dan Smith Date: Tue Jun 13 17:51:29 2023 -0400 Squashed 'externals/coda-oss/' changes from e87c32b4d..f4d42005f f4d42005f fix build error in NITRO ff11a5557 keep using std::complex for now (#682) c88b9c053 types::complex (#681) d1244a080 don't need our own make_unique in C++14 (#680) aeec0131c assert()s for mem::CopyablePtr (#679) 72b0ebd60 add types::complex_short (#678) 932130a58 patch to build other projects c00c1f203 coda-oss release 2023-06-06 (#677) ef54bbcd5 remove more compiler warnings (#676) dadfc5ce6 distinguish between byte-swapping a buffer and single value (#674) 90187f6cd more xml.lite tweaks for SIDD-3.0/ISM (#675) eb9960772 stronger type-checking for byteSwap() (#673) ff4f820ed xml.lite tweaks to support SIDD 3.0 ISM (#672) b1de8c0e5 std::byte should be a unique type (#671) c05bf9a02 allow enums to be byte-swapped too 1f9fd88d6 remove spurious 47684c45b byteSwap now uses byte buffers (#670) cbc659db2 add swapBytes() utility from SIX (#669) 891481b64 simplify byte-swapping (#668) 540ae763e more byteSwap() tweaks 0774c03c4 threaded byteSwap() (#667) d156370d3 swapping a single-byte value makes no sense c120e3255 be sure parameter is used to avoid compiler warning e85ec9331 --output-on-failure for CTest (#666) e80376197 turn off "there is no warning number" warning c5f0a5d15 A C-string may not be NULL-terminated (#665) 0c5eb29ae use platform-specific routines for byteSwap() (#664) 0b7d581fa remove transform_async() (#663) f6489b6be Merge branch 'main' into feature/xml.lite_tweaks 836c426a2 use function-pointers so that isConsoleOutput is only checked once 56e3c45b1 move depthPrint() functionality into non-member function in preparation for future changes ddcd26d97 Merge branch 'main' into feature/xml.lite_tweaks 69cc0e506 use the more rigorous create_and_check_datatype() 9efb87558 Merge branch 'main' into feature/hdf5 4d2f2f417 more HighFive unittests (#662) 14191a844 HighFive::create_datatype() goes from C++ to HighFive 98583473f utility routines to read string attributes 1fa75ce81 use the C API to read a string attribute 71e7b69f5 still can't figure out how to read a string attribute :-( e96f37a69 test reading the file attributes a25244519 getAttribute() unittest 8f12a3000 getDataType() unittest 857ff0af3 HighFive utility routines (#661) 1d687db57 writeDataSet() utility overload 106aa6894 sigh ... H5Easy::dump() fill fails on Windows/WAF :-( 2641b60b2 Merge branch 'main' into feature/hdf5 35c19e7e8 change actions to @v3 (#660) 212bbd3a3 works on local machine, but not build server ... ? 7125118b0 dump of 1D vector doesn't work :-( c704db435 sigh ... WAF build still failing :-( 01aae4616 does dump() of a 1D vector work? 76a53c813 comment-out H5 writing :-( 0f0e19aff test_highfive_dump() cb8f73795 trying to get highfive_dump() unittest working w/Windows-WAF 6584a264a does test_highfive_create() work? cde6147ce tweak HighFive wrappers (#659) 316566854 Revert "trying HighFive "write" unittests again" a9ec24ca4 trying HighFive "write" unittests again 585ad49a5 tweak names of utility routines 4c91a4d97 make it easier to read a std::vector and std::vecotr 0217ffa26 readDataSet() now works for 1D data 95e8973f2 trying to get hdf5::lite::load() working 4d294611d "const" correctness 5e6305c3f fix load_complex() 4a134dc5f start work on utility routines to read complex data from HDF5 9d76a7f41 Merge branch 'main' into feature/hdf5 8f9667a24 whitepsace ebd3fc99e Merge branch 'main' into feature/hdf5 40091b069 comment-out writing tests for now ... need to figure our WAF bulid failure 935aa3459 be sure the dataset has real data 114b9bf33 update release notes bd9c0b26c tweak HighFive utility routines acda1ef57 turn off diagnostics around expected failures 22a748840 readDataSet() utility routine for HighFive bd88a8c25 HighFive writeDataSet() utility to work with our SpanRC 6142f5b33 use HighFive routines to write a HDF5 file 5bbf1abaf Use HiveFive routines to get info about the file 84fbc8378 duplicate unittests with H5Easy f1f054c03 Merge branch 'main' into feature/hdf5 9b63ca470 fix directory names f6f826689 fix directory names 7aeb82c33 Merge branch 'main' into feature/hdf5 d028baaeb hook up HighFive header-only library (#653) 3083b0a31 Revert "HighFive 2.6.2" 246985a7f Revert ""build" HighFive HDF5 library" a8b75a586 Revert "turn off HighFive Boost support" ec68d5f83 Revert "Add HighFive unittests" f1f85b9e7 Revert "get test_high_five_base more-or-less compiling" 5ea634ee1 Revert "more work on getting HighFive unittests to build" ecc45433c more work on getting HighFive unittests to build bb194788a get test_high_five_base more-or-less compiling d42bde000 Add HighFive unittests ddc86bb32 turn off HighFive Boost support b255122d4 "build" HighFive HDF5 library 396cc3ef2 HighFive 2.6.2 5e5f9d9c0 Merge branch 'main' into feature/hdf5 ee938b4a5 changes from SIX bb764df90 Merge branch 'main' into feature/xml.lite_tweaks de2a24380 make derived classes 'final' if possible 14e19bcd2 Change xml lite function to virtual (#645) 8f42ac8e9 Merge branch 'main' into feature/xml.lite_tweaks 18ad90645 hdf5Write unittest 3462e1179 createFile() and writeFile() overloads ecee81d53 fix typos 197eecfa6 sketch-out hdf5::lite::writeFile() bd2311795 use SpanRC for writeFile(), not yet implemented ea9af7510 simple SpanRC to hold a 2D-size and pointer 027c19ee8 createFile() unittest 1f9d07ecb hook up createFile() 8c7e4473f start hooking up HDF5 writing 146e0bea3 Merge branch 'main' into feature/hdf5 88ca9fcb7 Merge branch 'main' into feature/hdf5 42b604b46 Squashed commit of the following: 10ee602c2 Merge branch 'main' into feature/hdf5 67aa42b69 restore changes from "main" 8bbfcbfbf unittests can be simplified to match fewer "view" classes 126bb802e Merge branch 'main' into feature/hdf5 3f8ba7a42 again, don't need a class just to convert from std::vector<> to std::span<> 24c2b489c Squashed commit of the following: 2703c119d Squashed commit of the following: 9d5228a2b don't need an entire class just to convert a std::vector<> into std::span<> 51bc931dc Merge branch 'main' into feature/hdf5 a84f25816 Squashed commit of the following: c4d2ed696 add missing #include guards, fix type in existing #include guard d541525a0 use a single ComplexViewConstIterator for all views 86e6a459f CODA_OSS_disable_warning causes GCC errors :-( 5d4b9c2cb only need an custom iterator for ComplexSpansView d9f0fb128 hook up iterators b9329e4db initial pass at a ComplexViewConstIterator 635238873 remove compiler warning about unused "constexpr" variables b39f6096f use the casing from H5 to make copy/pasting code slightly easier 0887b13eb Merge branch 'main' into feature/hdf5 bd07df1ca Consistent casing for Dataset, Datatype, Dataspace 7acd30ee2 tweak hdf5.lite dependencies 38ab914df Jupyter notebook for creating H5 files 95a040e0b _small.h5 is now (correctly) FLOAT32 107e7c487 make a simple values() member function to avoid template magic e1feca919 use TEST_SPECIFIC_EXCEPTION macro instead of try/catch 738333688 readDatasetT() now throws for the wrong buffer type 6b2cc2529 Merge branch 'feature/hdf5' of github.com:mdaus/coda-oss into feature/hdf5 310f8fd3d can't get template magic right for copy_axis() 86b306d59 stepping through copy ctors in the debugger is annoying f243e92d6 trying to make wrong type of buffer fail 2b10d9652 read in new sample file a28e59d8c help the compiler with type deduction 49bf5e9bc nested_complex_float_data_small.h5 e029325fc utility routines to "deconstruct" and array of std::complex dede3bd39 Merge branch 'main' into feature/hdf5 904b1ef5e tweak class names, make_() and copy() utility routines 8237b9efb make it harder to pass the wrong types to ComplexViews 4d9aeda2c ComplexArrayView and ComplexParallelView utility classes f5e367dfa test std::span> a4a2844f2 read in the nested "i" and "r" data 115615265 sample file has subgroups 8e1b7869a Merge branch 'feature/hdf5' of github.com:mdaus/coda-oss into feature/hdf5 9f4232a1d update sample H5 file 8c55db73a walk through HDF5 sub-groups 7775ed9c4 Update 123_barfoo_catdog_cx.h5 677975d7c Matlab code to create sample H5 file a0e7dfe07 Update test_hdf5info.cpp 0b67e1602 pass __FILE__ and __LINE__ from calling site for a more accurate exception message 86a677321 skeleton for more sample data 85f79b099 Merge branch 'main' into feature/hdf5 18088e942 Merge branch 'main' into feature/hdf5 3a1d17692 Merge branch 'main' into feature/hdf5 1755c69d7 Merge branch 'main' into feature/hdf5 9ad015432 No more "11" suffix on exception names c20d96251 Squashed commit of the following: c88cee999 other values to be filled-in bca4a4ecd incorporation NamedObject from HDF5 docs 61fa68f72 groupInfo() 460e7d766 datasetInfo() 14eb9b764 start filling in DatasetInfo afe5f1c3a start to fill in DatasetInfo 77a968c72 start filling in GroupInfo d81bcdfd9 openGroup() to open groups (loc) a0cd29469 comment-out "dataset" unittest for now 86e006024 begin filling in FileInfo 366dda6ab a return_type_of utility is needed to deduce the return type e21928263 explicitly pass return type to template 4937ccd11 template to reduce boilerplate when calling try_catch_H5Exceptions b3b5ebde7 use new exception utility routines ea1c03ef0 put exception handling/conversion in a utility routine 819a99d39 utility routine for exception handling 6f34eea97 put utilities in a separate file for easier reuse fcbde4f24 break utility routines into smaller pieces for easier reuse 52358ea8a WIN32 no longer automatically defined? 5a4286472 Revert "build HDF5 with C89" 680e599e9 build HDF5 with C89 a87a07121 Merge branch 'main' into feature/hdf5 8447c1a90 Revert "sym-links instead of copying files" db3b5e12b Merge branch 'main' into feature/xml.lite_tweaks fb60b5696 Merge branch 'main' into feature/hdf5 5110a5cc8 Comments about _u and _q 1a937d32c Merge branch 'main' into feature/xml.lite_tweaks fa06f04d7 get ready for hdf5.lite enhancdements b040c7c43 sym-links instead of copying files aa431bb47 use _u for xml::lite::Uri 3d0c6d58c fix case-sensitive #include filename 93dcd0e52 operator() for getElementByName() 75a93af85 more operator[] overloads to make attribute management easier 4ab8216f8 user-defined string literals to remove some noise around xml::lite::QName f82f0b0fc Merge branch 'main' into feature/xml.lite_tweaks ae30e3644 Merge branch 'feature/xml.lite_tweaks' of github.com:mdaus/coda-oss into feature/xml.lite_tweaks ffdd9beb0 simplify attribute creation 9bf5414f5 simplify attribute creation 82d7a4e95 SWIG gets confused about namespaces 7a61d0741 fix bug on Element ctor uncovered by unittest fdd7e58c1 QName is also in the xerces namespace which confuses SWIG bindings a325b7053 operator+=() overload for addChild daf30e6c0 Merge branch 'feature/xml.lite_tweaks' of github.com:mdaus/coda-oss into feature/xml.lite_tweaks b887d2b47 provide overloads for Element& rather than creating new "reference" types 1fa6bba38 rename test_xmleasy.cpp 7c8c9e0f1 += overload 850da6f63 overload for std::string 4547fc5a7 use UIT-8 strings for characterData 4723462a3 convenient addChild() overloads e48720753 copy over ElementReference from xml.easy a4ca30a0d Merge branch 'main' into feature/xml.lite_tweaks 6ae9f0b71 Revert "check-in of new xml.easy (to move code between computers)" f7466a6d7 Revert "simple routines for single element" a5490230d Revert "make some operators simplier ways of calling functions" c9a25630a Revert "get document creation working" 8af8710b0 Revert "free functions instead of member functions" 16c3847cb Revert "ElementReference distinct from Element" 7d68e156f Revert "ElementMutableReference" 00eb2a282 Merge branch 'main' into feature/xml.lite_tweaks a42969c1f ElementMutableReference a20ae9355 ElementReference distinct from Element 14eeeea0b free functions instead of member functions 4aae014b3 get document creation working 883569269 make some operators simplier ways of calling functions 053bd1212 simple routines for single element 8bf701a2e check-in of new xml.easy (to move code between computers) 41f959051 unittests for creating XML documents from scratch 9752d50ae Merge branch 'main' into feature/xml.lite_tweaks 1531d5709 by default, don't validate strings passed to Uri() 46d13d4bf Merge branch 'master' into feature/xml.lite_tweaks 39b547d32 remove more vestiges of Expat and LibXML ec8274d52 remove LibXML and Expat as they're no longer used/supported. 20eeefeef Merge branch 'master' into feature/xml.lite_tweaks 95074b9b1 update for newer Intel compiler 7024f71e1 Merge branch 'master' into feature/xml.lite_tweaks 57b1cbc83 Merge branch 'master' into feature/xml.lite_tweaks 4b67561c3 remove validate() overload that nobody is using fa15f1e5d Squashed commit of the following: 1484a9090 test the new validate() API 470da70fb hookup StringStreamT routines 2cddf2504 begin hooking up validate() overloads 1b5d910f3 overload validate() for UTF-8 and Windows-1252 03309b8c9 Squashed commit of the following: b72c6c5bf older compiler doesn't like our make_unique af8f00307 validate UTF-8 XML on Linux 211188613 unit-test for LEGACY XML validation 3c1169d2b Squashed commit of the following: 3afff19ca std::filesystem::path for FileInputStreamOS 908d452f8 WIP: validate all of our sample XML files 00f9bb16b validate against a XML schema 243d8c356 Merge branch 'master' into feature/xml.lite_tweaks 2815d707d fix to work with SWIG bindings. :-( 460862132 trying (again) to remove vestiages of old code e3c83a858 Revert "new code should use UTF-8" 811207c92 new code should use UTF-8 0ffd835f9 Squashed commit of the following: 1e7e03ded Merge branch 'master' into feature/xml.lite_tweaks c1d806aff Merge branch 'master' into feature/xml.lite_tweaks 850d3c811 str::strip() that can be easier to use than str::trim() 580ba9c8c explicitly =delete move 2b39831a8 Squashed commit of the following: 39eebdc23 Merge branch 'master' into feature/xml.lite_tweaks 9adf86cba force calling new UTF-8 write() routines ea61b6204 Merge branch 'master' into feature/xml.lite_tweaks 8a34583fa overload to take schemaPaths as filesystem::path 8671b442f parse XML embedded in a binary file ec4a902f1 updates from xerces.lite 80dc4d963 updates from xerces.lite 549766d6c Attributes::contains() no longer catches an exception 8a645ceac need "sys/" when building in other environments 36af08269 super-simple URI validation 78ef28a3e SWIG bindings are a PITA! :-( e9cba8491 SWIG needs help with Uri 8a8d8dc07 another routines used by pre-build SWIG bindings 818e1ec5d pre-build SWIG bindings use getElementByTagName() member function 067cac5d8 old compiler gets confused on unadorned QName ba92c0ae7 more use of Uri and QName 446c7d17a use QName in new code d6f8b0c83 more direct use of QName 90fff1c73 use xml::lite::QName instead of tuple 646cbb5ed more direct use of QName and Uri ba589ea3b make QName more robust bab0ee8b5 createElement() -> addNewElement() e3a145747 grab changes from six-library 32285e95c Merge branch 'master' into feature/xml.lite_tweaks 9f79f0bf6 Merge branch 'master' into feature/xml.lite_tweaks a12bbc32c make it easier to create new Elements with a value fc9967f98 make it easy for callers to addChild() keep a reference to the Element 4627766b7 be sure test_xmlparser works in "externals" of other projects bf2276396 "private" is part of the name-mangling fad92bcc8 making sure copy-ctor is implemented f90fdcead consolidate common XML test code 9fc53f2d5 use str:: utility for casting 6da6f794b still trying to find the right macro for SWIG 0c1b86c56 still trying to fix SWIG fdc6fc9bd trying to fix SWIG build error 7835e8c27 SWIG needs copy-ctor 585695942 disable copy/assignment for Element, it's probably almost always wrong 391fed613 fix double-delete caused by copying 61790fe69 retry parsing XML with Windows-1252 if first parse() fails 63cffac59 change string_encoding to match coda-oss style of PascalCase 010479bbe read an XML file we know is wrongly encoded as Windows-1252 9a0505062 more references instead of pointers 2d44b6951 Reading Windows-1252 w/o "encoding" fails 63dc7b076 read Windows-1252 too c9434c9cb test as UIT-8 too f310ccf0c get reading from UTF-8 XML working on Windows 1fa39c2be get testReadUtf8XmlFile working on Linux 1a83cd815 sys::Path is too much trouble right now ed60aa22c unit-test to read XML from a file a9336db7c Squashed commit of the following: 0825beb0d Merge branch 'master' into feature/xml.lite_tweaks c618489be Merge branch 'master' into feature/xml.lite_tweaks e8e4b8fe1 determine string_encoding based on platform 1f43bcfc2 create a new Element by using the platform to determine "characterData" encoding 961bef66b Merge branch 'master' into feature/xml.lite_tweaks e9798a5cb fix static_assert() 6f7772874 Merge branch 'master' into feature/xml.lite_tweaks b98d4f5a9 Merge branch 'master' into feature/xml.lite_tweaks 1b5abba2a The (old) version of SWIG we're using doesn't like certain C++11 features. 53bdeabaf Merge branch 'master' into feature/xml.lite_tweaks 60cf8ae80 "" doesn't work with decltype() in older C++ 97e72477a reduce getValue() overloads by making "key" a template argument 5e6373e55 reduce code duplication f9e7cfeee provide castValue instead of getValue(T&) cbd0bd8f2 castValue throws instead of returning a bool like getValue(T&) 87c7514fc Merge branch 'master' into feature/xml.lite_tweaks 10cc61223 make getElement*() consistent for zero or >1 results f5b137e3c Merge branch 'master' into feature/xml.lite_tweaks 1765efc62 allow clients to specify toType() and toString() for getValue() and setValue() df8b746e1 allow clients to specify their own toType/toString routines 66702726a Merge branch 'master' into feature/xml.lite_tweaks 6956311f1 Merge branch 'master' into feature/xml.lite_tweaks d505f3593 Merge branch 'master' into feature/xml.lite_tweaks fbd106115 catch a BadCastException and return false from getValue() 3a78377b5 use a template to reduce duplicated code 0ad4b8606 Merge branch 'master' into feature/xml.lite_tweaks a848aa3a2 get & set the characer data as a type f3ee1ee12 utility routines to set an attribute value 595227683 templates to get an attribute value convert to a specific type 06639227b miised a change in last commit 1aa458ef8 add getValue() overloads that return true/false rather than throwing faa6d3075 added getElementByTagName() overloads as that's a very common use-case git-subtree-dir: externals/coda-oss git-subtree-split: f4d42005fa477ae59da193422aa2cb14b877cf0c commit ec161c5b334ea8133777a78ce94181807e591642 Merge: d2d594b9f 272cae451 Author: Dan Smith Date: Tue Jun 13 17:51:29 2023 -0400 Merge commit '272cae451cbe3ad6820d1221aafe375d77b1ba04' into develop/sync_externals commit d2d594b9ff50bc00c15a4228927ea1ec0449381b Author: Dan Smith Date: Tue Jun 13 17:51:25 2023 -0400 latest from CODA-OSS and NITRO commit 09ec30cc503ffd74daa401514ab9b674c6e4a3cf Merge: 28a4b2bd1 4a21b2db5 Author: Dan Smith Date: Thu Jun 15 15:54:31 2023 -0400 Merge branch 'main' into develop/complex_short commit 28a4b2bd17daabbb9ba94aae53a58986acd58a9b Author: Dan Smith Date: Thu Jun 15 14:58:55 2023 -0400 restore "old" CODA-OSS to minimize differences commit f41c086967d2e5b05ee8988272ab8ca8c0014f85 Author: Dan Smith Date: Thu Jun 15 14:40:31 2023 -0400 keep using std::complex<> everywhere commit bc1704c8cb985f1987a7d3ff2b37c2e48286a8fd Author: Dan Smith Date: Thu Jun 15 14:22:47 2023 -0400 latest from CODA-OSS commit 4ec782e6c9409f1985628c36a88577b286af61e7 Author: Dan Smith Date: Thu Jun 15 13:56:24 2023 -0400 build against "old" CODA-OSS commit bffd6a985d8dc8e08b42aed78bbe7a162ac45bf6 Author: Dan Smith Date: Thu Jun 15 13:56:08 2023 -0400 restore CODA-OSS changes to minimize merge differences commit d93e0e80c94013e1b957eb2c33ba112643c306c3 Author: Dan Smith Date: Thu Jun 15 13:39:37 2023 -0400 more passing the entire complex type as a template parameter commit 0872159268ff8f38e3c3d42788598725ce142616 Author: Dan Smith Date: Thu Jun 15 13:25:14 2023 -0400 no more types::complex commit 379a89312f55c86f1de95f6ff14e7aeca72df32c Author: Dan Smith Date: Thu Jun 15 12:36:06 2023 -0400 use CODA_OSS_types_unique_zinteger commit 2b9b396c4d460233418f293d6ebdf157231b8757 Author: Dan Smith Date: Thu Jun 15 11:58:00 2023 -0400 latest from CODA-OSS commit 5d19ea2946556ab9f7e2e1ec98e0d07fecf578e2 Merge: 0dab1a156 7e99024da Author: Dan Smith Date: Thu Jun 15 11:07:26 2023 -0400 Merge branch 'develop/complex' into develop/complex_short commit 7e99024da866660e7e4da621b75f4561e638044b Author: Dan Smith Date: Thu Jun 15 11:06:20 2023 -0400 unittest changes from develop/complex_short branch commit e5c0f6d52e05bf50741a6bc086eae9ce53a89e9e Author: Dan Smith Date: Thu Jun 15 11:00:34 2023 -0400 more changes from CODA-OSS commit ca7cb60f6b39a2f1a03dd1497bb20a4da5925c24 Author: Dan Smith Date: Thu Jun 15 10:34:57 2023 -0400 no more types::complex commit 6048da55638d0283cf789347740871aa2d07fba1 Author: Dan Smith Date: Thu Jun 15 10:18:44 2023 -0400 latest from CODA-OSS commit 16c99ed82bb9b57edc1ea5e28d68f89b63519664 Author: Dan Smith Date: Thu Jun 15 08:13:27 2023 -0400 pass the entire complex type and use value_type commit 4d9d2a764319f3177b427b3a03ae95c99ef02494 Author: Dan Smith Date: Thu Jun 15 09:24:49 2023 -0400 pass entire complex type as template parameter commit 0dab1a15681e51a5464b363baa0f263e25521c4a Author: Dan Smith Date: Thu Jun 15 09:24:49 2023 -0400 pass entire complex type as template parameter commit e4c29f670785b3312dda1d6b6da30847fa798b89 Author: Dan Smith Date: Thu Jun 15 09:14:37 2023 -0400 Update PVPBlock.cpp commit 7133f7f4b4752d0e049ef48241a4e1b707a5c4ec Author: Dan Smith Date: Thu Jun 15 09:09:11 2023 -0400 restore types::z* overloads commit 9a0c890090d5501bb2c563e0b36a787cfad70af6 Merge: a3a71ba35 fc8ba82bd Author: Dan Smith Date: Thu Jun 15 09:01:31 2023 -0400 Merge branch 'develop/complex' into develop/complex_short commit fc8ba82bd5357454d02276c1605ddcd5973322d1 Author: Dan Smith Date: Thu Jun 15 08:59:58 2023 -0400 findComplex() utility commit 8b762374c282458c469ad6e4502aaee7aa695079 Author: Dan Smith Date: Thu Jun 15 08:47:56 2023 -0400 const& for Parameter arguments commit a3a71ba351b9b790c20bb80e4fac861592758164 Author: Dan Smith Date: Thu Jun 15 08:26:00 2023 -0400 getComplex() overloads commit 6fc1ee4b96b722b81042f79ed476c481af13aadd Author: Dan Smith Date: Thu Jun 15 08:13:27 2023 -0400 pass the entire complex type and use value_type commit 13e44351a9e912c91fd79ada8b09a544c482874a Author: J. Daniel Smith Date: Wed Jun 14 21:47:37 2023 -0400 more progress on types::complex commit 5e72ecca7037861e87f311339c61bc2cf77305fe Author: Dan Smith Date: Wed Jun 14 17:43:52 2023 -0400 use our own type for complex commit 9bfc4f9799df5261bbc0c7afb1ffa08abc060ba1 Author: Dan Smith Date: Wed Jun 14 17:42:58 2023 -0400 latest from CODA-OSS commit 39153f274d56de88a28b526978dd4ad832e767f9 Author: Dan Smith Date: Wed Jun 14 16:45:05 2023 -0400 fix Parameter::setValue() overloads commit b8007fbad15e529eb503bbfd692c85ce6d34a0a6 Author: Dan Smith Date: Wed Jun 14 16:37:10 2023 -0400 latest from coda-oss commit 27f080ec628c4497709cfc85183f3a1ceaad11cb Author: Dan Smith Date: Wed Jun 14 16:22:29 2023 -0400 move is implicitly deleted because of =delete for copy commit bd69591ff8c93d1aaa9f184346eac2aca83b3272 Merge: 71d519492 35b59b9a0 Author: Dan Smith Date: Wed Jun 14 16:09:16 2023 -0400 Merge branch 'main' into develop/complex_short commit 71d519492046c4c61986f181f6ec7aa18cb4c0c6 Author: Dan Smith Date: Tue Jun 13 15:25:54 2023 -0400 std::complex -> six::zfloat commit a3eee8257746732f61b959c9b31442511d81b590 Merge: d0bb8c181 e13c3da4f Author: Dan Smith Date: Tue Jun 13 15:17:07 2023 -0400 Merge branch 'main' into develop/complex_short commit d0bb8c1819da2ade60c4ce3349ff40f32fe31301 Author: Dan Smith Date: Tue Jun 13 15:15:46 2023 -0400 finish (almost) switching to types::complex for integers commit bbe1320e33768a0a0f151feb138643c80a8bdfbd Author: Dan Smith Date: Tue Jun 13 14:57:21 2023 -0400 types::complex is std::complex for now commit 00047f57ea462c610d249d25fcd2f0105a7c0f41 Author: Dan Smith Date: Tue Jun 13 14:36:27 2023 -0400 latest from coda-oss commit ac376dcf72763892e9e9b9c03fb14bc34fd04630 Author: Dan Smith Date: Tue Jun 13 14:13:42 2023 -0400 Update test_dump_images.cpp commit 2907efbcfdb33f154138944831a94a2c508b5a68 Author: Dan Smith Date: Mon Jun 12 16:39:29 2023 -0400 use types::complex for TInteger commit 2580312337bf1b7ee20d5ba9eed83c8e65e06e6f Author: Dan Smith Date: Mon Jun 12 16:26:16 2023 -0400 CPHD aliaes for std::complex commit d177963c782c08c137d14b9608207d40754db568 Author: Dan Smith Date: Mon Jun 12 16:17:38 2023 -0400 latest from coda-oss commit e05937c9b568f52fa9f41b279e2c8ecfa63e5fc0 Author: Dan Smith Date: Mon Jun 12 15:41:34 2023 -0400 use types::z* aliases for complex commit 2b61dcc4974b7326db762f6f6fd60dc263bb87e6 Author: Dan Smith Date: Mon Jun 12 15:05:41 2023 -0400 begin switching to types::complex for integral T commit b4e625673c3d270896eed26b4c83bc827befc538 Author: Dan Smith Date: Mon Jun 12 14:59:30 2023 -0400 turn off _SILENCE_NONFLOATING_COMPLEX_DEPRECATION_WARNING commit 9bd683bc8858d07378c390c3cd4fcaed4a490a21 Author: Dan Smith Date: Mon Jun 12 14:54:22 2023 -0400 std::complex -> zfloat commit 47aa0e8994af5b31602f63adaac3b3415cb769c2 Author: Dan Smith Date: Mon Jun 12 14:45:00 2023 -0400 std::complex -> zfloat commit 3785ed2c8e0f812ae43e1e81971bce6777eb91a1 Author: Dan Smith Date: Mon Jun 12 14:38:18 2023 -0400 aliases for std::complex and std::complex commit d5db375ba08737551023d9b21455f3d5cd71faf0 Author: Dan Smith Date: Mon Jun 12 14:20:01 2023 -0400 Squashed commit of the following: commit bb2bb5aaf944040ea5bc42168b846324287dcad8 Merge: bbba5a210 4c146e7d0 Author: Dan Smith Date: Mon Jun 12 13:04:09 2023 -0400 Merge commit '4c146e7d01b14cf408b0e398cba96705df69090c' into develop/sync_externals commit 4c146e7d01b14cf408b0e398cba96705df69090c Author: Dan Smith Date: Mon Jun 12 13:04:09 2023 -0400 Squashed 'externals/coda-oss/' changes from aeec0131c..c88b9c053 c88b9c053 types::complex (#681) d1244a080 don't need our own make_unique in C++14 (#680) git-subtree-dir: externals/coda-oss git-subtree-split: c88b9c05325c802f88a85ddcebb498be4afacad0 commit bbba5a210c0257f622781914e9d228eeca23341c Author: Dan Smith Date: Mon Jun 12 13:04:06 2023 -0400 latest from CODA-OSS commit 370dd8876136755230624ebc955bc67642b1482b Merge: 58ff5a537 ffe1caafd Author: Dan Smith Date: Mon Jun 12 13:03:25 2023 -0400 Merge branch 'main' into develop/sync_externals commit 58ff5a5371d9158910e99613f4ce6e6fc36e543e Author: Dan Smith Date: Thu Jun 8 16:23:08 2023 -0400 latest from CODA-OSS commit 3bfc33a40274fa7a073983d4e4ddd907e45730d2 Author: Dan Smith Date: Thu Jun 8 14:34:45 2023 -0400 latest from CODA-OSS and NITRO commit 389417a983778ba2a07af9c6dbfea80484324b97 Merge: bce7ba0b1 4ad490fe4 Author: Dan Smith Date: Thu Jun 8 14:34:28 2023 -0400 latest from CODA-OSS and NITRO commit 4ad490fe4224df18ce4a437c40a257af0686140e Author: Dan Smith Date: Thu Jun 8 14:34:22 2023 -0400 Squashed 'externals/nitro/' changes from c8ecbe9ae..05dae18a3 05dae18a3 patch to build other projects 8f974e995 NITRO-2.11.3 (#554) 870aa6afd update to coda-oss 2023-06-05 (#553) 2fd7a0bfa latest from coda-oss (#552) 0eecce004 invoke() utility to reduce code duplication (#550) 59fb02fe9 latest from coda-oss (#551) 9fbf2b7b8 Fill out adapter free block which is used for nitf decompression (#549) 089ba0b5b latest from coda-oss 3b52f0025 latest from coda-oss (#547) 90c6263e2 latest from coda-oss (#544) 90d513ac5 latest from coda-oss (#543) git-subtree-dir: externals/nitro git-subtree-split: 05dae18a3a9c5ad70e1ce814c21ca8ec278829be commit 86929db19a438630d531ca0c34bdcd8e8c527ae9 Author: Dan Smith Date: Thu Jun 8 14:34:18 2023 -0400 Squashed 'externals/coda-oss/' changes from e87c32b4d..aeec0131c aeec0131c assert()s for mem::CopyablePtr (#679) 72b0ebd60 add types::complex_short (#678) 932130a58 patch to build other projects c00c1f203 coda-oss release 2023-06-06 (#677) ef54bbcd5 remove more compiler warnings (#676) dadfc5ce6 distinguish between byte-swapping a buffer and single value (#674) 90187f6cd more xml.lite tweaks for SIDD-3.0/ISM (#675) eb9960772 stronger type-checking for byteSwap() (#673) ff4f820ed xml.lite tweaks to support SIDD 3.0 ISM (#672) b1de8c0e5 std::byte should be a unique type (#671) c05bf9a02 allow enums to be byte-swapped too 1f9fd88d6 remove spurious 47684c45b byteSwap now uses byte buffers (#670) cbc659db2 add swapBytes() utility from SIX (#669) 891481b64 simplify byte-swapping (#668) 540ae763e more byteSwap() tweaks 0774c03c4 threaded byteSwap() (#667) d156370d3 swapping a single-byte value makes no sense c120e3255 be sure parameter is used to avoid compiler warning e85ec9331 --output-on-failure for CTest (#666) e80376197 turn off "there is no warning number" warning c5f0a5d15 A C-string may not be NULL-terminated (#665) 0c5eb29ae use platform-specific routines for byteSwap() (#664) 0b7d581fa remove transform_async() (#663) f6489b6be Merge branch 'main' into feature/xml.lite_tweaks 836c426a2 use function-pointers so that isConsoleOutput is only checked once 56e3c45b1 move depthPrint() functionality into non-member function in preparation for future changes ddcd26d97 Merge branch 'main' into feature/xml.lite_tweaks 69cc0e506 use the more rigorous create_and_check_datatype() 9efb87558 Merge branch 'main' into feature/hdf5 4d2f2f417 more HighFive unittests (#662) 14191a844 HighFive::create_datatype() goes from C++ to HighFive 98583473f utility routines to read string attributes 1fa75ce81 use the C API to read a string attribute 71e7b69f5 still can't figure out how to read a string attribute :-( e96f37a69 test reading the file attributes a25244519 getAttribute() unittest 8f12a3000 getDataType() unittest 857ff0af3 HighFive utility routines (#661) 1d687db57 writeDataSet() utility overload 106aa6894 sigh ... H5Easy::dump() fill fails on Windows/WAF :-( 2641b60b2 Merge branch 'main' into feature/hdf5 35c19e7e8 change actions to @v3 (#660) 212bbd3a3 works on local machine, but not build server ... ? 7125118b0 dump of 1D vector doesn't work :-( c704db435 sigh ... WAF build still failing :-( 01aae4616 does dump() of a 1D vector work? 76a53c813 comment-out H5 writing :-( 0f0e19aff test_highfive_dump() cb8f73795 trying to get highfive_dump() unittest working w/Windows-WAF 6584a264a does test_highfive_create() work? cde6147ce tweak HighFive wrappers (#659) 316566854 Revert "trying HighFive "write" unittests again" a9ec24ca4 trying HighFive "write" unittests again 585ad49a5 tweak names of utility routines 4c91a4d97 make it easier to read a std::vector and std::vecotr 0217ffa26 readDataSet() now works for 1D data 95e8973f2 trying to get hdf5::lite::load() working 4d294611d "const" correctness 5e6305c3f fix load_complex() 4a134dc5f start work on utility routines to read complex data from HDF5 9d76a7f41 Merge branch 'main' into feature/hdf5 8f9667a24 whitepsace ebd3fc99e Merge branch 'main' into feature/hdf5 40091b069 comment-out writing tests for now ... need to figure our WAF bulid failure 935aa3459 be sure the dataset has real data 114b9bf33 update release notes bd9c0b26c tweak HighFive utility routines acda1ef57 turn off diagnostics around expected failures 22a748840 readDataSet() utility routine for HighFive bd88a8c25 HighFive writeDataSet() utility to work with our SpanRC 6142f5b33 use HighFive routines to write a HDF5 file 5bbf1abaf Use HiveFive routines to get info about the file 84fbc8378 duplicate unittests with H5Easy f1f054c03 Merge branch 'main' into feature/hdf5 9b63ca470 fix directory names f6f826689 fix directory names 7aeb82c33 Merge branch 'main' into feature/hdf5 d028baaeb hook up HighFive header-only library (#653) 3083b0a31 Revert "HighFive 2.6.2" 246985a7f Revert ""build" HighFive HDF5 library" a8b75a586 Revert "turn off HighFive Boost support" ec68d5f83 Revert "Add HighFive unittests" f1f85b9e7 Revert "get test_high_five_base more-or-less compiling" 5ea634ee1 Revert "more work on getting HighFive unittests to build" ecc45433c more work on getting HighFive unittests to build bb194788a get test_high_five_base more-or-less compiling d42bde000 Add HighFive unittests ddc86bb32 turn off HighFive Boost support b255122d4 "build" HighFive HDF5 library 396cc3ef2 HighFive 2.6.2 5e5f9d9c0 Merge branch 'main' into feature/hdf5 ee938b4a5 changes from SIX bb764df90 Merge branch 'main' into feature/xml.lite_tweaks de2a24380 make derived classes 'final' if possible 14e19bcd2 Change xml lite function to virtual (#645) 8f42ac8e9 Merge branch 'main' into feature/xml.lite_tweaks 18ad90645 hdf5Write unittest 3462e1179 createFile() and writeFile() overloads ecee81d53 fix typos 197eecfa6 sketch-out hdf5::lite::writeFile() bd2311795 use SpanRC for writeFile(), not yet implemented ea9af7510 simple SpanRC to hold a 2D-size and pointer 027c19ee8 createFile() unittest 1f9d07ecb hook up createFile() 8c7e4473f start hooking up HDF5 writing 146e0bea3 Merge branch 'main' into feature/hdf5 88ca9fcb7 Merge branch 'main' into feature/hdf5 42b604b46 Squashed commit of the following: 10ee602c2 Merge branch 'main' into feature/hdf5 67aa42b69 restore changes from "main" 8bbfcbfbf unittests can be simplified to match fewer "view" classes 126bb802e Merge branch 'main' into feature/hdf5 3f8ba7a42 again, don't need a class just to convert from std::vector<> to std::span<> 24c2b489c Squashed commit of the following: 2703c119d Squashed commit of the following: 9d5228a2b don't need an entire class just to convert a std::vector<> into std::span<> 51bc931dc Merge branch 'main' into feature/hdf5 a84f25816 Squashed commit of the following: c4d2ed696 add missing #include guards, fix type in existing #include guard d541525a0 use a single ComplexViewConstIterator for all views 86e6a459f CODA_OSS_disable_warning causes GCC errors :-( 5d4b9c2cb only need an custom iterator for ComplexSpansView d9f0fb128 hook up iterators b9329e4db initial pass at a ComplexViewConstIterator 635238873 remove compiler warning about unused "constexpr" variables b39f6096f use the casing from H5 to make copy/pasting code slightly easier 0887b13eb Merge branch 'main' into feature/hdf5 bd07df1ca Consistent casing for Dataset, Datatype, Dataspace 7acd30ee2 tweak hdf5.lite dependencies 38ab914df Jupyter notebook for creating H5 files 95a040e0b _small.h5 is now (correctly) FLOAT32 107e7c487 make a simple values() member function to avoid template magic e1feca919 use TEST_SPECIFIC_EXCEPTION macro instead of try/catch 738333688 readDatasetT() now throws for the wrong buffer type 6b2cc2529 Merge branch 'feature/hdf5' of github.com:mdaus/coda-oss into feature/hdf5 310f8fd3d can't get template magic right for copy_axis() 86b306d59 stepping through copy ctors in the debugger is annoying f243e92d6 trying to make wrong type of buffer fail 2b10d9652 read in new sample file a28e59d8c help the compiler with type deduction 49bf5e9bc nested_complex_float_data_small.h5 e029325fc utility routines to "deconstruct" and array of std::complex dede3bd39 Merge branch 'main' into feature/hdf5 904b1ef5e tweak class names, make_() and copy() utility routines 8237b9efb make it harder to pass the wrong types to ComplexViews 4d9aeda2c ComplexArrayView and ComplexParallelView utility classes f5e367dfa test std::span> a4a2844f2 read in the nested "i" and "r" data 115615265 sample file has subgroups 8e1b7869a Merge branch 'feature/hdf5' of github.com:mdaus/coda-oss into feature/hdf5 9f4232a1d update sample H5 file 8c55db73a walk through HDF5 sub-groups 7775ed9c4 Update 123_barfoo_catdog_cx.h5 677975d7c Matlab code to create sample H5 file a0e7dfe07 Update test_hdf5info.cpp 0b67e1602 pass __FILE__ and __LINE__ from calling site for a more accurate exception message 86a677321 skeleton for more sample data 85f79b099 Merge branch 'main' into feature/hdf5 18088e942 Merge branch 'main' into feature/hdf5 3a1d17692 Merge branch 'main' into feature/hdf5 1755c69d7 Merge branch 'main' into feature/hdf5 9ad015432 No more "11" suffix on exception names c20d96251 Squashed commit of the following: c88cee999 other values to be filled-in bca4a4ecd incorporation NamedObject from HDF5 docs 61fa68f72 groupInfo() 460e7d766 datasetInfo() 14eb9b764 start filling in DatasetInfo afe5f1c3a start to fill in DatasetInfo 77a968c72 start filling in GroupInfo d81bcdfd9 openGroup() to open groups (loc) a0cd29469 comment-out "dataset" unittest for now 86e006024 begin filling in FileInfo 366dda6ab a return_type_of utility is needed to deduce the return type e21928263 explicitly pass return type to template 4937ccd11 template to reduce boilerplate when calling try_catch_H5Exceptions b3b5ebde7 use new exception utility routines ea1c03ef0 put exception handling/conversion in a utility routine 819a99d39 utility routine for exception handling 6f34eea97 put utilities in a separate file for easier reuse fcbde4f24 break utility routines into smaller pieces for easier reuse 52358ea8a WIN32 no longer automatically defined? 5a4286472 Revert "build HDF5 with C89" 680e599e9 build HDF5 with C89 a87a07121 Merge branch 'main' into feature/hdf5 8447c1a90 Revert "sym-links instead of copying files" db3b5e12b Merge branch 'main' into feature/xml.lite_tweaks fb60b5696 Merge branch 'main' into feature/hdf5 5110a5cc8 Comments about _u and _q 1a937d32c Merge branch 'main' into feature/xml.lite_tweaks fa06f04d7 get ready for hdf5.lite enhancdements b040c7c43 sym-links instead of copying files aa431bb47 use _u for xml::lite::Uri 3d0c6d58c fix case-sensitive #include filename 93dcd0e52 operator() for getElementByName() 75a93af85 more operator[] overloads to make attribute management easier 4ab8216f8 user-defined string literals to remove some noise around xml::lite::QName f82f0b0fc Merge branch 'main' into feature/xml.lite_tweaks ae30e3644 Merge branch 'feature/xml.lite_tweaks' of github.com:mdaus/coda-oss into feature/xml.lite_tweaks ffdd9beb0 simplify attribute creation 9bf5414f5 simplify attribute creation 82d7a4e95 SWIG gets confused about namespaces 7a61d0741 fix bug on Element ctor uncovered by unittest fdd7e58c1 QName is also in the xerces namespace which confuses SWIG bindings a325b7053 operator+=() overload for addChild daf30e6c0 Merge branch 'feature/xml.lite_tweaks' of github.com:mdaus/coda-oss into feature/xml.lite_tweaks b887d2b47 provide overloads for Element& rather than creating new "reference" types 1fa6bba38 rename test_xmleasy.cpp 7c8c9e0f1 += overload 850da6f63 overload for std::string 4547fc5a7 use UIT-8 strings for characterData 4723462a3 convenient addChild() overloads e48720753 copy over ElementReference from xml.easy a4ca30a0d Merge branch 'main' into feature/xml.lite_tweaks 6ae9f0b71 Revert "check-in of new xml.easy (to move code between computers)" f7466a6d7 Revert "simple routines for single element" a5490230d Revert "make some operators simplier ways of calling functions" c9a25630a Revert "get document creation working" 8af8710b0 Revert "free functions instead of member functions" 16c3847cb Revert "ElementReference distinct from Element" 7d68e156f Revert "ElementMutableReference" 00eb2a282 Merge branch 'main' into feature/xml.lite_tweaks a42969c1f ElementMutableReference a20ae9355 ElementReference distinct from Element 14eeeea0b free functions instead of member functions 4aae014b3 get document creation working 883569269 make some operators simplier ways of calling functions 053bd1212 simple routines for single element 8bf701a2e check-in of new xml.easy (to move code between computers) 41f959051 unittests for creating XML documents from scratch 9752d50ae Merge branch 'main' into feature/xml.lite_tweaks 1531d5709 by default, don't validate strings passed to Uri() 46d13d4bf Merge branch 'master' into feature/xml.lite_tweaks 39b547d32 remove more vestiges of Expat and LibXML ec8274d52 remove LibXML and Expat as they're no longer used/supported. 20eeefeef Merge branch 'master' into feature/xml.lite_tweaks 95074b9b1 update for newer Intel compiler 7024f71e1 Merge branch 'master' into feature/xml.lite_tweaks 57b1cbc83 Merge branch 'master' into feature/xml.lite_tweaks 4b67561c3 remove validate() overload that nobody is using fa15f1e5d Squashed commit of the following: 1484a9090 test the new validate() API 470da70fb hookup StringStreamT routines 2cddf2504 begin hooking up validate() overloads 1b5d910f3 overload validate() for UTF-8 and Windows-1252 03309b8c9 Squashed commit of the following: b72c6c5bf older compiler doesn't like our make_unique af8f00307 validate UTF-8 XML on Linux 211188613 unit-test for LEGACY XML validation 3c1169d2b Squashed commit of the following: 3afff19ca std::filesystem::path for FileInputStreamOS 908d452f8 WIP: validate all of our sample XML files 00f9bb16b validate against a XML schema 243d8c356 Merge branch 'master' into feature/xml.lite_tweaks 2815d707d fix to work with SWIG bindings. :-( 460862132 trying (again) to remove vestiages of old code e3c83a858 Revert "new code should use UTF-8" 811207c92 new code should use UTF-8 0ffd835f9 Squashed commit of the following: 1e7e03ded Merge branch 'master' into feature/xml.lite_tweaks c1d806aff Merge branch 'master' into feature/xml.lite_tweaks 850d3c811 str::strip() that can be easier to use than str::trim() 580ba9c8c explicitly =delete move 2b39831a8 Squashed commit of the following: 39eebdc23 Merge branch 'master' into feature/xml.lite_tweaks 9adf86cba force calling new UTF-8 write() routines ea61b6204 Merge branch 'master' into feature/xml.lite_tweaks 8a34583fa overload to take schemaPaths as filesystem::path 8671b442f parse XML embedded in a binary file ec4a902f1 updates from xerces.lite 80dc4d963 updates from xerces.lite 549766d6c Attributes::contains() no longer catches an exception 8a645ceac need "sys/" when building in other environments 36af08269 super-simple URI validation 78ef28a3e SWIG bindings are a PITA! :-( e9cba8491 SWIG needs help with Uri 8a8d8dc07 another routines used by pre-build SWIG bindings 818e1ec5d pre-build SWIG bindings use getElementByTagName() member function 067cac5d8 old compiler gets confused on unadorned QName ba92c0ae7 more use of Uri and QName 446c7d17a use QName in new code d6f8b0c83 more direct use of QName 90fff1c73 use xml::lite::QName instead of tuple 646cbb5ed more direct use of QName and Uri ba589ea3b make QName more robust bab0ee8b5 createElement() -> addNewElement() e3a145747 grab changes from six-library 32285e95c Merge branch 'master' into feature/xml.lite_tweaks 9f79f0bf6 Merge branch 'master' into feature/xml.lite_tweaks a12bbc32c make it easier to create new Elements with a value fc9967f98 make it easy for callers to addChild() keep a reference to the Element 4627766b7 be sure test_xmlparser works in "externals" of other projects bf2276396 "private" is part of the name-mangling fad92bcc8 making sure copy-ctor is implemented f90fdcead consolidate common XML test code 9fc53f2d5 use str:: utility for casting 6da6f794b still trying to find the right macro for SWIG 0c1b86c56 still trying to fix SWIG fdc6fc9bd trying to fix SWIG build error 7835e8c27 SWIG needs copy-ctor 585695942 disable copy/assignment for Element, it's probably almost always wrong 391fed613 fix double-delete caused by copying 61790fe69 retry parsing XML with Windows-1252 if first parse() fails 63cffac59 change string_encoding to match coda-oss style of PascalCase 010479bbe read an XML file we know is wrongly encoded as Windows-1252 9a0505062 more references instead of pointers 2d44b6951 Reading Windows-1252 w/o "encoding" fails 63dc7b076 read Windows-1252 too c9434c9cb test as UIT-8 too f310ccf0c get reading from UTF-8 XML working on Windows 1fa39c2be get testReadUtf8XmlFile working on Linux 1a83cd815 sys::Path is too much trouble right now ed60aa22c unit-test to read XML from a file a9336db7c Squashed commit of the following: 0825beb0d Merge branch 'master' into feature/xml.lite_tweaks c618489be Merge branch 'master' into feature/xml.lite_tweaks e8e4b8fe1 determine string_encoding based on platform 1f43bcfc2 create a new Element by using the platform to determine "characterData" encoding 961bef66b Merge branch 'master' into feature/xml.lite_tweaks e9798a5cb fix static_assert() 6f7772874 Merge branch 'master' into feature/xml.lite_tweaks b98d4f5a9 Merge branch 'master' into feature/xml.lite_tweaks 1b5abba2a The (old) version of SWIG we're using doesn't like certain C++11 features. 53bdeabaf Merge branch 'master' into feature/xml.lite_tweaks 60cf8ae80 "" doesn't work with decltype() in older C++ 97e72477a reduce getValue() overloads by making "key" a template argument 5e6373e55 reduce code duplication f9e7cfeee provide castValue instead of getValue(T&) cbd0bd8f2 castValue throws instead of returning a bool like getValue(T&) 87c7514fc Merge branch 'master' into feature/xml.lite_tweaks 10cc61223 make getElement*() consistent for zero or >1 results f5b137e3c Merge branch 'master' into feature/xml.lite_tweaks 1765efc62 allow clients to specify toType() and toString() for getValue() and setValue() df8b746e1 allow clients to specify their own toType/toString routines 66702726a Merge branch 'master' into feature/xml.lite_tweaks 6956311f1 Merge branch 'master' into feature/xml.lite_tweaks d505f3593 Merge branch 'master' into feature/xml.lite_tweaks fbd106115 catch a BadCastException and return false from getValue() 3a78377b5 use a template to reduce duplicated code 0ad4b8606 Merge branch 'master' into feature/xml.lite_tweaks a848aa3a2 get & set the characer data as a type f3ee1ee12 utility routines to set an attribute value 595227683 templates to get an attribute value convert to a specific type 06639227b miised a change in last commit 1aa458ef8 add getValue() overloads that return true/false rather than throwing faa6d3075 added getElementByTagName() overloads as that's a very common use-case git-subtree-dir: externals/coda-oss git-subtree-split: aeec0131c51497c5d448a39be0d2df608d93bc15 commit bce7ba0b1ae40e9ddcb4f24610e7e4d702272d54 Merge: 646b70e8d 86929db19 Author: Dan Smith Date: Thu Jun 8 14:34:18 2023 -0400 Merge commit '86929db19a438630d531ca0c34bdcd8e8c527ae9' into develop/sync_externals commit 646b70e8d47438211451493837e6b2d76db4e896 Author: Dan Smith Date: Thu Jun 8 14:34:13 2023 -0400 latest from CODA-OSS and NITRO * use cphd::Version enum rather than strings * use cphd::Version in more places instead of a string version * cphd::FileHeader::DEFAULT_VERSION has to be `const char*` for existing Python bindings * releaseInfo can be empty (but must exist) "... we found that the six library does a check when reading a CPHD file to ensure that the Release Info field not only exists, but that it is not an empty string. The CPHD spec does require that the field exists, but does not seem to prohibit it from being an empty string. We have gotten some vendor CPHDs with an empty field here and have failed reading the file due to this. I checked and SARPY is able to read (it must not implement the same check)." * Create CPHD_schema_V1.1.0_2021_11_30.xsd Download from https://nsgreg.nga.mil/registries/search/results.jsp?registryType=doc&searchTextField=cphd&searchOnField=name®isterField=any&itemTypeField=doc&itemTypeField=dst&statusNameField=2&nsgKeywordsField=any&disrServiceAreaField=any&stdStatusField=any&dayField=24&monthField=7&yearField=2023&tzOffset=240&searchButton= * tweak order to match spec * start adding new CPHD 1.1.0 types * Create NGA.STND.0068-1_1.1.0_CPHD_DIDD_FINAL.pdf * keep adding new CPHD 1.1.0 types * prepare to parse optional Polarization parameters added in CPHD 1.1.0 * serialize and parse new PolRefType * add new delayBias parameter * add the UseEBPVP parameter * Add the UseACFPVP parameter * put `ZeroToOne` and `NegHalfToHalf` typedefs in a common place * add AntGPId * use UTF-8 for newly added strings * add DTAId and UseDTA * XmlValueElement utility to minimize copy/paste errors * use six::XmlOptionalElement for more new fields * use XmlOptionalElement for newly added strings * using XmlLite directly, no need for forwarding routines * name() -> tag() * use XmlOptionalElement for newly added optional values * simple update to unittest some new values * Added AntPolRef * add EBFreqShiftSF and MLFreqDilationSF * operator=() instead of value() * remove a little bit of C++ noise * begin work on TxAntenna and RcvAntenna * fix bug in optional causing compile failure * fix optional * XmlValueElement -> XsElement * XmlOptionalElement -> XsElement_minOccurs0 * start hooking up TxAntenna * hook up PerVectorParameterXYZ and PerVectorParameterEB * XmlLite instances should be "const" * switch UnmodeledS to use new XsElement<> so there's more testing; also gets rid of some yucky macros * switch UnmodeledDecorr to XsElement_minOccurs0 * latest from CODA-OSS * XsElement now in xml::lite * use the QName to create an element * XsElement is only used in SIX and there's no test code in CODA-OSS * support existing get() from mem::ScopedCopyablePtr * use implicit casts to minimize differences to existing code * don't need make_XsElement() anymore * compare the QName()s rather than tags. * make it clear when we're accessing the std::optional * with implicit cast, calls to .value() can be reduced preserving existing code * begin adding overloads for QName * parseOptional() -> parse() overload * getFirstAndOnly() overload for QName * XsNonNegativeInteger and XsPositiveInteger_fixed2 aliases * DwellTimeArray * in the XSD, DwellTimeArrayType is almost the same as AntGainPhaseType * DwellTimeArray to the XML * convert new PolarizationType enum values to/from string * update ReleaseNotes.md * Squashed 'externals/coda-oss/' changes from e87c32b4d..065e86ddc 065e86ddc operator==() for QName (#710) 1c16380ce remove zint* typedefs; don't want to encourage use of types::Complex (#709) 6dd247991 our optional<> is now closer to C++17 (#708) 87ac61739 strict checking on `std::complex` is too much of a hassle for now 034d52c86 overloads to byte-swap type::Complex are too much trouble (#707) 42d449c33 sys::byteSwap overloads for types::Complex (#705) 4092fd8e7 remove work-around for NITRO bug (#704) e2472acfc build in NITRO and SIX (#703) 32ccf9105 Use same build paths as Visual Studio (#701) 366ac9f43 Another round of removing compiler warnings (#702) a7f8ef260 Fix compile warnings from building CODA (#700) f70b4202f account for coda-oss.vcxproj being in other SLNs af3faebfc Remove more compiler/code-analysis warnings (#699) 82be2a6db unittests should work w/o install (#698) dbb90a06d add msbuild for coda-oss.sln (#697) 5a417140a reduce compiler warnings (#696) 288619dfa all modules now part of coda-oss.vcxproj (#695) c2fc5fc66 add more projects to coda-oss-lite.vcxproj (#694) ceb86c186 support $(PlatformToolset) as a "special" environment variable (#693) d78a8595a OS::getSIMDInstructionSet() utility (#692) 2d2df467d fix `python3 waf dumplib` 54033e70e Merge branch 'main' into feature/complex_short 3c63f9f65 std::numbers from C++20 (#691) 892dd0e00 ComplexInteger and ComplexReal to better match existing naming conventions (#690) b3872181e match coda-oss naming conventions (#688) 704d6867f beef-up our complex type (#687) 47c1c1cd6 check is_absolute() for URLs (#686) c042373e1 be sure our Path::isAbolute() matches std::filesystem::path::absolute() (#684) ad10286bc volatile is about "special" memory, not threading (#685) f4d42005f fix build error in NITRO ff11a5557 keep using std::complex for now (#682) c88b9c053 types::complex (#681) d1244a080 don't need our own make_unique in C++14 (#680) aeec0131c assert()s for mem::CopyablePtr (#679) 72b0ebd60 add types::complex_short (#678) 932130a58 patch to build other projects c00c1f203 coda-oss release 2023-06-06 (#677) ef54bbcd5 remove more compiler warnings (#676) dadfc5ce6 distinguish between byte-swapping a buffer and single value (#674) 90187f6cd more xml.lite tweaks for SIDD-3.0/ISM (#675) eb9960772 stronger type-checking for byteSwap() (#673) ff4f820ed xml.lite tweaks to support SIDD 3.0 ISM (#672) b1de8c0e5 std::byte should be a unique type (#671) c05bf9a02 allow enums to be byte-swapped too 1f9fd88d6 remove spurious 47684c45b byteSwap now uses byte buffers (#670) cbc659db2 add swapBytes() utility from SIX (#669) 891481b64 simplify byte-swapping (#668) 540ae763e more byteSwap() tweaks 0774c03c4 threaded byteSwap() (#667) d156370d3 swapping a single-byte value makes no sense c120e3255 be sure parameter is used to avoid compiler warning e85ec9331 --output-on-failure for CTest (#666) e80376197 turn off "there is no warning number" warning c5f0a5d15 A C-string may not be NULL-terminated (#665) 0c5eb29ae use platform-specific routines for byteSwap() (#664) 0b7d581fa remove transform_async() (#663) f6489b6be Merge branch 'main' into feature/xml.lite_tweaks 836c426a2 use function-pointers so that isConsoleOutput is only checked once 56e3c45b1 move depthPrint() functionality into non-member function in preparation for future changes ddcd26d97 Merge branch 'main' into feature/xml.lite_tweaks 69cc0e506 use the more rigorous create_and_check_datatype() 9efb87558 Merge branch 'main' into feature/hdf5 4d2f2f417 more HighFive unittests (#662) 14191a844 HighFive::create_datatype() goes from C++ to HighFive 98583473f utility routines to read string attributes 1fa75ce81 use the C API to read a string attribute 71e7b69f5 still can't figure out how to read a string attribute :-( e96f37a69 test reading the file attributes a25244519 getAttribute() unittest 8f12a3000 getDataType() unittest 857ff0af3 HighFive utility routines (#661) 1d687db57 writeDataSet() utility overload 106aa6894 sigh ... H5Easy::dump() fill fails on Windows/WAF :-( 2641b60b2 Merge branch 'main' into feature/hdf5 35c19e7e8 change actions to @v3 (#660) 212bbd3a3 works on local machine, but not build server ... ? 7125118b0 dump of 1D vector doesn't work :-( c704db435 sigh ... WAF build still failing :-( 01aae4616 does dump() of a 1D vector work? 76a53c813 comment-out H5 writing :-( 0f0e19aff test_highfive_dump() cb8f73795 trying to get highfive_dump() unittest working w/Windows-WAF 6584a264a does test_highfive_create() work? cde6147ce tweak HighFive wrappers (#659) 316566854 Revert "trying HighFive "write" unittests again" a9ec24ca4 trying HighFive "write" unittests again 585ad49a5 tweak names of utility routines 4c91a4d97 make it easier to read a std::vector and std::vecotr 0217ffa26 readDataSet() now works for 1D data 95e8973f2 trying to get hdf5::lite::load() working 4d294611d "const" correctness 5e6305c3f fix load_complex() 4a134dc5f start work on utility routines to read complex data from HDF5 9d76a7f41 Merge branch 'main' into feature/hdf5 8f9667a24 whitepsace ebd3fc99e Merge branch 'main' into feature/hdf5 40091b069 comment-out writing tests for now ... need to figure our WAF bulid failure 935aa3459 be sure the dataset has real data 114b9bf33 update release notes bd9c0b26c tweak HighFive utility routines acda1ef57 turn off diagnostics around expected failures 22a748840 readDataSet() utility routine for HighFive bd88a8c25 HighFive writeDataSet() utility to work with our SpanRC 6142f5b33 use HighFive routines to write a HDF5 file 5bbf1abaf Use HiveFive routines to get info about the file 84fbc8378 duplicate unittests with H5Easy f1f054c03 Merge branch 'main' into feature/hdf5 9b63ca470 fix directory names f6f826689 fix directory names 7aeb82c33 Merge branch 'main' into feature/hdf5 d028baaeb hook up HighFive header-only library (#653) 3083b0a31 Revert "HighFive 2.6.2" 246985a7f Revert ""build" HighFive HDF5 library" a8b75a586 Revert "turn off HighFive Boost support" ec68d5f83 Revert "Add HighFive unittests" f1f85b9e7 Revert "get test_high_five_base more-or-less compiling" 5ea634ee1 Revert "more work on getting HighFive unittests to build" ecc45433c more work on getting HighFive unittests to build bb194788a get test_high_five_base more-or-less compiling d42bde000 Add HighFive unittests ddc86bb32 turn off HighFive Boost support b255122d4 "build" HighFive HDF5 library 396cc3ef2 HighFive 2.6.2 5e5f9d9c0 Merge branch 'main' into feature/hdf5 ee938b4a5 changes from SIX bb764df90 Merge branch 'main' into feature/xml.lite_tweaks de2a24380 make derived classes 'final' if possible 14e19bcd2 Change xml lite function to virtual (#645) 8f42ac8e9 Merge branch 'main' into feature/xml.lite_tweaks 18ad90645 hdf5Write unittest 3462e1179 createFile() and writeFile() overloads ecee81d53 fix typos 197eecfa6 sketch-out hdf5::lite::writeFile() bd2311795 use SpanRC for writeFile(), not yet implemented ea9af7510 simple SpanRC to hold a 2D-size and pointer 027c19ee8 createFile() unittest 1f9d07ecb hook up createFile() 8c7e4473f start hooking up HDF5 writing 146e0bea3 Merge branch 'main' into feature/hdf5 88ca9fcb7 Merge branch 'main' into feature/hdf5 42b604b46 Squashed commit of the following: 10ee602c2 Merge branch 'main' into feature/hdf5 67aa42b69 restore changes from "main" 8bbfcbfbf unittests can be simplified to match fewer "view" classes 126bb802e Merge branch 'main' into feature/hdf5 3f8ba7a42 again, don't need a class just to convert from std::vector<> to std::span<> 24c2b489c Squashed commit of the following: 2703c119d Squashed commit of the following: 9d5228a2b don't need an entire class just to convert a std::vector<> into std::span<> 51bc931dc Merge branch 'main' into feature/hdf5 a84f25816 Squashed commit of the following: c4d2ed696 add missing #include guards, fix type in existing #include guard d541525a0 use a single ComplexViewConstIterator for all views 86e6a459f CODA_OSS_disable_warning causes GCC errors :-( 5d4b9c2cb only need an custom iterator for ComplexSpansView d9f0fb128 hook up iterators b9329e4db initial pass at a ComplexViewConstIterator 635238873 remove compiler warning about unused "constexpr" variables b39f6096f use the casing from H5 to make copy/pasting code slightly easier 0887b13eb Merge branch 'main' into feature/hdf5 bd07df1ca Consistent casing for Dataset, Datatype, Dataspace 7acd30ee2 tweak hdf5.lite dependencies 38ab914df Jupyter notebook for creating H5 files 95a040e0b _small.h5 is now (correctly) FLOAT32 107e7c487 make a simple values() member function to avoid template magic e1feca919 use TEST_SPECIFIC_EXCEPTION macro instead of try/catch 738333688 readDatasetT() now throws for the wrong buffer type 6b2cc2529 Merge branch 'feature/hdf5' of github.com:mdaus/coda-oss into feature/hdf5 310f8fd3d can't get template magic right for copy_axis() 86b306d59 stepping through copy ctors in the debugger is annoying f243e92d6 trying to make wrong type of buffer fail 2b10d9652 read in new sample file a28e59d8c help the compiler with type deduction 49bf5e9bc nested_complex_float_data_small.h5 e029325fc utility routines to "deconstruct" and array of std::complex dede3bd39 Merge branch 'main' into feature/hdf5 904b1ef5e tweak class names, make_() and copy() utility routines 8237b9efb make it harder to pass the wrong types to ComplexViews 4d9aeda2c ComplexArrayView and ComplexParallelView utility classes f5e367dfa test std::span> a4a2844f2 read in the nested "i" and "r" data 115615265 sample file has subgroups 8e1b7869a Merge branch 'feature/hdf5' of github.com:mdaus/coda-oss into feature/hdf5 9f4232a1d update sample H5 file 8c55db73a walk through HDF5 sub-groups 7775ed9c4 Update 123_barfoo_catdog_cx.h5 677975d7c Matlab code to create sample H5 file a0e7dfe07 Update test_hdf5info.cpp 0b67e1602 pass __FILE__ and __LINE__ from calling site for a more accurate exception message 86a677321 skeleton for more sample data 85f79b099 Merge branch 'main' into feature/hdf5 18088e942 Merge branch 'main' into feature/hdf5 3a1d17692 Merge branch 'main' into feature/hdf5 1755c69d7 Merge branch 'main' into feature/hdf5 9ad015432 No more "11" suffix on exception names c20d96251 Squashed commit of the following: c88cee999 other values to be filled-in bca4a4ecd incorporation NamedObject from HDF5 docs 61fa68f72 groupInfo() 460e7d766 datasetInfo() 14eb9b764 start filling in DatasetInfo afe5f1c3a start to fill in DatasetInfo 77a968c72 start filling in GroupInfo d81bcdfd9 openGroup() to open groups (loc) a0cd29469 comment-out "dataset" unittest for now 86e006024 begin filling in FileInfo 366dda6ab a return_type_of utility is needed to deduce the return type e21928263 explicitly pass return type to template 4937ccd11 template to reduce boilerplate when calling try_catch_H5Exceptions b3b5ebde7 use new exception utility routines ea1c03ef0 put exception handling/conversion in a utility routine 819a99d39 utility routine for exception handling 6f34eea97 put utilities in a separate file for easier reuse fcbde4f24 break utility routines into smaller pieces for easier reuse 52358ea8a WIN32 no longer automatically defined? 5a4286472 Revert "build HDF5 with C89" 680e599e9 build HDF5 with C89 a87a07121 Merge branch 'main' into feature/hdf5 8447c1a90 Revert "sym-links instead of copying files" db3b5e12b Merge branch 'main' into feature/xml.lite_tweaks fb60b5696 Merge branch 'main' into feature/hdf5 5110a5cc8 Comments about _u and _q 1a937d32c Merge branch 'main' into feature/xml.lite_tweaks fa06f04d7 get ready for hdf5.lite enhancdements b040c7c43 sym-links instead of copying files aa431bb47 use _u for xml::lite::Uri 3d0c6d58c fix case-sensitive #include filename 93dcd0e52 operator() for getElementByName() 75a93af85 more operator[] overloads to make attribute management easier 4ab8216f8 user-defined string literals to remove some noise around xml::lite::QName f82f0b0fc Merge branch 'main' into feature/xml.lite_tweaks ae30e3644 Merge branch 'feature/xml.lite_tweaks' of github.com:mdaus/coda-oss into feature/xml.lite_tweaks ffdd9beb0 simplify attribute creation 9bf5414f5 simplify attribute creation 82d7a4e95 SWIG gets confused about namespaces 7a61d0741 fix bug on Element ctor uncovered by unittest fdd7e58c1 QName is also in the xerces namespace which confuses SWIG bindings a325b7053 operator+=() overload for addChild daf30e6c0 Merge branch 'feature/xml.lite_tweaks' of github.com:mdaus/coda-oss into feature/xml.lite_tweaks b887d2b47 provide overloads for Element& rather than creating new "reference" types 1fa6bba38 rename test_xmleasy.cpp 7c8c9e0f1 += overload 850da6f63 overload for std::string 4547fc5a7 use UIT-8 strings for characterData 4723462a3 convenient addChild() overloads e48720753 copy over ElementReference from xml.easy a4ca30a0d Merge branch 'main' into feature/xml.lite_tweaks 6ae9f0b71 Revert "check-in of new xml.easy (to move code between computers)" f7466a6d7 Revert "simple routines for single element" a5490230d Revert "make some operators simplier ways of calling functions" c9a25630a Revert "get document creation working" 8af8710b0 Revert "free functions instead of member functions" 16c3847cb Revert "ElementReference distinct from Element" 7d68e156f Revert "ElementMutableReference" 00eb2a282 Merge branch 'main' into feature/xml.lite_tweaks a42969c1f ElementMutableReference a20ae9355 ElementReference distinct from Element 14eeeea0b free functions instead of member functions 4aae014b3 get document creation working 883569269 make some operators simplier ways of calling functions 053bd1212 simple routines for single element 8bf701a2e check-in of new xml.easy (to move code between computers) 41f959051 unittests for creating XML documents from scratch 9752d50ae Merge branch 'main' into feature/xml.lite_tweaks 1531d5709 by default, don't validate strings passed to Uri() 46d13d4bf Merge branch 'master' into feature/xml.lite_tweaks 39b547d32 remove more vestiges of Expat and LibXML ec8274d52 remove LibXML and Expat as they're no longer used/supported. 20eeefeef Merge branch 'master' into feature/xml.lite_tweaks 95074b9b1 update for newer Intel compiler 7024f71e1 Merge branch 'master' into feature/xml.lite_tweaks 57b1cbc83 Merge branch 'master' into feature/xml.lite_tweaks 4b67561c3 remove validate() overload that nobody is using fa15f1e5d Squashed commit of the following: 1484a9090 test the new validate() API 470da70fb hookup StringStreamT routines 2cddf2504 begin hooking up validate() overloads 1b5d910f3 overload validate() for UTF-8 and Windows-1252 03309b8c9 Squashed commit of the following: b72c6c5bf older compiler doesn't like our make_unique af8f00307 validate UTF-8 XML on Linux 211188613 unit-test for LEGACY XML validation 3c1169d2b Squashed commit of the following: 3afff19ca std::filesystem::path for FileInputStreamOS 908d452f8 WIP: validate all of our sample XML files 00f9bb16b validate against a XML schema 243d8c356 Merge branch 'master' into feature/xml.lite_tweaks 2815d707d fix to work with SWIG bindings. :-( 460862132 trying (again) to remove vestiages of old code e3c83a858 Revert "new code should use UTF-8" 811207c92 new code should use UTF-8 0ffd835f9 Squashed commit of the following: 1e7e03ded Merge branch 'master' into feature/xml.lite_tweaks c1d806aff Merge branch 'master' into feature/xml.lite_tweaks 850d3c811 str::strip() that can be easier to use than str::trim() 580ba9c8c explicitly =delete move 2b39831a8 Squashed commit of the following: 39eebdc23 Merge branch 'master' into feature/xml.lite_tweaks 9adf86cba force calling new UTF-8 write() routines ea61b6204 Merge branch 'master' into feature/xml.lite_tweaks 8a34583fa overload to take schemaPaths as filesystem::path 8671b442f parse XML embedded in a binary file ec4a902f1 updates from xerces.lite 80dc4d963 updates from xerces.lite 549766d6c Attributes::contains() no longer catches an exception 8a645ceac need "sys/" when building in other environments 36af08269 super-simple URI validation 78ef28a3e SWIG bindings are a PITA! :-( e9cba8491 SWIG needs help with Uri 8a8d8dc07 another routines used by pre-build SWIG bindings 818e1ec5d pre-build SWIG bindings use getElementByTagName() member function 067cac5d8 old compiler gets confused on unadorned QName ba92c0ae7 more use of Uri and QName 446c7d17a use QName in new code d6f8b0c83 more direct use of QName 90fff1c73 use xml::lite::QName instead of tuple 646cbb5ed more direct use of QName and Uri ba589ea3b make QName more robust bab0ee8b5 createElement() -> addNewElement() e3a145747 grab changes from six-library 32285e95c Merge branch 'master' into feature/xml.lite_tweaks 9f79f0bf6 Merge branch 'master' into feature/xml.lite_tweaks a12bbc32c make it easier to create new Elements with a value fc9967f98 make it easy for callers to addChild() keep a reference to the Element 4627766b7 be sure test_xmlparser works in "externals" of other projects bf2276396 "private" is part of the name-mangling fad92bcc8 making sure copy-ctor is implemented f90fdcead consolidate common XML test code 9fc53f2d5 use str:: utility for casting 6da6f794b still trying to find the right macro for SWIG 0c1b86c56 still trying to fix SWIG fdc6fc9bd trying to fix SWIG build error 7835e8c27 SWIG needs copy-ctor 585695942 disable copy/assignment for Element, it's probably almost always wrong 391fed613 fix double-delete caused by copying 61790fe69 retry parsing XML with Windows-1252 if first parse() fails 63cffac59 change string_encoding to match coda-oss style of PascalCase 010479bbe read an XML file we know is wrongly encoded as Windows-1252 9a0505062 more references instead of pointers 2d44b6951 Reading Windows-1252 w/o "encoding" fails 63dc7b076 read Windows-1252 too c9434c9cb test as UIT-8 too f310ccf0c get reading from UTF-8 XML working on Windows 1fa39c2be get testReadUtf8XmlFile working on Linux 1a83cd815 sys::Path is too much trouble right now ed60aa22c unit-test to read XML from a file a9336db7c Squashed commit of the following: 0825beb0d Merge branch 'master' into feature/xml.lite_tweaks c618489be Merge branch 'master' into feature/xml.lite_tweaks e8e4b8fe1 determine string_encoding based on platform 1f43bcfc2 create a new Element by using the platform to determine "characterData" encoding 961bef66b Merge branch 'master' into feature/xml.lite_tweaks e9798a5cb fix static_assert() 6f7772874 Merge branch 'master' into feature/xml.lite_tweaks b98d4f5a9 Merge branch 'master' into feature/xml.lite_tweaks 1b5abba2a The (old) version of SWIG we're using doesn't like certain C++11 features. 53bdeabaf Merge branch 'master' into feature/xml.lite_tweaks 60cf8ae80 "" doesn't work with decltype() in older C++ 97e72477a reduce getValue() overloads by making "key" a template argument 5e6373e55 reduce code duplication f9e7cfeee provide castValue instead of getValue(T&) cbd0bd8f2 castValue throws instead of returning a bool like getValue(T&) 87c7514fc Merge branch 'master' into feature/xml.lite_tweaks 10cc61223 make getElement*() consistent for zero or >1 results f5b137e3c Merge branch 'master' into feature/xml.lite_tweaks 1765efc62 allow clients to specify toType() and toString() for getValue() and setValue() df8b746e1 allow clients to specify their own toType/toString routines 66702726a Merge branch 'master' into feature/xml.lite_tweaks 6956311f1 Merge branch 'master' into feature/xml.lite_tweaks d505f3593 Merge branch 'master' into feature/xml.lite_tweaks fbd106115 catch a BadCastException and return false from getValue() 3a78377b5 use a template to reduce duplicated code 0ad4b8606 Merge branch 'master' into feature/xml.lite_tweaks a848aa3a2 get & set the characer data as a type f3ee1ee12 utility routines to set an attribute value 595227683 templates to get an attribute value convert to a specific type 06639227b miised a change in last commit 1aa458ef8 add getValue() overloads that return true/false rather than throwing faa6d3075 added getElementByTagName() overloads as that's a very common use-case git-subtree-dir: externals/coda-oss git-subtree-split: 065e86ddcbd20a353efe5e0231503dd01c8343a8 * latest from CODA-OSS * Squashed 'externals/nitro/' changes from c8ecbe9ae..5724d8c18 5724d8c18 latest from CODA-OSS (#570) fb794f0fe latest from CODA-OSS (#569) 7a6132ba0 update files changes in cpp17 branch (#568) de91d4977 Fix bug creating NITFException (#567) 225273436 fix YAML for 'main' 5d1c83d11 single project for unittests (#566) 102a019db latest from CODA-OSS (known broken build) (#565) b4ae2d429 match YAML from coda-oss 176bcaf6d build NITRO.SLN using msbuild (#562) 85e9043b8 latest from CODA-OSS (#561) 49ec50325 use new "PlatformToolkit" special environment variable (#560) 6c06e3711 latest from CODA-OSS (#559) cee9feb42 latest from CODA-OSS (#558) 3f01809fa latest from coda-oss (#557) 471fb3fc1 Update test_j2k_loading++.cpp b12caf2fc latest from CODA-OSS (#556) 0cd432624 use sys::make_span (#555) 05dae18a3 patch to build other projects 8f974e995 NITRO-2.11.3 (#554) 870aa6afd update to coda-oss 2023-06-05 (#553) 2fd7a0bfa latest from coda-oss (#552) 0eecce004 invoke() utility to reduce code duplication (#550) 59fb02fe9 latest from coda-oss (#551) 9fbf2b7b8 Fill out adapter free block which is used for nitf decompression (#549) 089ba0b5b latest from coda-oss 3b52f0025 latest from coda-oss (#547) 90c6263e2 latest from coda-oss (#544) 90d513ac5 latest from coda-oss (#543) git-subtree-dir: externals/nitro git-subtree-split: 5724d8c185ec42159a0f68914f38cb161c2a8df8 * latest from CODA-OSS * build with C++17 * make sure we'll always be able to uniquely identify versions * remove more macros * `Unmodeled` -> `unmodeled` * utility routines to reduce copy/paste errors * switch CorrCoefZero and DecorrRate to use XsElement * switch unmodeled to new XsElement_minOccurs0 * Missed a Unmoded -> unmodeled somehow ... * v200 -> v2_0_0 * simplify Unmodeled processing: reduce use of get() * use XsElement for the remaining new SIDD 3.0 XML * make newFromElement() a template. * add missing test_valid_sixsicd unittest * with FmtX() overloads, the use of .c_str() can be reduced. * remove unimplemented getPVPdata() overload * replace std::unique_ptr with std::vector so clients can get size of allocated buffer * use std::span<> for better type-safety * more use of std::span to help ensure we don't walk off the end of arrays * prototypes for unused? SWIG bindings * Squashed commit of the following: commit a35af9ea382f8699afd3570da25df09063c0d0f5 Author: Dan Smith Date: Wed Sep 6 09:00:51 2023 -0400 std::complex -> six::zfloat commit b1bc7e9e75689ed65a6131b89275045b6a350e4c Author: Dan Smith Date: Tue Sep 5 17:11:58 2023 -0400 separate nearest_neighbors() member function not needed commit ec071035c34c48d4e3df8c23eec72bc11b936475 Author: Dan Smith Date: Tue Sep 5 16:16:49 2023 -0400 getPhase() utility routine commit b0fcad4fab0f89597cec1988e0456957af4c1b20 Author: Dan Smith Date: Tue Sep 5 15:13:36 2023 -0400 cx_float -> zfloat commit 74be8b86f4d28b2a8a0f227ba090668d838354d7 Author: Dan Smith Date: Tue Sep 5 12:19:25 2023 -0400 use fromComplex overload returning a std::vector commit 6d903d480b7f3b411e1e26e819f52aecca609d1a Author: Dan Smith Date: Tue Sep 5 11:28:22 2023 -0400 more use of AMP8I_PHS8I_t rather than std::pair commit d38f8224bb6cdd33a3bc2454bee9a2582791c31d Author: Dan Smith Date: Tue Sep 5 11:15:38 2023 -0400 use std::as_bytes() commit afba730077b43143afd0994516c7171194f72ee5 Author: Dan Smith Date: Fri Sep 1 12:23:17 2023 -0400 remove unused overloads commit 519b95d36a5ae91540c64f73e77cab783cb887dd Author: Dan Smith Date: Fri Sep 1 11:35:00 2023 -0400 use overload which returns a std::vector<> commit e78d7ce35d680357ba6a02e9bad62a0e5ba0d78f Author: Dan Smith Date: Fri Sep 1 11:20:21 2023 -0400 overload to return the converted data in a std::vector commit 234a646d7ee75d87443c37d6d7ecb60715d44fbf Merge: 6cb4e1744 7cf8d232e Author: Dan Smith Date: Fri Sep 1 11:00:31 2023 -0400 Merge branch 'main' into feature/8AMPI_PHSI commit 6cb4e1744a445d7ca826eda302b1bfadbcba39f2 Author: Dan Smith Date: Fri Jul 7 12:41:53 2023 -0400 it seems is broken with GCC 9.x ? commit be3113cbdb5b0292e0a4d8272757836a36c71dcf Merge: 7f0fe99b5 ef861bc68 Author: Dan Smith Date: Fri Jul 7 12:29:43 2023 -0400 Merge branch 'main' into feature/8AMPI_PHSI commit 7f0fe99b567217e67c3ba420e16134d5c7ee82fc Author: Dan Smith Date: Mon Jun 19 15:10:30 2023 -0400 w/C++17 commit ecd2525641467342acc3bf674a2ec51b38504c1a Merge: 9cf7ae672 12c50d2d2 Author: Dan Smith Date: Mon Jun 19 15:02:48 2023 -0400 Merge branch 'main' into feature/8AMPI_PHSI commit 9cf7ae672bcc2000a7a8c13848ba7ca1da756f53 Author: Dan Smith Date: Mon Jun 19 14:54:24 2023 -0400 `long double` doesn't change results from `float` but prevents AVX/SSE commit 28f95a0f99ff0d26641d036700a61533461a356a Author: Dan Smith Date: Mon Jun 19 14:44:45 2023 -0400 std::numbers::pi instead of M_PI commit 1a28600214aba4af20361698d34f8278fd3a3490 Author: Dan Smith Date: Mon Jun 19 14:33:51 2023 -0400 Squashed commit of the following: commit c747f326b60ba8a82b3c33e91aabe2651d6bb13d Author: Dan Smith Date: Mon Jun 19 14:30:50 2023 -0400 latest from CODA-OSS and NITRO commit b142ec4fcb2a8007e35e3d68e0ae752f4b2828d0 Merge: 2829f93c9 3d4e554aa Author: Dan Smith Date: Mon Jun 19 14:30:15 2023 -0400 sync_externals commit 3d4e554aa3934c7157bf9c2e57e2482662938b10 Author: Dan Smith Date: Mon Jun 19 14:30:07 2023 -0400 Squashed 'externals/nitro/' changes from 3f01809fa..cee9feb42 cee9feb42 latest from CODA-OSS (#558) git-subtree-dir: externals/nitro git-subtree-split: cee9feb424b0f9c1f11f37f67a1795b3cc5e8dd1 commit 2829f93c9de0e8787dbe6cb319d6f32143dcdd8e Merge: e47ccf30e 12995e63a Author: Dan Smith Date: Mon Jun 19 14:29:10 2023 -0400 Merge branch 'main' into develop/sync_externals commit e47ccf30e059e0cd32b42dc90a45f4b8a8512caf Author: Dan Smith Date: Mon Jun 19 14:19:10 2023 -0400 latest from CODA-OSS commit 04090c4a13b921f33257662950e46bfc2e58cabb Merge: cc6009422 ac1ccde84 Author: Dan Smith Date: Mon Jun 19 14:18:41 2023 -0400 sync_externals commit ac1ccde84b2be856ac947b2670dd8228c9980889 Author: Dan Smith Date: Mon Jun 19 14:18:34 2023 -0400 Squashed 'externals/nitro/' changes from c8ecbe9ae..3f01809fa 3f01809fa latest from coda-oss (#557) 471fb3fc1 Update test_j2k_loading++.cpp b12caf2fc latest from CODA-OSS (#556) 0cd432624 use sys::make_span (#555) 05dae18a3 patch to build other projects 8f974e995 NITRO-2.11.3 (#554) 870aa6afd update to coda-oss 2023-06-05 (#553) 2fd7a0bfa latest from coda-oss (#552) 0eecce004 invoke() utility to reduce code duplication (#550) 59fb02fe9 latest from coda-oss (#551) 9fbf2b7b8 Fill out adapter free block which is used for nitf decompression (#549) 089ba0b5b latest from coda-oss 3b52f0025 latest from coda-oss (#547) 90c6263e2 latest from coda-oss (#544) 90d513ac5 latest from coda-oss (#543) git-subtree-dir: externals/nitro git-subtree-split: 3f01809fae7d471aa0f1594fc5eec1e3111cd710 commit cc6009422ec41dd6e48ade90c37bdbfd97a1bc35 Merge: fec3755e0 1ceb8e3ff Author: Dan Smith Date: Mon Jun 19 14:18:30 2023 -0400 Merge commit '1ceb8e3ffb55a240085250cfde3f4d1ab7ef0b04' into develop/sync_externals commit 1ceb8e3ffb55a240085250cfde3f4d1ab7ef0b04 Author: Dan Smith Date: Mon Jun 19 14:18:30 2023 -0400 Squashed 'externals/coda-oss/' changes from e87c32b4d..54033e70e 54033e70e Merge branch 'main' into feature/complex_short 3c63f9f65 std::numbers from C++20 (#691) 892dd0e00 ComplexInteger and ComplexReal to better match existing naming conventions (#690) b3872181e match coda-oss naming conventions (#688) 704d6867f beef-up our complex type (#687) 47c1c1cd6 check is_absolute() for URLs (#686) c042373e1 be sure our Path::isAbolute() matches std::filesystem::path::absolute() (#684) ad10286bc volatile is about "special" memory, not threading (#685) f4d42005f fix build error in NITRO ff11a5557 keep using std::complex for now (#682) c88b9c053 types::complex (#681) d1244a080 don't need our own make_unique in C++14 (#680) aeec0131c assert()s for mem::CopyablePtr (#679) 72b0ebd60 add types::complex_short (#678) 932130a58 patch to build other projects c00c1f203 coda-oss release 2023-06-06 (#677) ef54bbcd5 remove more compiler warnings (#676) dadfc5ce6 distinguish between byte-swapping a buffer and single value (#674) 90187f6cd more xml.lite tweaks for SIDD-3.0/ISM (#675) eb9960772 stronger type-checking for byteSwap() (#673) ff4f820ed xml.lite tweaks to support SIDD 3.0 ISM (#672) b1de8c0e5 std::byte should be a unique type (#671) c05bf9a02 allow enums to be byte-swapped too 1f9fd88d6 remove spurious 47684c45b byteSwap now uses byte buffers (#670) cbc659db2 add swapBytes() utility from SIX (#669) 891481b64 simplify byte-swapping (#668) 540ae763e more byteSwap() tweaks 0774c03c4 threaded byteSwap() (#667) d156370d3 swapping a single-byte value makes no sense c120e3255 be sure parameter is used to avoid compiler warning e85ec9331 --output-on-failure for CTest (#666) e80376197 turn off "there is no warning number" warning c5f0a5d15 A C-string may not be NULL-terminated (#665) 0c5eb29ae use platform-specific routines for byteSwap() (#664) 0b7d581fa remove transform_async() (#663) f6489b6be Merge branch 'main' into feature/xml.lite_tweaks 836c426a2 use function-pointers so that isConsoleOutput is only checked once 56e3c45b1 move depthPrint() functionality into non-member function in preparation for future changes ddcd26d97 Merge branch 'main' into feature/xml.lite_tweaks 69cc0e506 use the more rigorous create_and_check_datatype() 9efb87558 Merge branch 'main' into feature/hdf5 4d2f2f417 more HighFive unittests (#662) 14191a844 HighFive::create_datatype() goes from C++ to HighFive 98583473f utility routines to read string attributes 1fa75ce81 use the C API to read a string attribute 71e7b69f5 still can't figure out how to read a string attribute :-( e96f37a69 test reading the file attributes a25244519 getAttribute() unittest 8f12a3000 getDataType() unittest 857ff0af3 HighFive utility routines (#661) 1d687db57 writeDataSet() utility overload 106aa6894 sigh ... H5Easy::dump() fill fails on Windows/WAF :-( 2641b60b2 Merge branch 'main' into feature/hdf5 35c19e7e8 change actions to @v3 (#660) 212bbd3a3 works on local machine, but not build server ... ? 7125118b0 dump of 1D vector doesn't work :-( c704db435 sigh ... WAF build still failing :-( 01aae4616 does dump() of a 1D vector work? 76a53c813 comment-out H5 writing :-( 0f0e19aff test_highfive_dump() cb8f73795 trying to get highfive_dump() unittest working w/Windows-WAF 6584a264a does test_highfive_create() work? cde6147ce tweak HighFive wrappers (#659) 316566854 Revert "trying HighFive "write" unittests again" a9ec24ca4 trying HighFive "write" unittests again 585ad49a5 tweak names of utility routines 4c91a4d97 make it easier to read a std::vector and std::vecotr 0217ffa26 readDataSet() now works for 1D data 95e8973f2 trying to get hdf5::lite::load() working 4d294611d "const" correctness 5e6305c3f fix load_complex() 4a134dc5f start work on utility routines to read complex data from HDF5 9d76a7f41 Merge branch 'main' into feature/hdf5 8f9667a24 whitepsace ebd3fc99e Merge branch 'main' into feature/hdf5 40091b069 comment-out writing tests for now ... need to figure our WAF bulid failure 935aa3459 be sure the dataset has real data 114b9bf33 update release notes bd9c0b26c tweak HighFive utility routines acda1ef57 turn off diagnostics around expected failures 22a748840 readDataSet() utility routine for HighFive bd88a8c25 HighFive writeDataSet() utility to work with our SpanRC 6142f5b33 use HighFive routines to write a HDF5 file 5bbf1abaf Use HiveFive routines to get info about the file 84fbc8378 duplicate unittests with H5Easy f1f054c03 Merge branch 'main' into feature/hdf5 9b63ca470 fix directory names f6f826689 fix directory names 7aeb82c33 Merge branch 'main' into feature/hdf5 d028baaeb hook up HighFive header-only library (#653) 3083b0a31 Revert "HighFive 2.6.2" 246985a7f Revert ""build" HighFive HDF5 library" a8b75a586 Revert "turn off HighFive Boost support" ec68d5f83 Revert "Add HighFive unittests" f1f85b9e7 Revert "get test_high_five_base more-or-less compiling" 5ea634ee1 Revert "more work on getting HighFive unittests to build" ecc45433c more work on getting HighFive unittests to build bb194788a get test_high_five_base more-or-less compiling d42bde000 Add HighFive unittests ddc86bb32 turn off HighFive Boost support b255122d4 "build" HighFive HDF5 library 396cc3ef2 HighFive 2.6.2 5e5f9d9c0 Merge branch 'main' into feature/hdf5 ee938b4a5 changes from SIX bb764df90 Merge branch 'main' into feature/xml.lite_tweaks de2a24380 make derived classes 'final' if possible 14e19bcd2 Change xml lite function to virtual (#645) 8f42ac8e9 Merge branch 'main' into feature/xml.lite_tweaks 18ad90645 hdf5Write unittest 3462e1179 createFile() and writeFile() overloads ecee81d53 fix typos 197eecfa6 sketch-out hdf5::lite::writeFile() bd2311795 use SpanRC for writeFile(), not yet implemented ea9af7510 simple SpanRC to hold a 2D-size and pointer 027c19ee8 createFile() unittest 1f9d07ecb hook up createFile() 8c7e4473f start hooking up HDF5 writing 146e0bea3 Merge branch 'main' into feature/hdf5 88ca9fcb7 Merge branch 'main' into feature/hdf5 42b604b46 Squashed commit of the following: 10ee602c2 Merge branch 'main' into feature/hdf5 67aa42b69 restore changes from "main" 8bbfcbfbf unittests can be simplified to match fewer "view" classes 126bb802e Merge branch 'main' into feature/hdf5 3f8ba7a42 again, don't need a class just to convert from std::vector<> to std::span<> 24c2b489c Squashed commit of the following: 2703c119d Squashed commit of the following: 9d5228a2b don't need an entire class just to convert a std::vector<> into std::span<> 51bc931dc Merge branch 'main' into feature/hdf5 a84f25816 Squashed commit of the following: c4d2ed696 add missing #include guards, fix type in existing #include guard d541525a0 use a single ComplexViewConstIterator for all views 86e6a459f CODA_OSS_disable_warning causes GCC errors :-( 5d4b9c2cb only need an custom iterator for ComplexSpansView d9f0fb128 hook up iterators b9329e4db initial pass at a ComplexViewConstIterator 635238873 remove compiler warning about unused "constexpr" variables b39f6096f use the casing from H5 to make copy/pasting code slightly easier 0887b13eb Merge branch 'main' into feature/hdf5 bd07df1ca Consistent casing for Dataset, Datatype, Dataspace 7acd30ee2 tweak hdf5.lite dependencies 38ab914df Jupyter notebook for creating H5 files 95a040e0b _small.h5 is now (correctly) FLOAT32 107e7c487 make a simple values() member function to avoid template magic e1feca919 use TEST_SPECIFIC_EXCEPTION macro instead of try/catch 738333688 readDatasetT() now throws for the wrong buffer type 6b2cc2529 Merge branch 'feature/hdf5' of github.com:mdaus/coda-oss into feature/hdf5 310f8fd3d can't get template magic right for copy_axis() 86b306d59 stepping through copy ctors in the debugger is annoying f243e92d6 trying to make wrong type of buffer fail 2b10d9652 read in new sample file a28e59d8c help the compiler with type deduction 49bf5e9bc nested_complex_float_data_small.h5 e029325fc utility routines to "deconstruct" and array of std::complex dede3bd39 Merge branch 'main' into feature/hdf5 904b1ef5e tweak class names, make_() and copy() utility routines 8237b9efb make it harder to pass the wrong types to ComplexViews 4d9aeda2c ComplexArrayView and ComplexParallelView utility classes f5e367dfa test std::span> a4a2844f2 read in the nested "i" and "r" data 115615265 sample file has subgroups 8e1b7869a Merge branch 'feature/hdf5' of github.com:mdaus/coda-oss into feature/hdf5 9f4232a1d update sample H5 file 8c55db73a walk through HDF5 sub-groups 7775ed9c4 Update 123_barfoo_catdog_cx.h5 677975d7c Matlab code to create sample H5 file a0e7dfe07 Update test_hdf5info.cpp 0b67e1602 pass __FILE__ and __LINE__ from calling site for a more accurate exception message 86a677321 skeleton for more sample data 85f79b099 Merge branch 'main' into feature/hdf5 18088e942 Merge branch 'main' into feature/hdf5 3a1d17692 Merge branch 'main' into feature/hdf5 1755c69d7 Merge branch 'main' into feature/hdf5 9ad015432 No more "11" suffix on exception names c20d96251 Squashed commit of the following: c88cee999 other values to be filled-in bca4a4ecd incorporation NamedObject from HDF5 docs 61fa68f72 groupInfo() 460e7d766 datasetInfo() 14eb9b764 start filling in DatasetInfo afe5f1c3a start to fill in DatasetInfo 77a968c72 start filling in GroupInfo d81bcdfd9 openGroup() to open groups (loc) a0cd29469 comment-out "dataset" unittest for now 86e006024 begin filling in FileInfo 366dda6ab a return_type_of utility is needed to deduce the return type e21928263 explicitly pass return type to template 4937ccd11 template to reduce boilerplate when calling try_catch_H5Exceptions b3b5ebde7 use new exception utility routines ea1c03ef0 put exception handling/conversion in a utility routine 819a99d39 utility routine for exception handling 6f34eea97 put utilities in a separate file for easier reuse fcbde4f24 break utility routines into smaller pieces for easier reuse 52358ea8a WIN32 no longer automatically defined? 5a4286472 Revert "build HDF5 with C89" 680e599e9 build HDF5 with C89 a87a07121 Merge branch 'main' into feature/hdf5 8447c1a90 Revert "sym-links instead of copying files" db3b5e12b Merge branch 'main' into feature/xml.lite_tweaks fb60b5696 Merge branch 'main' into feature/hdf5 5110a5cc8 Comments about _u and _q 1a937d32c Merge branch 'main' into feature/xml.lite_tweaks fa06f04d7 get ready for hdf5.lite enhancdements b040c7c43 sym-links instead of copying files aa431bb47 use _u for xml::lite::Uri 3d0c6d58c fix case-sensitive #include filename 93dcd0e52 operator() for getElementByName() 75a93af85 more operator[] overloads to make attribute management easier 4ab8216f8 user-defined string literals to remove some noise around xml::lite::QName f82f0b0fc Merge branch 'main' into feature/xml.lite_tweaks ae30e3644 Merge branch 'feature/xml.lite_tweaks' of github.com:mdaus/coda-oss into feature/xml.lite_tweaks ffdd9beb0 simplify attribute creation 9bf5414f5 simplify attribute creation 82d7a4e95 SWIG gets confused about namespaces 7a61d0741 fix bug on Element ctor uncovered by unittest fdd7e58c1 QName is also in the xerces namespace which confuses SWIG bindings a325b7053 operator+=() overload for addChild daf30e6c0 Merge branch 'feature/xml.lite_tweaks' of github.com:mdaus/coda-oss into feature/xml.lite_tweaks b887d2b47 provide overloads for Element& rather than creating new "reference" types 1fa6bba38 rename test_xmleasy.cpp 7c8c9e0f1 += overload 850da6f63 overload for std::string 4547fc5a7 use UIT-8 strings for characterData 4723462a3 convenient addChild() overloads e48720753 copy over ElementReference from xml.easy a4ca30a0d Merge branch 'main' into feature/xml.lite_tweaks 6ae9f0b71 Revert "check-in of new xml.easy (to move code between computers)" f7466a6d7 Revert "simple routines for single element" a5490230d Revert "make some operators simplier ways of calling functions" c9a25630a Revert "get document creation working" 8af8710b0 Revert "free functions instead of member functions" 16c3847cb Revert "ElementReference distinct from Element" 7d68e156f Revert "ElementMutableReference" 00eb2a282 Merge branch 'main' into feature/xml.lite_tweaks a42969c1f ElementMutableReference a20ae9355 ElementReference distinct from Element 14eeeea0b free functions instead of member functions 4aae014b3 get document creation working 883569269 make some operators simplier ways of calling functions 053bd1212 simple routines for single element 8bf701a2e check-in of new xml.easy (to move code between computers) 41f959051 unittests for creating XML documents from scratch 9752d50ae Merge branch 'main' into feature/xml.lite_tweaks 1531d5709 by default, don't validate strings passed to Uri() 46d13d4bf Merge branch 'master' into feature/xml.lite_tweaks 39b547d32 remove more vestiges of Expat and LibXML ec8274d52 remove LibXML and Expat as they're no longer used/supported. 20eeefeef Merge branch 'master' into feature/xml.lite_tweaks 95074b9b1 update for newer Intel compiler 7024f71e1 Merge branch 'master' into feature/xml.lite_tweaks 57b1cbc83 Merge branch 'master' into feature/xml.lite_tweaks 4b67561c3 remove validate() overload that nobody is using fa15f1e5d Squashed commit of the following: 1484a9090 test the new validate() API 470da70fb hookup StringStreamT routines 2cddf2504 begin hooking up validate() overloads 1b5d910f3 overload validate() for UTF-8 and Windows-1252 03309b8c9 Squashed commit of the following: b72c6c5bf older compiler doesn't like our make_unique af8f00307 validate UTF-8 XML on Linux 211188613 unit-test for LEGACY XML validation 3c1169d2b Squashed commit of the following: 3afff19ca std::filesystem::path for FileInputStreamOS 908d452f8 WIP: validate all of our sample XML files 00f9bb16b validate against a XML schema 243d8c356 Merge branch 'master' into feature/xml.lite_tweaks 2815d707d fix to work with SWIG bindings. :-( 460862132 trying (again) to remove vestiages of old code e3c83a858 Revert "new code should use UTF-8" 811207c92 new code should use UTF-8 0ffd835f9 Squashed commit of the following: 1e7e03ded Merge branch 'master' into feature/xml.lite_tweaks c1d806aff Merge branch 'master' into feature/xml.lite_tweaks 850d3c811 str::strip() that can be easier to use than str::trim() 580ba9c8c explicitly =delete move 2b39831a8 Squashed commit of the following: 39eebdc23 Merge branch 'master' into feature/xml.lite_tweaks 9adf86cba force calling new UTF-8 write() routines ea61b6204 Merge branch 'master' into feature/xml.lite_tweaks 8a34583fa overload to take schemaPaths as filesystem::path 8671b442f parse XML embedded in a binary file ec4a902f1 updates from xerces.lite 80dc4d963 updates from xerces.lite 549766d6c Attributes::contains() no longer catches an exception 8a645ceac need "sys/" when building in other environments 36af08269 super-simple URI validation 78ef28a3e SWIG bindings are a PITA! :-( e9cba8491 SWIG needs help with Uri 8a8d8dc07 another routines used by pre-build SWIG bindings 818e1ec5d pre-build SWIG bindings use getElementByTagName() member function 067cac5d8 old compiler gets confused on unadorned QName ba92c0ae7 more use of Uri and QName 446c7d17a use QName in new code d6f8b0c83 more direct use of QName 90fff1c73 use xml::lite::QName instead of tuple 646cbb5ed more direct use of QName and Uri ba589ea3b make QName more robust bab0ee8b5 createElement() -> addNewElement() e3a145747 grab changes from six-library 32285e95c Merge branch 'master' into feature/xml.lite_tweaks 9f79f0bf6 Merge branch 'master' into feature/xml.lite_tweaks a12bbc32c make it easier to create new Elements with a value fc9967f98 make it easy for callers to addChild() keep a reference to the Element 4627766b7 be sure test_xmlparser works in "externals" of other projects bf2276396 "private" is part of the name-mangling fad92bcc8 making sure copy-ctor is implemented f90fdcead consolidate common XML test code 9fc53f2d5 use str:: utility for casting 6da6f794b still trying to find the right macro for SWIG 0c1b86c56 still trying to fix SWIG fdc6fc9bd trying to fix SWIG build error 7835e8c27 SWIG needs copy-ctor 585695942 disable copy/assignment for Element, it's probably almost always wrong 391fed613 fix double-delete caused by copying 61790fe69 retry parsing XML with Windows-1252 if first parse() fails 63cffac59 change string_encoding to match coda-oss style of PascalCase 010479bbe read an XML file we know is wrongly encoded as Windows-1252 9a0505062 more references instead of pointers 2d44b6951 Reading Windows-1252 w/o "encoding" fails 63dc7b076 read Windows-1252 too c9434c9cb test as UIT-8 too f310ccf0c get reading from UTF-8 XML working on Windows 1fa39c2be get testReadUtf8XmlFile working on Linux 1a83cd815 sys::Path is too much trouble right now ed60aa22c unit-test to read XML from a file a9336db7c Squashed commit of the following: 0825beb0d Merge branch 'master' into feature/xml.lite_tweaks c618489be Merge branch 'master' into feature/xml.lite_tweaks e8e4b8fe1 determine string_encoding based on platform 1f43bcfc2 create a new Element by using the platform to determine "characterData" encoding 961bef66b Merge branch 'master' into feature/xml.lite_tweaks e9798a5cb fix static_assert() 6f7772874 Merge branch 'master' into feature/xml.lite_tweaks b98d4f5a9 Merge branch 'master' into feature/xml.lite_tweaks 1b5abba2a The (old) version of SWIG we're using doesn't like certain C++11 features. 53bdeabaf Merge branch 'master' into feature/xml.lite_tweaks 60cf8ae80 "" doesn't work with decltype() in older C++ 97e72477a reduce getValue() overloads by making "key" a template argument 5e6373e55 reduce code duplication f9e7cfeee provide castValue instead of getValue(T&) cbd0bd8f2 castValue throws instead of returning a bool like getValue(T&) 87c7514fc Merge branch 'master' into feature/xml.lite_tweaks 10cc61223 make getElement*() consistent for zero or >1 results f5b137e3c Merge branch 'master' into feature/xml.lite_tweaks 1765efc62 allow clients to specify toType() and toString() for getValue() and setValue() df8b746e1 allow clients to specify their own toType/toString routines 66702726a Merge branch 'master' into feature/xml.lite_tweaks 6956311f1 Merge branch 'master' into feature/xml.lite_tweaks d505f3593 Merge branch 'master' into feature/xml.lite_tweaks fbd106115 catch a BadCastException and return false from getValue() 3a78377b5 use a template to reduce duplicated code 0ad4b8606 Merge branch 'master' into feature/xml.lite_tweaks a848aa3a2 get & set the characer data as a type f3ee1ee12 utility routines to set an attribute value 595227683 templates to get an attribute value convert to a specific type 06639227b miised a change in last commit 1aa458ef8 add getValue() overloads that return true/false rather than throwing faa6d3075 added getElementByTagName() overloads as that's a very common use-case git-subtree-dir: externals/coda-oss git-subtree-split: 54033e70e353da94340dd7b96d0b1c6652308952 commit fec3755e04a8311103aef1ded477b17ce826b044 Author: Dan Smith Date: Mon Jun 19 14:18:05 2023 -0400 latest from CODA-OSS commit 367cccc1a7e5bda1176a91c36e10b7677099fb35 Merge: 563e0fd27 12995e63a Author: Dan Smith Date: Mon Jun 19 14:33:43 2023 -0400 Merge branch 'main' into feature/8AMPI_PHSI commit 563e0fd2770139742c9445b8aab0276c8565a81a Merge: 51b7a0df8 212b9de38 Author: Dan Smith Date: Mon Jun 19 14:10:47 2023 -0400 Merge branch 'main' into feature/8AMPI_PHSI commit 51b7a0df863bb6ee016dbfb5499e162374eef181 Author: Dan Smith Date: Mon Jun 19 09:23:31 2023 -0400 nearest_neighbors() so that the loop is closer to the actual code commit 1a99280479d3186ec17c5121950f56acd8eb1184 Author: Dan Smith Date: Fri Jun 16 13:26:10 2023 -0400 use parallel version of std::transform with C++17 commit a21804f38f53d5cda718041fa77c99b21efadbf5 Author: Dan Smith Date: Fri Jun 16 12:18:56 2023 -0400 Squashed commit of the following: commit 67d0bc78b1a93d02fc496ec755fc794060ab5bb5 Merge: 42f479813 a2cb168ce Author: Dan Smith Date: Fri Jun 16 10:37:57 2023 -0400 Merge branch 'develop/complex_short' of github.com:ngageoint/six-library into develop/complex_short commit 42f479813d7b2d431753028cab5ff5c4874bb62c Author: Dan Smith Date: Fri Jun 16 10:37:43 2023 -0400 Parameter::operator==() must a member function for existing SWIG bindings commit a2cb168cebbf0b89348d106be8a878fb6746f155 Author: Dan Smith Date: Fri Jun 16 10:32:22 2023 -0400 renames from CODA-OSS commit 68d184a89f899a709c6c7e54f858e4a8a4ed2955 Author: Dan Smith Date: Fri Jun 16 10:15:28 2023 -0400 figure out ComplexInteger in SIX rather than CODA-OSS commit 802087c892ecc653c0cd0086ec888d622c9192f8 Author: Dan Smith Date: Fri Jun 16 10:01:05 2023 -0400 separate .H file for complex commit 4d24ae394a290e21f074614ee95f46a182c43e33 Author: Dan Smith Date: Fri Jun 16 09:54:05 2023 -0400 remove unneeded #include of types/Complex.h commit e021d71c2d25641afbfe7d6741f60b2c745bd12d Author: Dan Smith Date: Fri Jun 16 09:49:48 2023 -0400 zinteger -> ComplexInteger commit 91599f83e4a8d1e3e8fe77d54bca4cb6f85ea692 Author: Dan Smith Date: Fri Jun 16 09:38:53 2023 -0400 complex.h -> Complex.h from CODA-OSS commit b3653cc75b07fb0415e2a18303058e57c31718b8 Merge: 786223e8c 6e34e8717 Author: Dan Smith Date: Thu Jun 15 16:11:31 2023 -0400 Merge branch 'main' into develop/complex_short commit 786223e8c0ebc05ca46e7c55eac8a26678ff2bff Author: Dan Smith Date: Thu Jun 15 16:04:31 2023 -0400 use CODA_OSS_types_unique_zinteger commit f143d3a53c4cdce580958fae0ef5588bb12cbda5 Author: Dan Smith Date: Thu Jun 15 15:54:40 2023 -0400 Squashed commit of the following: commit 011ba83af6202c4a5358c366ac0e88edcbfd6986 Merge: 7390b8b19 4a21b2db5 Author: Dan Smith Date: Thu Jun 15 15:37:33 2023 -0400 Merge branch 'main' into develop/sync_externals commit 7390b8b19f4f9d21d0ffc34ae9906cea2227936d Merge: 7f79e6d6f b902f6c17 Author: Dan Smith Date: Thu Jun 15 14:21:10 2023 -0400 Merge commit 'b902f6c1743778d8fceeee5b3209ebca2370312a' into develop/sync_externals commit b902f6c1743778d8fceeee5b3209ebca2370312a Author: Dan Smith Date: Thu Jun 15 14:21:10 2023 -0400 Squashed 'externals/coda-oss/' changes from f4d42005f..704d6867f 704d6867f beef-up our complex type (#687) 47c1c1cd6 check is_absolute() for URLs (#686) c042373e1 be sure our Path::isAbolute() matches std::filesystem::path::absolute() (#684) ad10286bc volatile is about "special" memory, not threading (#685) git-subtree-dir: externals/coda-oss git-subtree-split: 704d6867f959f60e3e62c44681a3fb1f7abc99bf commit 7f79e6d6fb8972e5074e582aa4c3214e9a524459 Author: Dan Smith Date: Thu Jun 15 14:21:06 2023 -0400 latest from CODA-OSS commit 24678b33f4aab533af0d807d6706f8587bd1c103 Merge: 9eb95e3aa 35b59b9a0 Author: Dan Smith Date: Thu Jun 15 14:20:30 2023 -0400 Merge branch 'main' into develop/sync_externals commit 9eb95e3aad1562b0d7915cf48db1b61a337a3878 Author: Dan Smith Date: Tue Jun 13 17:51:55 2023 -0400 latest from CODA-OSS and NITRO commit 1bd99042ef18b76df9da27d946b5616d9dd254b1 Merge: ec161c5b3 c59d69c06 Author: Dan Smith Date: Tue Jun 13 17:51:40 2023 -0400 sync_externals commit c59d69c06eda40c7295ab607fdc8a5dad7d2c1b1 Author: Dan Smith Date: Tue Jun 13 17:51:34 2023 -0400 Squashed 'externals/nitro/' changes from c8ecbe9ae..3f01809fa 3f01809fa latest from coda-oss (#557) 471fb3fc1 Update test_j2k_loading++.cpp b12caf2fc latest from CODA-OSS (#556) 0cd432624 use sys::make_span (#555) 05dae18a3 patch to build other projects 8f974e995 NITRO-2.11.3 (#554) 870aa6afd update to coda-oss 2023-06-05 (#553) 2fd7a0bfa latest from coda-oss (#552) 0eecce004 invoke() utility to reduce code duplication (#550) 59fb02fe9 latest from coda-oss (#551) 9fbf2b7b8 Fill out adapter free block which is used for nitf decompression (#549) 089ba0b5b latest from coda-oss 3b52f0025 latest from coda-oss (#547) 90c6263e2 latest from coda-oss (#544) 90d513ac5 latest from coda-oss (#543) git-subtree-dir: externals/nitro git-subtree-split: 3f01809fae7d471aa0f1594fc5eec1e3111cd710 commit 272cae451cbe3ad6820d1221aafe375d77b1ba04 Author: Dan Smith Date: Tue Jun 13 17:51:29 2023 -0400 Squashed 'externals/coda-oss/' changes from e87c32b4d..f4d42005f f4d42005f fix build error in NITRO ff11a5557 keep using std::complex for now (#682) c88b9c053 types::complex (#681) d1244a080 don't need our own make_unique in C++14 (#680) aeec0131c assert()s for mem::CopyablePtr (#679) 72b0ebd60 add types::complex_short (#678) 932130a58 patch to build other projects c00c1f203 coda-oss release 2023-06-06 (#677) ef54bbcd5 remove more compiler warnings (#676) dadfc5ce6 distinguish between byte-swapping a buffer and single value (#674) 90187f6cd more xml.lite tweaks for SIDD-3.0/ISM (#675) eb9960772 stronger type-checking for byteSwap() (#673) ff4f820ed xml.lite tweaks to support SIDD 3.0 ISM (#672) b1de8c0e5 std::byte should be a unique type (#671) c05bf9a02 allow enums to be byte-swapped too 1f9fd88d6 remove spurious 47684c45b byteSwap now uses byte buffers (#670) cbc659db2 add swapBytes() utility from SIX (#669) 891481b64 simplify byte-swapping (#668) 540ae763e more byteSwap() tweaks 0774c03c4 threaded byteSwap() (#667) d156370d3 swapping a single-byte value makes no sense c120e3255 be sure parameter is used to avoid compiler warning e85ec9331 --output-on-failure for CTest (#666) e80376197 turn off "there is no warning number" warning c5f0a5d15 A C-string may not be NULL-terminated (#665) 0c5eb29ae use platform-specific routines for byteSwap() (#664) 0b7d581fa remove transform_async() (#663) f6489b6be Merge branch 'main' into feature/xml.lite_tweaks 836c426a2 use function-pointers so that isConsoleOutput is only checked once 56e3c45b1 move depthPrint() functionality into non-member function in preparation for future changes ddcd26d97 Merge branch 'main' into feature/xml.lite_tweaks 69cc0e506 use the more rigorous create_and_check_datatype() 9efb87558 Merge branch 'main' into feature/hdf5 4d2f2f417 more HighFive unittests (#662) 14191a844 HighFive::create_datatype() goes from C++ to HighFive 98583473f utility routines to read string attributes 1fa75ce81 use the C API to read a string attribute 71e7b69f5 still can't figure out how to read a string attribute :-( e96f37a69 test reading the file attributes a25244519 getAttribute() unittest 8f12a3000 getDataType() unittest 857ff0af3 HighFive utility routines (#661) 1d687db57 writeDataSet() utility overload 106aa6894 sigh ... H5Easy::dump() fill fails on Windows/WAF :-( 2641b60b2 Merge branch 'main' into feature/hdf5 35c19e7e8 change actions to @v3 (#660) 212bbd3a3 works on local machine, but not build server ... ? 7125118b0 dump of 1D vector doesn't work :-( c704db435 sigh ... WAF build still failing :-( 01aae4616 does dump() of a 1D vector work? 76a53c813 comment-out H5 writing :-( 0f0e19aff test_highfive_dump() cb8f73795 trying to get highfive_dump() unittest working w/Windows-WAF 6584a264a does test_highfive_create() work? cde6147ce tweak HighFive wrappers (#659) 316566854 Revert "trying HighFive "write" unittests again" a9ec24ca4 trying HighFive "write" unittests again 585ad49a5 tweak names of utility routines 4c91a4d97 make it easier to read a std::vector and std::vecotr 0217ffa26 readDataSet() now works for 1D data 95e8973f2 trying to get hdf5::lite::load() working 4d294611d "const" correctness 5e6305c3f fix load_complex() 4a134dc5f start work on utility routines to read complex data from HDF5 9d76a7f41 Merge branch 'main' into feature/hdf5 8f9667a24 whitepsace ebd3fc99e Merge branch 'main' into feature/hdf5 40091b069 comment-out writing tests for now ... need to figure our WAF bulid failure 935aa3459 be sure the dataset has real data 114b9bf33 update release notes bd9c0b26c tweak HighFive utility routines acda1ef57 turn off diagnostics around expected failures 22a748840 readDataSet() utility routine for HighFive bd88a8c25 HighFive writeDataSet() utility to work with our SpanRC 6142f5b33 use HighFive routines to write a HDF5 file 5bbf1abaf Use HiveFive routines to get info about the file 84fbc8378 duplicate unittests with H5Easy f1f054c03 Merge branch 'main' into feature/hdf5 9b63ca470 fix directory names f6f826689 fix directory names 7aeb82c33 Merge branch 'main' into feature/hdf5 d028baaeb hook up HighFive header-only library (#653) 3083b0a31 Revert "HighFive 2.6.2" 246985a7f Revert ""build" HighFive HDF5 library" a8b75a586 Revert "turn off HighFive Boost support" ec68d5f83 Revert "Add HighFive unittests" f1f85b9e7 Revert "get test_high_five_base more-or-less compiling" 5ea634ee1 Revert "more work on getting HighFive unittests to build" ecc45433c more work on getting HighFive unittests to build bb194788a get test_high_five_base more-or-less compiling d42bde000 Add HighFive unittests ddc86bb32 turn off HighFive Boost support b255122d4 "build" HighFive HDF5 library 396cc3ef2 HighFive 2.6.2 5e5f9d9c0 Merge branch 'main' into feature/hdf5 ee938b4a5 changes from SIX bb764df90 Merge branch 'main' into feature/xml.lite_tweaks de2a24380 make derived classes 'final' if possible 14e19bcd2 Change xml lite function to virtual (#645) 8f42ac8e9 Merge branch 'main' into feature/xml.lite_tweaks 18ad90645 hdf5Write unittest 3462e1179 createFile() and writeFile() overloads ecee81d53 fix typos 197eecfa6 sketch-out hdf5::lite::writeFile() bd2311795 use SpanRC for writeFile(), not yet implemented ea9af7510 simple SpanRC to hold a 2D-size and pointer 027c19ee8 createFile() unittest 1f9d07ecb hook up createFile() 8c7e4473f start hooking up HDF5 writing 146e0bea3 Merge branch 'main' into feature/hdf5 88ca9fcb7 Merge branch 'main' into feature/hdf5 42b604b46 Squashed commit of the following: 10ee602c2 Merge branch 'main' into feature/hdf5 67aa42b69 restore changes from "main" 8bbfcbfbf unittests can be simplified to match fewer "view" classes 126bb802e Merge branch 'main' into feature/hdf5 3f8ba7a42 again, don't need a class just to convert from std::vector<> to std::span<> 24c2b489c Squashed commit of the following: 2703c119d Squashed commit of the following: 9d5228a2b don't need an entire class just to convert a std::vector<> into std::span<> 51bc931dc Merge branch 'main' into feature/hdf5 a84f25816 Squashed commit of the following: c4d2ed696 add missing #include guards, fix type in existing #include guard d541525a0 use a single ComplexViewConstIterator for all views 86e6a459f CODA_OSS_disable_warning causes GCC errors :-( 5d4b9c2cb only need an custom iterator for ComplexSpansView d9f0fb128 hook up iterators b9329e4db initial pass at a ComplexViewConstIterator 635238873 remove compiler warning about unused "constexpr" variables b39f6096f use the casing from H5 to make copy/pasting code slightly easier 0887b13eb Merge branch 'main' into feature/hdf5 bd07df1ca Consistent casing for Dataset, Datatype, Dataspace 7acd30ee2 tweak hdf5.lite dependencies 38ab914df Jupyter notebook for creating H5 files 95a040e0b _small.h5 is now (correctly) FLOAT32 107e7c487 make a simple values() member function to avoid template magic e1feca919 use TEST_SPECIFIC_EXCEPTION macro instead of try/catch 738333688 readDatasetT() now throws for the wrong buffer type 6b2cc2529 Merge branch 'feature/hdf5' of github.com:mdaus/coda-oss into feature/hdf5 310f8fd3d can't get template magic right for copy_axis() 86b306d59 stepping through copy ctors in the debugger is annoying f243e92d6 trying to make wrong type of buffer fail 2b10d9652 read in new sample file a28e59d8c help the compiler with type deduction 49bf5e9bc nested_complex_float_data_small.h5 e029325fc utility routines to "deconstruct" and array of std::complex dede3bd39 Merge branch 'main' into feature/hdf5 904b1ef5e tweak class names, make_() and copy() utility routines 8237b9efb make it harder to pass the wrong types to ComplexViews 4d9aeda2c ComplexArrayView and ComplexParallelView utility classes f5e367dfa test std::span> a4a2844f2 read in the nested "i" and "r" data 115615265 sample file has subgroups 8e1b7869a Merge branch 'feature/hdf5' of github.com:mdaus/coda-oss into feature/hdf5 9f4232a1d update sample H5 file 8c55db73a walk through HDF5 sub-groups 7775ed9c4 Update 123_barfoo_catdog_cx.h5 677975d7c Matlab code to create sample H5 file a0e7dfe07 Update test_hdf5info.cpp 0b67e1602 pass __FILE__ and __LINE__ from calling site for a more accurate exception message 86a677321 skeleton for more sample data 85f79b099 Merge branch 'main' into feature/hdf5 18088e942 Merge branch 'main' into feature/hdf5 3a1d17692 Merge branch 'main' into feature/hdf5 1755c69d7 Merge branch 'main' into feature/hdf5 9ad015432 No more "11" suffix on exception names c20d96251 Squashed commit of the following: c88cee999 other values to be filled-in bca4a4ecd incorporation NamedObject from HDF5 docs 61fa68f72 groupInfo() 460e7d766 datasetInfo() 14eb9b764 start filling in DatasetInfo afe5f1c3a start to fill in DatasetInfo 77a968c72 start filling in GroupInfo d81bcdfd9 openGroup() to open groups (loc) a0cd29469 comment-out "dataset" unittest for now 86e006024 begin filling in FileInfo 366dda6ab a return_type_of utility is needed to deduce the return type e21928263 explicitly pass return type to template 4937ccd11 template to reduce boilerplate when calling try_catch_H5Exceptions b3b5ebde7 use new exception utility routines ea1c03ef0 put exception handling/conversion in a utility routine 819a99d39 utility routine for exception handling 6f34eea97 put utilities in a separate file for easier reuse fcbde4f24 break utility routines into smaller pieces for easier reuse 52358ea8a WIN32 no longer automatically defined? 5a4286472 Revert "build HDF5 with C89" 680e599e9 build HDF5 with C89 a87a07121 Merge branch 'main' into feature/hdf5 8447c1a90 Revert "sym-links instead of copying files" db3b5e12b Merge branch 'main' into feature/xml.lite_tweaks fb60b5696 Merge branch 'main' into feature/hdf5 5110a5cc8 Comments about _u and _q 1a937d32c Merge branch 'main' into feature/xml.lite_tweaks fa06f04d7 get ready for hdf5.lite enhancdements b040c7c43 sym-links instead of copying files aa431bb47 use _u for xml::lite::Uri 3d0c6d58c fix case-sensitive #include filename 93dcd0e52 operator() for getElementByName() 75a93af85 more operator[] overloads to make attribute management easier 4ab8216f8 user-defined string literals to remove some noise around xml::lite::QName f82f0b0fc Merge branch 'main' into feature/xml.lite_tweaks ae30e3644 Merge branch 'feature/xml.lite_tweaks' of github.com:mdaus/coda-oss into feature/xml.lite_tweaks ffdd9beb0 simplify attribute creation 9bf5414f5 simplify attribute creation 82d7a4e95 SWIG gets confused about namespaces 7a61d0741 fix bug on Element ctor uncovered by unittest fdd7e58c1 QName is also in the xerces namespace which confuses SWIG bindings a325b7053 operator+=() overload for addChild daf30e6c0 Merge branch 'feature/xml.lite_tweaks' of github.com:mdaus/coda-oss into feature/xml.lite_tweaks b887d2b47 provide overloads for Element& rather than creating new "reference" types 1fa6bba38 rename test_xmleasy.cpp 7c8c9e0f1 += overload 850da6f63 overload for std::string 4547fc5a7 use UIT-8 strings for characterData 4723462a3 convenient addChild() overloads e48720753 copy over ElementReference from xml.easy a4ca30a0d Merge branch 'main' into feature/xml.lite_tweaks 6ae9f0b71 Revert "check-in of new xml.easy (to move code between computers)" f7466a6d7 Revert "simple routines for single element" a5490230d Revert "make some operators simplier ways of calling functions" c9a25630a Revert "get document creation working" 8af8710b0 Revert "free functions instead of member functions" 16c3847cb Revert "ElementReference distinct from Element" 7d68e156f Revert "ElementMutableReference" 00eb2a282 Merge branch 'main' into feature/xml.lite_tweaks a42969c1f ElementMutableReference a20ae9355 ElementReference distinct from Element 14eeeea0b free functions instead of member functions 4aae014b3 get document creation working 883569269 make some operators simplier ways of calling functions 053bd1212 simple routines for single element 8bf701a2e check-in of new xml.easy (to move code between computers) 41f959051 unittests for creating XML documents from scratch 9752d50ae Merge branch 'main' into feature/xml.lite_tweaks 1531d5709 by default, don't validate strings passed to Uri() 46d13d4bf Merge branch 'master' into feature/xml.lite_tweaks 39b547d32 remove more vestiges of Expat and LibXML ec8274d52 remove LibXML and Expat as they're no longer used/supported. 20eeefeef Merge branch 'master' into feature/xml.lite_tweaks 95074b9b1 update for newer Intel compiler 7024f71e1 Merge branch 'master' into feature/xml.lite_tweaks 57b1cbc83 Merge branch 'master' into feature/xml.lite_tweaks 4b67561c3 remove validate() overload that nobody is using fa15f1e5d Squashed commit of the following: 1484a9090 test the new validate() API 470da70fb hookup StringStreamT routines 2cddf2504 begin hooking up validate() overloads 1b5d910f3 overload validate() for UTF-8 and Windows-1252 03309b8c9 Squashed commit of the following: b72c6c5bf older compiler doesn't like our make_unique af8f00307 validate UTF-8 XML on Linux 211188613 unit-test for LEGACY XML validation 3c1169d2b Squashed commit of the following: 3afff19ca std::filesystem::path for FileInputStreamOS 908d452f8 WIP: validate all of our sample XML files 00f9bb16b validate against a XML schema 243d8c356 Merge branch 'master' into feature/xml.lite_tweaks 2815d707d fix to work with SWIG bindings. :-( 460862132 trying (again) to remove vestiages of old code e3c83a858 Revert "new code should use UTF-8" 811207c92 new code should use UTF-8 0ffd835f9 Squashed commit of the following: 1e7e03ded Merge branch 'master' into feature/xml.lite_tweaks c1d806aff Merge branch 'master' into feature/xml.lite_tweaks 850d3c811 str::strip() that can be easier to use than str::trim() 580ba9c8c explicitly =delete move 2b39831a8 Squashed commit of the following: 39eebdc23 Merge branch 'master' into feature/xml.lite_tweaks 9adf86cba force calling new UTF-8 write() routines ea61b6204 Merge branch 'master' into feature/xml.lite_tweaks 8a34583fa overload to take schemaPaths as filesystem::path 8671b442f parse XML embedded in a binary file ec4a902f1 updates from xerces.lite 80dc4d963 updates from xerces.lite 549766d6c Attributes::contains() no longer catches an exception 8a645ceac need "sys/" when building in other environments 36af08269 super-simple URI validation 78ef28a3e SWIG bindings are a PITA! :-( e9cba8491 SWIG needs help with Uri 8a8d8dc07 another routines used by pre-build SWIG bindings 818e1ec5d pre-build SWIG bindings use getElementByTagName() member function 067cac5d8 old compiler gets confused on unadorned QName ba92c0ae7 more use of Uri and QName 446c7d17a use QName in new code d6f8b0c83 more direct use of QName 90fff1c73 use xml::lite::QName instead of tuple 646cbb5ed more direct use of QName and Uri ba589ea3b make QName more robust bab0ee8b5 createElement() -> addNewElement() e3a145747 grab changes from six-library 32285e95c Merge branch 'master' into feature/xml.lite_tweaks 9f79f0bf6 Merge branch 'master' into feature/xml.lite_tweaks a12bbc32c make it easier to create new Elements with a value fc9967f98 make it easy for callers to addChild() keep a reference to the Element 4627766b7 be sure test_xmlparser works in "externals" of other projects bf2276396 "private" is part of the name-mangling fad92bcc8 making sure copy-ctor is implemented f90fdcead consolidate common XML test code 9fc53f2d5 use str:: utility for casting 6da6f794b still trying to find the right macro for SWIG 0c1b86c56 still trying to fix SWIG fdc6fc9bd trying to fix SWIG build error 7835e8c27 SWIG needs copy-ctor 585695942 disable copy/assignment for Element, it's probably almost always wrong 391fed613 fix double-delete caused by copying 61790fe69 retry parsing XML with Windows-1252 if first parse() fails 63cffac59 change string_encoding to match coda-oss style of PascalCase 010479bbe read an XML file we know is wrongly encoded as Windows-1252 9a0505062 more references instead of pointers 2d44b6951 Reading Windows-1252 w/o "encoding" fails 63dc7b076 read Windows-1252 too c9434c9cb test as UIT-8 too f310ccf0c get reading from UTF-8 XML working on Windows 1fa39c2be get testReadUtf8XmlFile working on Linux 1a83cd815 sys::Path is too much trouble right now ed60aa22c unit-test to read XML from a file a9336db7c Squashed commit of the following: 0825beb0d Merge branch 'master' into feature/xml.lite_tweaks c618489be Merge branch 'master' into feature/xml.lite_tweaks e8e4b8fe1 determine string_encoding based on platform 1f43bcfc2 create a new Element by using the platform to determine "characterData" encoding 961bef66b Merge branch 'master' into feature/xml.lite_tweaks e9798a5cb fix static_assert() 6f7772874 Merge branch 'master' into feature/xml.lite_tweaks b98d4f5a9 Merge branch 'master' into feature/xml.lite_tweaks 1b5abba2a The (old) version of SWIG we're using doesn't like certain C++11 features. 53bdeabaf Merge branch 'master' into feature/xml.lite_tweaks 60cf8ae80 "" doesn't work with decltype() in older C++ 97e72477a reduce getValue() overloads by making "key" a template argument 5e6373e55 reduce code duplication f9e7cfeee provide castValue instead of getValue(T&) cbd0bd8f2 castValue throws instead of returning a bool like getValue(T&) 87c7514fc Merge branch 'master' into feature/xml.lite_tweaks 10cc61223 make getElement*() consistent for zero or >1 results f5b137e3c Merge branch 'master' into feature/xml.lite_tweaks 1765efc62 allow clients to specify toType() and toString() for getValue() and setValue() df8b746e1 allow clients to specify their own toType/toString routines 66702726a Merge branch 'master' into feature/xml.lite_tweaks 6956311f1 Merge branch 'master' into feature/xml.lite_tweaks d505f3593 Merge branch 'master' into feature/xml.lite_tweaks fbd106115 catch a BadCastException and return false from getValue() 3a78377b5 use a template to reduce duplicated code 0ad4b8606 Merge branch 'master' into feature/xml.lite_tweaks a848aa3a2 get & set the characer data as a type f3ee1ee12 utility routines to set an attribute value 595227683 templates to get an attribute value convert to a specific type 06639227b miised a change in last commit 1aa458ef8 add getValue() overloads that return true/false rather than throwing faa6d3075 added getElementByTagName() overloads as that's a very common use-case git-subtree-dir: externals/coda-oss git-subtree-split: f4d42005fa477ae59da193422aa2cb14b877cf0c commit ec161c5b334ea8133777a78ce94181807e591642 Merge: d2d594b9f 272cae451 Author: Dan Smith Date: Tue Jun 13 17:51:29 2023 -0400 Merge commit '272cae451cbe3ad6820d1221aafe375d77b1ba04' into develop/sync_externals commit d2d594b9ff50bc00c15a4228927ea1ec0449381b Author: Dan Smith Date: Tue Jun 13 17:51:25 2023 -0400 latest from CODA-OSS and NITRO commit 09ec30cc503ffd74daa401514ab9b674c6e4a3cf Merge: 28a4b2bd1 4a21b2db5 Author: Dan Smith Date: Thu Jun 15 15:54:31 2023 -0400 Merge branch 'main' into develop/complex_short commit 28a4b2bd17daabbb9ba94aae53a58986acd58a9b Author: Dan Smith Date: Thu Jun 15 14:58:55 2023 -0400 restore "old" CODA-OSS to minimize differences commit f41c086967d2e5b05ee8988272ab8ca8c0014f85 Author: Dan Smith Date: Thu Jun 15 14:40:31 2023 -0400 keep using std::complex<> everywhere commit bc1704c8cb985f1987a7d3ff2b37c2e48286a8fd Author: Dan Smith Date: Thu Jun 15 14:22:47 2023 -0400 latest from CODA-OSS commit 4ec782e6c9409f1985628c36a88577b286af61e7 Author: Dan Smith Date: Thu Jun 15 13:56:24 2023 -0400 build against "old" CODA-OSS commit bffd6a985d8dc8e08b42aed78bbe7a162ac45bf6 Author: Dan Smith Date: Thu Jun 15 13:56:08 2023 -0400 restore CODA-OSS changes to minimize merge differences commit d93e0e80c94013e1b957eb2c33ba112643c306c3 Author: Dan Smith Date: Thu Jun 15 13:39:37 2023 -0400 more passing the entire complex type as a template parameter commit 0872159268ff8f38e3c3d42788598725ce142616 Author: Dan Smith Date: Thu Jun 15 13:25:14 2023 -0400 no more types::complex commit 379a89312f55c86f1de95f6ff14e7aeca72df32c Author: Dan Smith Date: Thu Jun 15 12:36:06 2023 -0400 use CODA_OSS_types_unique_zinteger commit 2b9b396c4d460233418f293d6ebdf157231b8757 Author: Dan Smith Date: Thu Jun 15 11:58:00 2023 -0400 latest from CODA-OSS commit 5d19ea2946556ab9f7e2e1ec98e0d07fecf578e2 Merge: 0dab1a156 7e99024da Author: Dan Smith Date: Thu Jun 15 11:07:26 2023 -0400 Merge branch 'develop/complex' into develop/complex_short commit 7e99024da866660e7e4da621b75f4561e638044b Author: Dan Smith Date: Thu Jun 15 11:06:20 2023 -0400 unittest changes from develop/complex_short branch commit e5c0f6d52e05bf50741a6bc086eae9ce53a89e9e Author: Dan Smith Date: Thu Jun 15 11:00:34 2023 -0400 more changes from CODA-OSS commit ca7cb60f6b39a2f1a03dd1497bb20a4da5925c24 Author: Dan Smith Date: Thu Jun 15 10:34:57 2023 -0400 no more types::complex commit 6048da55638d0283cf789347740871aa2d07fba1 Author: Dan Smith Date: Thu Jun 15 10:18:44 2023 -0400 latest from CODA-OSS commit 16c99ed82bb9b57edc1ea5e28d68f89b63519664 Author: Dan Smith Date: Thu Jun 15 08:13:27 2023 -0400 pass the entire complex type and use value_type commit 4d9d2a764319f3177b427b3a03ae95c99ef02494 Author: Dan Smith Date: Thu Jun 15 09:24:49 2023 -0400 pass entire complex type as template parameter commit 0dab1a15681e51a5464b363baa0f263e25521c4a Author: Dan Smith Date: Thu Jun 15 09:24:49 2023 -0400 pass entire complex type as template parameter commit e4c29f670785b3312dda1d6b6da30847fa798b89 Author: Dan Smith Date: Thu Jun 15 09:14:37 2023 -0400 Update PVPBlock.cpp commit 7133f7f4b4752d0e049ef48241a4e1b707a5c4ec Author: Dan Smith Date: Thu Jun 15 09:09:11 2023 -0400 restore types::z* overloads commit 9a0c890090d5501bb2c563e0b36a787cfad70af6 Merge: a3a71ba35 fc8ba82bd Author: Dan Smith Date: Thu Jun 15 09:01:31 2023 -0400 Merge branch 'develop/complex' into develop/complex_short commit fc8ba82bd5357454d02276c1605ddcd5973322d1 Author: Dan Smith Date: Thu Jun 15 08:59:58 2023 -0400 findComplex() utility commit 8b762374c282458c469ad6e4502aaee7aa695079 Author: Dan Smith Date: Thu Jun 15 08:47:56 2023 -0400 const& for Parameter arguments commit a3a71ba351b9b790c20bb80e4fac861592758164 Author: Dan Smith Date: Thu Jun 15 08:26:00 2023 -0400 getComplex() overloads commit 6fc1ee4b96b722b81042f79ed476c481af13aadd Author: Dan Smith Date: Thu Jun 15 08:13:27 2023 -0400 pass the entire complex type and use value_type commit 13e44351a9e912c91fd79ada8b09a544c482874a Author: J. Daniel Smith Date: Wed Jun 14 21:47:37 2023 -0400 more progress on types::complex commit 5e72ecca7037861e87f311339c61bc2cf77305fe Author: Dan Smith Date: Wed Jun 14 17:43:52 2023 -0400 use our own type for complex commit 9bfc4f9799df5261bbc0c7afb1ffa08abc060ba1 Author: Dan Smith Date: Wed Jun 14 17:42:58 2023 -0400 latest from CODA-OSS commit 39153f274d56de88a28b526978dd4ad832e767f9 Author: Dan Smith Date: Wed Jun 14 16:45:05 2023 -0400 fix Parameter::setValue() overloads commit b8007fbad15e529eb503bbfd692c85ce6d34a0a6 Author: Dan Smith Date: Wed Jun 14 16:37:10 2023 -0400 latest from coda-oss commit 27f080ec628c4497709cfc85183f3a1ceaad11cb Author: Dan Smith Date: Wed Jun 14 16:22:29 2023 -0400 move is implicitly deleted because of =delete for copy commit bd69591ff8c93d1aaa9f184346eac2aca83b3272 Merge: 71d519492 35b59b9a0 Author: Dan Smith Date: Wed Jun 14 16:09:16 2023 -0400 Merge branch 'main' into develop/complex_short commit 71d519492046c4c61986f181f6ec7aa18cb4c0c6 Author: Dan Smith Date: Tue Jun 13 15:25:54 2023 -0400 std::complex -> six::zfloat commit a3eee8257746732f61b959c9b31442511d81b590 Merge: d0bb8c181 e13c3da4f Author: Dan Smith Date: Tue Jun 13 15:17:07 2023 -0400 Merge branch 'main' into develop/complex_short commit d0bb8c1819da2ade60c4ce3349ff40f32fe31301 Author: Dan Smith Date: Tue Jun 13 15:15:46 2023 -0400 finish (almost) switching to types::complex for integers commit bbe1320e33768a0a0f151feb138643c80a8bdfbd Author: Dan Smith Date: Tue Jun 13 14:57:21 2023 -0400 types::complex is std::complex for now commit 00047f57ea462c610d249d25fcd2f0105a7c0f41 Author: Dan Smith Date: Tue Jun 13 14:36:27 2023 -0400 latest from coda-oss commit ac376dcf72763892e9e9b9c03fb14bc34fd04630 Author: Dan Smith Date: Tue Jun 13 14:13:42 2023 -0400 Update test_dump_images.cpp commit 2907efbcfdb33f154138944831a94a2c508b5a68 Author: Dan Smith Date: Mon Jun 12 16:39:29 2023 -0400 use types::complex for TInteger commit 2580312337bf1b7ee20d5ba9eed83c8e65e06e6f Author: Dan Smith Date: Mon Jun 12 16:26:16 2023 -0400 CPHD aliaes for std::complex commit d177963c782c08c137d14b9608207d40754db568 Author: Dan Smith Date: Mon Jun 12 16:17:38 2023 -0400 latest from coda-oss commit e05937c9b568f52fa9f41b279e2c8ecfa63e5fc0 Author: Dan Smith Date: Mon Jun… * getVersion() and setVersion() overloads to use Version enum * BaseFileHeader::readVersion() now returns an enum instead of a std::string * more use of Version enum rather than a string * process XML using UTF-8 * include txAntenna and rcvAntenna in output * use .size() and .size_bytes() * pass around a cphd::Version in more places * create Metadata and FileHeader with non-default versions * no copy, only move for `Metadata` * allow FileHeader::DefaultVersion to be changed * do work in constructor; no need for separate initialize() * set the `Metadata` version at a lower-level so everybody gets it * isolate version -> URI conversion * avoid passing FileHeader::getDefaultVersion() to a new Metadata instance * utility routine to create Metadata * almost remove default (Version-less) constructor for Metadata * initialize the `FileHeader` in the constructor * read the FileHeader version directly at creation * read() -> readImpl() * no more default constructor for `FileHeader` * no more default constructor for `Metadata` * need default constructors and copy for existing SWIG bindings * existing Python bindings want to get/set a string version * existing SWIG bindings also want to get/set the FileHeader version as a string --- .../c++/cphd/include/cphd/BaseFileHeader.h | 8 +- .../c++/cphd/include/cphd/CPHDReader.h | 15 ++- .../c++/cphd/include/cphd/CPHDWriter.h | 54 ++++------ .../c++/cphd/include/cphd/CPHDXMLControl.h | 11 +- .../c++/cphd/include/cphd/CPHDXMLParser.h | 9 +- six/modules/c++/cphd/include/cphd/Data.h | 8 ++ .../c++/cphd/include/cphd/DataWriter.h | 26 ++++- .../c++/cphd/include/cphd/FileHeader.h | 49 ++++++--- six/modules/c++/cphd/include/cphd/Metadata.h | 26 +++-- six/modules/c++/cphd/include/cphd/PVP.h | 34 ++++-- six/modules/c++/cphd/include/cphd/PVPBlock.h | 15 ++- .../c++/cphd/include/cphd/SupportBlock.h | 41 ++----- .../c++/cphd/include/cphd/TestDataGenerator.h | 23 +++- .../c++/cphd/source/BaseFileHeader.cpp | 27 ++++- six/modules/c++/cphd/source/ByteSwap.cpp | 15 +-- six/modules/c++/cphd/source/CPHDReader.cpp | 40 +++---- six/modules/c++/cphd/source/CPHDWriter.cpp | 100 ++++++++---------- .../c++/cphd/source/CPHDXMLControl.cpp | 52 +++------ six/modules/c++/cphd/source/CPHDXMLParser.cpp | 28 +++-- six/modules/c++/cphd/source/DataWriter.cpp | 22 ++-- six/modules/c++/cphd/source/FileHeader.cpp | 63 +++++++---- six/modules/c++/cphd/source/Metadata.cpp | 34 ++---- six/modules/c++/cphd/source/PVP.cpp | 13 ++- six/modules/c++/cphd/source/SupportBlock.cpp | 66 ++++++------ .../c++/cphd/tests/test_compare_cphd.cpp | 21 ++-- .../c++/cphd/tests/test_round_trip.cpp | 14 ++- .../test_compressed_signal_block_round.cpp | 6 +- .../cphd/unittests/test_cphd_xml_control.cpp | 30 +++--- .../c++/cphd/unittests/test_file_header.cpp | 35 +++--- .../cphd/unittests/test_pvp_block_round.cpp | 9 +- .../c++/cphd/unittests/test_read_wideband.cpp | 55 +++++----- .../unittests/test_signal_block_round.cpp | 3 +- .../unittests/test_support_block_round.cpp | 11 +- .../c++/cphd03/include/cphd03/FileHeader.h | 6 +- six/modules/c++/cphd03/source/FileHeader.cpp | 4 +- six/modules/c++/samples/test_dump_images.cpp | 2 +- six/modules/c++/samples/test_parse_xml.cpp | 2 +- six/modules/c++/scene/tests/test_scene.cpp | 12 +-- .../c++/six.sicd/source/ComplexXMLParser.cpp | 8 +- .../six.sicd/source/ComplexXMLParser10x.cpp | 4 +- .../six.sidd/source/DerivedClassification.cpp | 46 +++----- .../c++/six.sidd/source/DerivedXMLParser.cpp | 4 +- .../six.sidd/source/GeoTIFFWriteControl.cpp | 4 +- six/modules/c++/six/include/six/Enum.h | 2 +- six/modules/c++/six/source/Utilities.cpp | 3 +- six/modules/c++/six/source/XMLControl.cpp | 2 +- 46 files changed, 543 insertions(+), 519 deletions(-) diff --git a/six/modules/c++/cphd/include/cphd/BaseFileHeader.h b/six/modules/c++/cphd/include/cphd/BaseFileHeader.h index 1f62a91f95..a0fcd0c1bc 100644 --- a/six/modules/c++/cphd/include/cphd/BaseFileHeader.h +++ b/six/modules/c++/cphd/include/cphd/BaseFileHeader.h @@ -30,6 +30,8 @@ #include #include +#include "cphd/Types.h" + namespace cphd { @@ -73,7 +75,9 @@ class BaseFileHeader * \throws except::Exception if file is not CPHD */ static - std::string readVersion(io::SeekableInputStream& inStream); + std::string strReadVersion(io::SeekableInputStream& inStream); + static Version readVersion(io::SeekableInputStream& inStream); + static Version toVersion(const std::string&); /* * \func read @@ -88,7 +92,7 @@ class BaseFileHeader * \throws except::Exception if expected header entry is not found * \throws except::Exception if any header info is missing or empty */ - virtual void read(io::SeekableInputStream& inStream) = 0; + virtual void readImpl(io::SeekableInputStream& inStream) = 0; /* * \func toString diff --git a/six/modules/c++/cphd/include/cphd/CPHDReader.h b/six/modules/c++/cphd/include/cphd/CPHDReader.h index 84cc7031f2..ed47c7e091 100644 --- a/six/modules/c++/cphd/include/cphd/CPHDReader.h +++ b/six/modules/c++/cphd/include/cphd/CPHDReader.h @@ -19,9 +19,9 @@ * see . * */ +#pragma once #ifndef SIX_cphd_CPHDReader_h_INCLUDED_ #define SIX_cphd_CPHDReader_h_INCLUDED_ -#pragma once #include @@ -78,6 +78,11 @@ struct CPHDReader final std::shared_ptr logger = std::shared_ptr()); + CPHDReader(const CPHDReader&) = delete; + CPHDReader& operator=(const CPHDReader&) = delete; + CPHDReader(CPHDReader&&) = default; + CPHDReader& operator=(CPHDReader&&) = default; + //! Get parameter functions size_t getNumChannels() const { @@ -152,14 +157,6 @@ struct CPHDReader final PVPBlock mPVPBlock; //! Signal block book-keeping info read in from CPHD file std::unique_ptr mWideband; - - /* - * Read in header, metadata, supportblock, pvpblock and wideband - */ - void initialize(std::shared_ptr inStream, - size_t numThreads, - std::shared_ptr logger, - const std::vector& schemaPaths); }; } diff --git a/six/modules/c++/cphd/include/cphd/CPHDWriter.h b/six/modules/c++/cphd/include/cphd/CPHDWriter.h index 2cc73c448a..49988b826b 100644 --- a/six/modules/c++/cphd/include/cphd/CPHDWriter.h +++ b/six/modules/c++/cphd/include/cphd/CPHDWriter.h @@ -20,16 +20,19 @@ * */ +#pragma once #ifndef SIX_cphd_CPHDWriter_h_INCLUDED_ #define SIX_cphd_CPHDWriter_h_INCLUDED_ -#pragma once #include #include +#include +#include #include #include #include +#include #include @@ -126,17 +129,12 @@ struct CPHDWriter final * \param supportData (Optional) The support array data to write to disk. */ template - void write( - const PVPBlock& pvpBlock, - const T* widebandData, - const sys::ubyte* supportData = nullptr); + void write(const PVPBlock& pvpBlock, const T* widebandData, + std::span supportData); template - void write( - const PVPBlock& pvpBlock, - const T* widebandData, - const std::byte* supportData = nullptr) + void write(const PVPBlock& pvpBlock, const T* widebandData) { - write(pvpBlock, widebandData, reinterpret_cast(supportData)); + write(pvpBlock, widebandData, std::span()); } /* @@ -161,12 +159,12 @@ struct CPHDWriter final * \param id The unique identifier of the support array */ template - void writeSupportData(const T* data, + void writeSupportData(const T* data_, const std::string& id) { - writeSupportDataImpl(reinterpret_cast(data), - mMetadata.data.getSupportArrayById(id).numRows * mMetadata.data.getSupportArrayById(id).numCols, - mMetadata.data.getSupportArrayById(id).bytesPerElement); + const auto size = mMetadata.data.getSupportArrayById(id).size_bytes(); + const auto data = sys::make_span(data_, size); + writeSupportDataImpl(data, mMetadata.data.getSupportArrayById(id).bytesPerElement); } /* @@ -177,22 +175,17 @@ struct CPHDWriter final * * \param data A pointer to the start of the support array data block */ + void writeSupportData(std::span); template - void writeSupportData(const T* data) + void writeSupportData(std::span data) { - auto dataPtr = reinterpret_cast(data); - for (auto it = mMetadata.data.supportArrayMap.begin(); it != mMetadata.data.supportArrayMap.end(); ++it) - { - // Move inputstream head to offset of particular support array - mStream->seek(mHeader.getSupportBlockByteOffset() + it->second.arrayByteOffset, io::SeekableOutputStream::START); - writeSupportDataImpl(dataPtr + it->second.arrayByteOffset, - it->second.numRows * it->second.numCols, - it->second.bytesPerElement); - } - // Move inputstream head to the end of the support block after all supports have been written - mStream->seek(mHeader.getSupportBlockByteOffset() + mHeader.getSupportBlockSize(), io::SeekableOutputStream::START); + writeSupportData(std::as_bytes(data)); + } + template + void writeSupportData(const std::vector& data) + { + writeSupportData(sys::make_span(data)); } - /* * \func writePVPData @@ -264,8 +257,7 @@ struct CPHDWriter final /* * Implementation of write support data */ - void writeSupportDataImpl(const std::byte* data, - size_t numElements, size_t elementSize); + void writeSupportDataImpl(std::span, size_t elementSize); //! DataWriter object std::unique_ptr mDataWriter; @@ -273,8 +265,6 @@ struct CPHDWriter final // Book-keeping element //! metadata information const Metadata& mMetadata; - //! header information - FileHeader mHeader; //! size of each element in signal block const size_t mElementSize; //! size of scratch space for byte swapping @@ -285,6 +275,8 @@ struct CPHDWriter final const std::vector mSchemaPaths; //! Output stream contains CPHD file std::shared_ptr mStream; + //! header information + FileHeader mHeader; }; } diff --git a/six/modules/c++/cphd/include/cphd/CPHDXMLControl.h b/six/modules/c++/cphd/include/cphd/CPHDXMLControl.h index 2a6b619cd2..da0f114cff 100644 --- a/six/modules/c++/cphd/include/cphd/CPHDXMLControl.h +++ b/six/modules/c++/cphd/include/cphd/CPHDXMLControl.h @@ -145,8 +145,10 @@ class CPHDXMLControl const std::vector& schemaPaths = std::vector()); //! \return Suported version to uri mapping - static std::unordered_map getVersionUriMap(); - static void getVersionUriMap(std::map&); + static std::map getVersionUriMap(); + + // Given the URI get associated version + static Version uriToVersion(const xml::lite::Uri&); protected: logging::Logger *mLog = nullptr; @@ -178,10 +180,7 @@ class CPHDXMLControl * \param uri A string specifying CPHD uri */ std::unique_ptr - getParser(const xml::lite::Uri&) const; - - // Given the URI get associated version - Version uriToVersion(const xml::lite::Uri&) const; + getParser(Version) const; }; } diff --git a/six/modules/c++/cphd/include/cphd/CPHDXMLParser.h b/six/modules/c++/cphd/include/cphd/CPHDXMLParser.h index 6961f0f1e0..a5c1698554 100644 --- a/six/modules/c++/cphd/include/cphd/CPHDXMLParser.h +++ b/six/modules/c++/cphd/include/cphd/CPHDXMLParser.h @@ -46,9 +46,8 @@ namespace cphd * \brief This class converts a Metadata object into a CPHD XML * Document Object Model (DOM) and vise-versa. */ -class CPHDXMLParser : public six::XMLParser +struct CPHDXMLParser final : public six::XMLParser { -public: /*! * \func CPHDXMLParser * \brief Constructor @@ -58,7 +57,7 @@ class CPHDXMLParser : public six::XMLParser * \param log provide logger object * \param ownLog flag indicates if log should be deleted */ - CPHDXMLParser(const std::string& uri, + CPHDXMLParser(Version, bool addClassAttributes, logging::Logger* log = nullptr, bool ownLog = false); @@ -85,8 +84,8 @@ class CPHDXMLParser : public six::XMLParser * * \return pointer to metadata object */ - std::unique_ptr fromXML( - const xml::lite::Document* doc); + std::unique_ptr fromXML(const xml::lite::Document* doc); + Metadata fromXML(const xml::lite::Document&, Version); private: typedef xml::lite::Element* XMLElem; diff --git a/six/modules/c++/cphd/include/cphd/Data.h b/six/modules/c++/cphd/include/cphd/Data.h index ca3daca693..743d2c28cf 100644 --- a/six/modules/c++/cphd/include/cphd/Data.h +++ b/six/modules/c++/cphd/include/cphd/Data.h @@ -95,6 +95,14 @@ struct Data { return numRows * numCols * bytesPerElement; } + size_t size() const + { + return numRows * numCols; + } + size_t size_bytes() const // c.f., std::span::size_bytes() + { + return size() * bytesPerElement; + } //! Unique string that identifies this support array //! (SA_ID). diff --git a/six/modules/c++/cphd/include/cphd/DataWriter.h b/six/modules/c++/cphd/include/cphd/DataWriter.h index 3be5c21ba7..125a1c2e24 100644 --- a/six/modules/c++/cphd/include/cphd/DataWriter.h +++ b/six/modules/c++/cphd/include/cphd/DataWriter.h @@ -20,16 +20,18 @@ * */ +#pragma once #ifndef SIX_cphd_DataWriter_h_INCLUDED_ #define SIX_cphd_DataWriter_h_INCLUDED_ -#pragma once #include #include #include // std::byte +#include #include #include +#include namespace cphd { @@ -69,7 +71,13 @@ struct DataWriter * \param numElements Total number of elements in array * \param elementSize Size of each element */ - virtual void operator()(const void* data, size_t numElements, size_t elementSize) = 0; + virtual void operator()(std::span, size_t elementSize) = 0; + void operator()(const void* data_, size_t numElements, size_t elementSize) + { + const auto pData = static_cast(data_); + std::span data(pData, numElements * elementSize); + (*this)(data, elementSize); + } protected: //! Output stream of CPHD @@ -112,7 +120,12 @@ struct DataWriterLittleEndian final : public DataWriter * \param numElements Total number of elements in array * \param elementSize Size of each element */ - void operator()(const void* data, size_t numElements, size_t elementSize) override; + void operator()(std::span, size_t elementSize) override; + void operator()(const sys::ubyte* data, size_t numElements, size_t elementSize) // for existing SWIG bindings + { + DataWriter* const pThis = this; + (*pThis)(data, numElements, elementSize); + } private: // Scratch space buffer @@ -154,7 +167,12 @@ struct DataWriterBigEndian final : public DataWriter * \param numElements Total number of elements in array * \param elementSize Size of each element */ - void operator()(const void* data, size_t numElements, size_t elementSize) override; + void operator()(std::span, size_t elementSize) override; + void operator()(const sys::ubyte* data, size_t numElements, size_t elementSize) // for existing SWIG bindings + { + DataWriter* const pThis = this; + (*pThis)(data, numElements, elementSize); + } }; // Create the appropriate DataWriter instance using std::endian::native. There are fancier diff --git a/six/modules/c++/cphd/include/cphd/FileHeader.h b/six/modules/c++/cphd/include/cphd/FileHeader.h index c096cc60ae..b196571986 100644 --- a/six/modules/c++/cphd/include/cphd/FileHeader.h +++ b/six/modules/c++/cphd/include/cphd/FileHeader.h @@ -19,8 +19,9 @@ * see . * */ -#ifndef __CPHD_FILE_HEADER_H__ -#define __CPHD_FILE_HEADER_H__ +#pragma once +#ifndef SIX_cphd_FileHeader_h_INCLUDED_ +#define SIX_cphd_FileHeader_h_INCLUDED_ #include #include @@ -39,7 +40,10 @@ namespace cphd */ class FileHeader final : public BaseFileHeader { + static Version defaultVersion; public: + static Version getDefaultVersion(); + static void setDefaultVersion(Version); static const char* DEFAULT_VERSION; // `const char*` for existing Python bindings /* @@ -48,7 +52,17 @@ class FileHeader final : public BaseFileHeader * \brief Constructor * initialize default variables */ - FileHeader(); + FileHeader(Version); +#ifdef SWIGPYTHON + FileHeader() = default; + FileHeader(const FileHeader&) = default; + FileHeader& operator=(const FileHeader&) = default; +#else + FileHeader(const FileHeader&) = delete; + FileHeader& operator=(const FileHeader&) = delete; +#endif + FileHeader(FileHeader&&) = default; + FileHeader& operator=(FileHeader&&) = default; virtual ~FileHeader() { @@ -61,7 +75,8 @@ class FileHeader final : public BaseFileHeader * * \param inStream Valid input stream of CPHD file */ - void read(io::SeekableInputStream& inStream) override; + void readImpl(io::SeekableInputStream&) override; + static FileHeader read(io::SeekableInputStream&); /* * \func toString @@ -86,6 +101,7 @@ class FileHeader final : public BaseFileHeader * returns file version string */ std::string getVersion() const; + void getVersion(Version&) const; /* * \func setVersion @@ -96,7 +112,7 @@ class FileHeader final : public BaseFileHeader * ex: 1.0.0, 1.0.1 etc * */ - void setVersion(const std::string& version); + void setVersion(const std::string&); void setVersion(Version); /* @@ -234,22 +250,25 @@ class FileHeader final : public BaseFileHeader private: // File type header - std::string mVersion; + Version mVersion; // Required key-value pairs - int64_t mXmlBlockSize; - int64_t mXmlBlockByteOffset; - int64_t mPvpBlockSize; - int64_t mPvpBlockByteOffset; - int64_t mSignalBlockSize; - int64_t mSignalBlockByteOffset; + int64_t mXmlBlockSize = 0; + int64_t mXmlBlockByteOffset = 0; + int64_t mPvpBlockSize = 0; + int64_t mPvpBlockByteOffset = 0; + int64_t mSignalBlockSize = 0; + int64_t mSignalBlockByteOffset = 0; std::string mClassification; std::string mReleaseInfo; // Optional key-value pairs - int64_t mSupportBlockSize; - int64_t mSupportBlockByteOffset; + int64_t mSupportBlockSize = 0; + int64_t mSupportBlockByteOffset = 0; + + void readAfterValidVersion(io::SeekableInputStream& inStream); }; + } -#endif +#endif // SIX_cphd_FileHeader_h_INCLUDED_ diff --git a/six/modules/c++/cphd/include/cphd/Metadata.h b/six/modules/c++/cphd/include/cphd/Metadata.h index 1cca99a41a..8b1981ea59 100644 --- a/six/modules/c++/cphd/include/cphd/Metadata.h +++ b/six/modules/c++/cphd/include/cphd/Metadata.h @@ -20,8 +20,9 @@ * */ -#ifndef __CPHD_METADATA_H__ -#define __CPHD_METADATA_H__ +#pragma once +#ifndef SIX_cphd_Metadata_h_INCLUDED_ +#define SIX_cphd_Metadata_h_INCLUDED_ #include @@ -59,7 +60,18 @@ struct Metadata final : MetadataBase { //! Default constructor //! Initializes CPHD version to default version specified in FileHeader - Metadata(); + Metadata(Version); + Metadata(Data&&); +#ifdef SWIGPYTHON + Metadata() = default; + Metadata(const Metadata&) = default; + Metadata& operator=(const Metadata&) = default; +#else + Metadata(const Metadata&) = delete; + Metadata& operator=(const Metadata&) = delete; +#endif + Metadata(Metadata&&) = default; + Metadata& operator=(Metadata&&) = default; /* * Getter functions @@ -78,12 +90,10 @@ struct Metadata final : MetadataBase */ DomainType getDomainType() const override; - //! Get CPHD version + //! CPHD version std::string getVersion() const; void getVersion(Version&) const; - - //! Set CPHD version - void setVersion(const std::string& version); + void setVersion(const std::string&); void setVersion(Version); //! CollectionInfo block. Contains the general collection information @@ -161,4 +171,4 @@ struct Metadata final : MetadataBase std::ostream& operator<< (std::ostream& os, const Metadata& d); } -#endif +#endif // SIX_cphd_Metadata_h_INCLUDED_ diff --git a/six/modules/c++/cphd/include/cphd/PVP.h b/six/modules/c++/cphd/include/cphd/PVP.h index d302b60a8c..e106dd23ca 100644 --- a/six/modules/c++/cphd/include/cphd/PVP.h +++ b/six/modules/c++/cphd/include/cphd/PVP.h @@ -124,7 +124,7 @@ struct PVPType std::string mFormat; }; void setOffset(PVPType&, size_t offset); - +std::ostream& operator<< (std::ostream& os, const PVPType& p); /*! * \struct APVPType @@ -211,6 +211,12 @@ struct PerVectorParameterXYZ final PVPType param; }; +inline std::ostream& operator<<(std::ostream& os, const PerVectorParameterXYZ& v) +{ + os << v.param << "\n"; + return os; +} + /*! * \struct PerVectorParameterEB @@ -237,6 +243,12 @@ struct PerVectorParameterEB final PVPType param; }; +inline std::ostream& operator<<(std::ostream& os, const PerVectorParameterEB& v) +{ + os << v.param << "\n"; + return os; +} + /*! * \struct TxAntenna @@ -267,6 +279,13 @@ struct TxAntenna final //! TxEB PVP Structure six::XsElement txEB{ "TxEB" }; }; +inline std::ostream& operator<<(std::ostream& os, const TxAntenna& v) +{ + os << v.txACX << "\n"; + os << v.txACY << "\n"; + os << v.txEB << "\n"; + return os; +} /*! * \struct RcvAntenna @@ -297,6 +316,13 @@ struct RcvAntenna final //! RcvEB PVP Structure six::XsElement rcvEB{ "RcvEB" }; }; +inline std::ostream& operator<<(std::ostream& os, const RcvAntenna& v) +{ + os << v.rcvACX << "\n"; + os << v.rcvACY << "\n"; + os << v.rcvEB << "\n"; + return os; +} /*! * \struct Pvp @@ -597,15 +623,9 @@ struct Pvp final * Set default size and format for each parameter */ void setDefaultValues(size_t size, const std::string& format, PVPType& param); - - /* - * Initializes default size and format for parameters - */ - void initialize(); }; //! Ostream operators -std::ostream& operator<< (std::ostream& os, const PVPType& p); std::ostream& operator<< (std::ostream& os, const APVPType& a); std::ostream& operator<< (std::ostream& os, const Pvp& p); } diff --git a/six/modules/c++/cphd/include/cphd/PVPBlock.h b/six/modules/c++/cphd/include/cphd/PVPBlock.h index e8ef6a4025..52be696925 100644 --- a/six/modules/c++/cphd/include/cphd/PVPBlock.h +++ b/six/modules/c++/cphd/include/cphd/PVPBlock.h @@ -194,8 +194,7 @@ struct PVPBlock return aP.getAddedPVP(mData[channel][set].addedPVP.find(name)->second); // return AddPVPNamespace::getAddedPVP(mData[channel][set].addedPVP.find(name)->second); } - throw except::Exception(Ctxt( - "Parameter was not set")); + throw except::Exception(Ctxt("Parameter was not set")); } //! Setter functions @@ -236,11 +235,9 @@ struct PVPBlock mData[channel][set].addedPVP.find(name)->second.setValue(value); return; } - throw except::Exception(Ctxt( - "Additional parameter requested already exists")); + throw except::Exception(Ctxt("Additional parameter requested already exists")); } - throw except::Exception(Ctxt( - "Parameter was not specified in XML")); + throw except::Exception(Ctxt("Parameter was not specified in XML")); } /* @@ -251,10 +248,10 @@ struct PVPBlock * \param[out] data Will be filled with PVP data. This will * be resized and zeroed internally. */ - void getPVPdata(size_t channel, - std::vector& data) const; void getPVPdata(size_t channel, std::vector& data) const; + void getPVPdata(size_t channel, + std::vector& data) const; // for existing SWIG bindings /* * \func getPVPdata @@ -359,7 +356,7 @@ struct PVPBlock * Each channel consists of a PVP Array, * which consists of multiple sets */ - struct PVPSet + struct PVPSet final { /*! * \func PVPSet diff --git a/six/modules/c++/cphd/include/cphd/SupportBlock.h b/six/modules/c++/cphd/include/cphd/SupportBlock.h index 6f55cde1cb..7cbd41a3b0 100644 --- a/six/modules/c++/cphd/include/cphd/SupportBlock.h +++ b/six/modules/c++/cphd/include/cphd/SupportBlock.h @@ -19,15 +19,15 @@ * see . * */ +#pragma once #ifndef __CPHD_SUPPORT_BLOCK_H__ #define __CPHD_SUPPORT_BLOCK_H__ -#pragma once #include #include #include #include - +#include #include #include @@ -118,13 +118,7 @@ struct SupportBlock final void read(const std::string& id, size_t numThreads, const mem::BufferView& data) const; - void read(const std::string& id, - size_t numThreads, - std::span data) const - { - mem::BufferView data_(reinterpret_cast(data.data()), data.size()); - read(id, numThreads, data_); - } + void read(const std::string& id, size_t numThreads, std::span data) const; /* * \func read @@ -139,17 +133,8 @@ struct SupportBlock final * \param[out] data std::unique_ptr<[]> that will hold the data read from the file. */ // Same as above but allocates the memory - void read(const std::string& id, - size_t numThreads, - std::unique_ptr& data) const; - void read(const std::string& id, - size_t numThreads, - std::unique_ptr& data) const - { - std::unique_ptr data_; - read(id, numThreads, data_); - data.reset(reinterpret_cast(data_.release())); - } + std::vector read(const std::string& id, size_t numThreads) const; + void read(const std::string& id, size_t numThreads, mem::ScopedArray&) const; // for existing SWIG bindings /* * \func readAll @@ -163,22 +148,10 @@ struct SupportBlock final * \param[out] data std::unique_ptr<[]> that will hold the data read from the file. * */ - void readAll(size_t numThreads, - std::unique_ptr& data) const; - void readAll(size_t numThreads, - std::unique_ptr& data) const - { - std::unique_ptr data_; - readAll(numThreads, data_); - data.reset(reinterpret_cast(data_.release())); - } - + std::vector readAll(size_t numThreads) const; + void readAll(size_t numThreads, mem::ScopedArray&) const; // for existing SWIG bindings private: - //! Initialize mOffsets for each array - // both for uncompressed and compressed data - void initialize(); - const std::shared_ptr mInStream; cphd::Data mData; const int64_t mSupportOffset; // offset in bytes to start of SupportBlock diff --git a/six/modules/c++/cphd/include/cphd/TestDataGenerator.h b/six/modules/c++/cphd/include/cphd/TestDataGenerator.h index c61846bd28..4767dd32db 100644 --- a/six/modules/c++/cphd/include/cphd/TestDataGenerator.h +++ b/six/modules/c++/cphd/include/cphd/TestDataGenerator.h @@ -121,16 +121,22 @@ inline cphd::SignalArrayFormat getSignalArrayFormat(size_t writeDataSize) template -void setUpData(Metadata& metadata, - const types::RowCol& dims, - const std::vector& writeData) +Metadata setUpData(const types::RowCol& dims, + const std::vector& writeData, + const std::string* pSignalCompressionID = nullptr) { + Data data; + if (pSignalCompressionID != nullptr) + { + data.signalCompressionID = *pSignalCompressionID; + } const size_t numChannels = 1; for (size_t ii = 0; ii < numChannels; ++ii) { - metadata.data.channels.push_back( + data.channels.push_back( cphd::Data::Channel(dims.row, dims.col)); } + Metadata metadata(std::move(data)); if (!writeData.empty()) { @@ -157,6 +163,15 @@ void setUpData(Metadata& metadata, } setUpMetadata(metadata); + + return metadata; +} +template +Metadata setUpData(const std::string& signalCompressionID, + const types::RowCol& dims, + const std::vector& writeData) +{ + return setUpData(dims, writeData, &signalCompressionID); } } diff --git a/six/modules/c++/cphd/source/BaseFileHeader.cpp b/six/modules/c++/cphd/source/BaseFileHeader.cpp index ed9d7433a4..851f61f5b1 100644 --- a/six/modules/c++/cphd/source/BaseFileHeader.cpp +++ b/six/modules/c++/cphd/source/BaseFileHeader.cpp @@ -46,7 +46,7 @@ bool BaseFileHeader::isCPHD(io::SeekableInputStream& inStream) return (::strncmp(buf, FILE_TYPE, 4) == 0); } -std::string BaseFileHeader::readVersion(io::SeekableInputStream& inStream) +std::string BaseFileHeader::strReadVersion(io::SeekableInputStream& inStream) { char buf[128]; inStream.seek(0, io::Seekable::START); @@ -64,6 +64,28 @@ std::string BaseFileHeader::readVersion(io::SeekableInputStream& inStream) return ret; } +Version BaseFileHeader::readVersion(io::SeekableInputStream& inStream) +{ + return toVersion(strReadVersion(inStream)); +} +Version BaseFileHeader::toVersion(const std::string& strVersion) +{ + #define SIX_cphd_FileHeader_setVersion_map_entry(v) { to_string(v), v} // avoid copy/paste errors + static const std::map string_to_vesion + { + { "1.0", Version::v1_0_0}, // existing files; should be "1.0.0" + SIX_cphd_FileHeader_setVersion_map_entry(Version::v1_0_0), + SIX_cphd_FileHeader_setVersion_map_entry(Version::v1_0_1), + SIX_cphd_FileHeader_setVersion_map_entry(Version::v1_1_0), + }; + #undef SIX_cphd_FileHeader_setVersion_map_entry + const auto it = string_to_vesion.find(strVersion); + if (it != string_to_vesion.end()) + { + return it->second; + } + throw std::logic_error("Unkown 'Version' value."); +} void BaseFileHeader::tokenize(const std::string& in, const std::string& delimiter, @@ -87,8 +109,7 @@ void BaseFileHeader::blockReadHeader(io::SeekableInputStream& inStream, static const char ERROR_MSG[] = "CPHD file malformed: Header must terminate with '\\f\\n'"; - std::vector buf(blockSize + 1); - std::fill(buf.begin(), buf.end(), static_cast(0)); + std::vector buf(blockSize + 1, static_cast(0)); headerBlock.clear(); // read each block in succession diff --git a/six/modules/c++/cphd/source/ByteSwap.cpp b/six/modules/c++/cphd/source/ByteSwap.cpp index f39f096ecb..929db6be0d 100644 --- a/six/modules/c++/cphd/source/ByteSwap.cpp +++ b/six/modules/c++/cphd/source/ByteSwap.cpp @@ -251,8 +251,7 @@ void byteSwapAndPromote(const void* input, ::byteSwapAndPromote(input, dims, numThreads, output); break; default: - throw except::Exception(Ctxt( - "Unexpected element size " + std::to_string(elementSize))); + throw except::Exception(Ctxt("Unexpected element size " + std::to_string(elementSize))); } } @@ -266,20 +265,16 @@ void byteSwapAndScale(const void* input, switch (elementSize) { case 2: - ::byteSwapAndScale(input, dims, scaleFactors, numThreads, - output); + ::byteSwapAndScale(input, dims, scaleFactors, numThreads, output); break; case 4: - ::byteSwapAndScale(input, dims, scaleFactors, numThreads, - output); + ::byteSwapAndScale(input, dims, scaleFactors, numThreads, output); break; case 8: - ::byteSwapAndScale(input, dims, scaleFactors, numThreads, - output); + ::byteSwapAndScale(input, dims, scaleFactors, numThreads, output); break; default: - throw except::Exception(Ctxt( - "Unexpected element size " + std::to_string(elementSize))); + throw except::Exception(Ctxt("Unexpected element size " + std::to_string(elementSize))); } } } diff --git a/six/modules/c++/cphd/source/CPHDReader.cpp b/six/modules/c++/cphd/source/CPHDReader.cpp index 999a2712d5..40258717e3 100644 --- a/six/modules/c++/cphd/source/CPHDReader.cpp +++ b/six/modules/c++/cphd/source/CPHDReader.cpp @@ -35,38 +35,25 @@ #include #include -namespace cphd -{ -CPHDReader::CPHDReader(std::shared_ptr inStream, - size_t numThreads, - const std::vector& schemaPaths, - std::shared_ptr logger) -{ - initialize(inStream, numThreads, logger, schemaPaths); -} - -CPHDReader::CPHDReader(const std::string& fromFile, +cphd::CPHDReader::CPHDReader(const std::string& fromFile, size_t numThreads, const std::vector& schemaPaths, std::shared_ptr logger) + : CPHDReader(std::make_shared(fromFile), numThreads, schemaPaths, logger) { - initialize(std::make_shared(fromFile), - numThreads, logger, schemaPaths); } -void CPHDReader::initialize(std::shared_ptr inStream, - size_t numThreads, - std::shared_ptr logger, - const std::vector& schemaPaths_) +static cphd::Metadata fromXML(io::SeekableInputStream& inStream, + const std::vector& schemaPaths_, + std::shared_ptr logger, + const cphd::FileHeader& mFileHeader) { - mFileHeader.read(*inStream); - // Read in the XML string - inStream->seek(mFileHeader.getXMLBlockByteOffset(), io::Seekable::START); + inStream.seek(mFileHeader.getXMLBlockByteOffset(), io::Seekable::START); six::MinidomParser xmlParser; xmlParser.preserveCharacterData(true); - xmlParser.parse(*inStream, gsl::narrow(mFileHeader.getXMLBlockSize())); + xmlParser.parse(inStream, gsl::narrow(mFileHeader.getXMLBlockSize())); if (logger.get() == nullptr) { @@ -76,8 +63,16 @@ void CPHDReader::initialize(std::shared_ptr inStream, std::vector schemaPaths; std::transform(schemaPaths_.begin(), schemaPaths_.end(), std::back_inserter(schemaPaths), [](const std::string& s) { return s; }); - mMetadata = CPHDXMLControl(logger.get()).fromXML(xmlParser.getDocument(), schemaPaths); + return cphd::CPHDXMLControl(logger.get()).fromXML(xmlParser.getDocument(), schemaPaths); +} +cphd::CPHDReader::CPHDReader(std::shared_ptr inStream, + size_t numThreads, + const std::vector& schemaPaths_, + std::shared_ptr logger) + : mFileHeader(cphd::FileHeader::read(*inStream)), + mMetadata(fromXML(*inStream, schemaPaths_, logger, mFileHeader)) +{ mSupportBlock = std::make_unique(inStream, mMetadata.data, mFileHeader); // Load the PVPBlock into memory @@ -88,4 +83,3 @@ void CPHDReader::initialize(std::shared_ptr inStream, mWideband = std::make_unique(inStream, mMetadata, mFileHeader.getSignalBlockByteOffset(), mFileHeader.getSignalBlockSize()); } -} diff --git a/six/modules/c++/cphd/source/CPHDWriter.cpp b/six/modules/c++/cphd/source/CPHDWriter.cpp index aafbe4ad8c..9d649c18f6 100644 --- a/six/modules/c++/cphd/source/CPHDWriter.cpp +++ b/six/modules/c++/cphd/source/CPHDWriter.cpp @@ -39,6 +39,12 @@ namespace cphd { +static Version getVersion(const Metadata& metadata) +{ + Version retval; + metadata.getVersion(retval); + return retval; +} CPHDWriter::CPHDWriter(const Metadata& metadata, std::shared_ptr outStream, @@ -50,7 +56,8 @@ CPHDWriter::CPHDWriter(const Metadata& metadata, mScratchSpaceSize(scratchSpaceSize), mNumThreads(numThreads), mSchemaPaths(schemaPaths), - mStream(outStream) + mStream(outStream), + mHeader(getVersion(metadata)) { // Get the correct dataWriter. // The CPHD file needs to be big endian. @@ -76,9 +83,7 @@ void CPHDWriter::writeMetadata(size_t supportSize, { const auto xmlMetadata(CPHDXMLControl().toXMLString(mMetadata, mSchemaPaths)); - Version cphdVersion; - mMetadata.getVersion(cphdVersion); - mHeader.setVersion(cphdVersion); + mHeader.setVersion(getVersion(mMetadata)); // update classification and release info if (!six::Init::isUndefined( @@ -127,17 +132,35 @@ void CPHDWriter::writeCompressedCPHDDataImpl(const std::byte* data, (*mDataWriter)(data, mMetadata.data.getCompressedSignalSize(channel), 1); } -void CPHDWriter::writeSupportDataImpl(const std::byte* data, - size_t numElements, - size_t elementSize) +static auto make_span(std::span data, const cphd::Data::SupportArray& dataArray) { - (*mDataWriter)(data, numElements, elementSize); + const auto pData = data.data() + dataArray.arrayByteOffset; + return sys::make_span(pData, dataArray.size_bytes()); } +void CPHDWriter::writeSupportDataImpl(std::span data, size_t elementSize) +{ + (*mDataWriter)(data, elementSize); +} +void CPHDWriter::writeSupportData(std::span data) +{ + for (auto&& mapEntry : mMetadata.data.supportArrayMap) + { + auto&& dataArray = mapEntry.second; + + // Move inputstream head to offset of particular support array + mStream->seek(mHeader.getSupportBlockByteOffset() + dataArray.arrayByteOffset, io::SeekableOutputStream::START); + writeSupportDataImpl(make_span(data, dataArray), dataArray.bytesPerElement); + } + // Move inputstream head to the end of the support block after all supports have been written + mStream->seek(mHeader.getSupportBlockByteOffset() + mHeader.getSupportBlockSize(), io::SeekableOutputStream::START); +} + + template void CPHDWriter::write(const PVPBlock& pvpBlock, - const T* widebandData, - const sys::ubyte* supportData) + const T* widebandData, + std::span supportData) { // Write File header and metadata to file // Padding is added in writeMetadata @@ -147,7 +170,7 @@ void CPHDWriter::write(const PVPBlock& pvpBlock, // Padding is added in writeSupportData if (mMetadata.data.getNumSupportArrays() != 0) { - if (supportData == nullptr) + if (supportData.empty()) { throw except::Exception(Ctxt("SupportData is not provided")); } @@ -170,44 +193,13 @@ void CPHDWriter::write(const PVPBlock& pvpBlock, elementsWritten += numElements; } } - -// For compressed data -template void CPHDWriter::write(const PVPBlock& pvpBlock, - const sys::ubyte* widebandData, - const sys::ubyte* supportData); -template void CPHDWriter::write(const PVPBlock& pvpBlock, - const std::byte* widebandData, - const std::byte* supportData); - -template void CPHDWriter::write( - const PVPBlock& pvpBlock, - const cphd::zint8_t* widebandData, - const sys::ubyte* supportData); - -template void CPHDWriter::write( - const PVPBlock& pvpBlock, - const cphd::zint16_t* widebandData, - const sys::ubyte* supportData); - -template void CPHDWriter::write( - const PVPBlock& pvpBlock, - const cphd::zfloat* widebandData, - const sys::ubyte* supportData); - -template void CPHDWriter::write( - const PVPBlock& pvpBlock, - const cphd::zint8_t* widebandData, - const std::byte* supportData); - -template void CPHDWriter::write( - const PVPBlock& pvpBlock, - const cphd::zint16_t* widebandData, - const std::byte* supportData); - -template void CPHDWriter::write( - const PVPBlock& pvpBlock, - const cphd::zfloat* widebandData, - const std::byte* supportData); +template void CPHDWriter::write(const PVPBlock&, const std::byte* widebandData, std::span); // For compressed data +template void CPHDWriter::write(const PVPBlock&, const cphd::zint8_t* widebandData, std::span); +template void CPHDWriter::write(const PVPBlock&, const cphd::zint16_t* widebandData, std::span); +template void CPHDWriter::write(const PVPBlock&, const cphd::zfloat* widebandData, std::span); +//template void CPHDWriter::write(const PVPBlock&, const cphd::zint8_t* widebandData, std::span); +//template void CPHDWriter::write(const PVPBlock&, const cphd::zint16_t* widebandData, std::span); +//template void CPHDWriter::write(const PVPBlock&, const cphd::zfloat* widebandData, std::span); void CPHDWriter::writeMetadata(const PVPBlock& pvpBlock) { @@ -274,20 +266,18 @@ void CPHDWriter::writeCPHDData(const T* data, size_t numElements, size_t channel) { + const void* const pData = data; if (mMetadata.data.isCompressed()) { - writeCompressedCPHDDataImpl(reinterpret_cast(data), - channel); + writeCompressedCPHDDataImpl(static_cast(pData), channel); } else { if (mElementSize != sizeof(T)) { - throw except::Exception( - Ctxt("Incorrect buffer data type used for metadata!")); + throw except::Exception(Ctxt("Incorrect buffer data type used for metadata!")); } - writeCPHDDataImpl(reinterpret_cast(data), - numElements); + writeCPHDDataImpl(static_cast(pData), numElements); } } diff --git a/six/modules/c++/cphd/source/CPHDXMLControl.cpp b/six/modules/c++/cphd/source/CPHDXMLControl.cpp index 34fcd42c87..fd7d1092bd 100644 --- a/six/modules/c++/cphd/source/CPHDXMLControl.cpp +++ b/six/modules/c++/cphd/source/CPHDXMLControl.cpp @@ -105,23 +105,6 @@ std::unique_ptr CPHDXMLControl::toXML( return doc; } -static std::unordered_map makeVersionUriMap_() -{ - std::map result; - CPHDXMLControl::getVersionUriMap(result); - - std::unordered_map retval; - for (const auto& version_and_uri : result) - { - retval[to_string(version_and_uri.first)] = version_and_uri.second; - } - return retval; -} -std::unordered_map CPHDXMLControl::getVersionUriMap() // for existing code -{ - static const auto retval = makeVersionUriMap_(); - return retval; -} static std::map getVersionUriMap_() { static const std::map retval = { @@ -131,27 +114,16 @@ static std::map getVersionUriMap_() }; return retval; } -void CPHDXMLControl::getVersionUriMap(std::map& result) +std::map CPHDXMLControl::getVersionUriMap() { - result = getVersionUriMap_(); + return getVersionUriMap_(); } std::unique_ptr CPHDXMLControl::toXMLImpl(const Metadata& metadata) { Version cphdVersion; metadata.getVersion(cphdVersion); - - static const auto versionUriMap = getVersionUriMap_(); - const auto it = versionUriMap.find(cphdVersion); - if (it != versionUriMap.end()) - { - return getParser(it->second)->toXML(metadata); - } - std::ostringstream ostr; - ostr << "The version " << metadata.getVersion() << " is invalid. " - << "Check if version is valid or " - << "add a entry to versionUriMap"; - throw except::Exception(Ctxt(ostr.str())); + return getParser(cphdVersion)->toXML(metadata); } /* FROM XML */ @@ -182,10 +154,7 @@ std::unique_ptr CPHDXMLControl::fromXML(const xml::lite::Document* doc { six::XMLControl::validate(doc, schemaPaths, mLog); } - std::unique_ptr metadata = fromXMLImpl(doc); - const xml::lite::Uri uri(doc->getRootElement()->getUri()); - metadata->setVersion(uriToVersion(uri)); - return metadata; + return fromXMLImpl(doc); } Metadata CPHDXMLControl::fromXML(const xml::lite::Document& doc, const std::vector& schemaPaths) { @@ -193,22 +162,25 @@ Metadata CPHDXMLControl::fromXML(const xml::lite::Document& doc, const std::vect std::transform(schemaPaths.begin(), schemaPaths.end(), std::back_inserter(schemaPaths_), [](const std::filesystem::path& p) { return p.string(); }); auto result = fromXML(&doc, schemaPaths_); - return *(result.release()); + + auto retval = std::move(*(result.release())); + return retval; } std::unique_ptr CPHDXMLControl::fromXMLImpl(const xml::lite::Document* doc) { const xml::lite::Uri uri(doc->getRootElement()->getUri()); - return getParser(uri)->fromXML(doc); + const auto version = uriToVersion(uri); + return getParser(version)->fromXML(doc); } std::unique_ptr -CPHDXMLControl::getParser(const xml::lite::Uri& uri) const +CPHDXMLControl::getParser(Version version) const { - return std::make_unique(uri.value, false, mLog); + return std::make_unique(version, false, mLog); } -Version CPHDXMLControl::uriToVersion(const xml::lite::Uri& uri) const +Version CPHDXMLControl::uriToVersion(const xml::lite::Uri& uri) { static const auto versionUriMap = getVersionUriMap_(); for (const auto& p : versionUriMap) diff --git a/six/modules/c++/cphd/source/CPHDXMLParser.cpp b/six/modules/c++/cphd/source/CPHDXMLParser.cpp index 1ea206ba35..ba02cbddd7 100644 --- a/six/modules/c++/cphd/source/CPHDXMLParser.cpp +++ b/six/modules/c++/cphd/source/CPHDXMLParser.cpp @@ -33,6 +33,7 @@ #include #include #include +#include #define ENFORCESPEC 0 @@ -45,12 +46,18 @@ typedef xml::lite::Element* XMLElem; namespace cphd { +static std::string strUriFromVersion(Version version) +{ + auto&& map = CPHDXMLControl::getVersionUriMap(); + return map.at(version).value; +} + CPHDXMLParser::CPHDXMLParser( - const std::string& uri, + Version version, bool addClassAttributes, logging::Logger* log, bool ownLog) : - six::XMLParser(uri, addClassAttributes, log, ownLog), + six::XMLParser(strUriFromVersion(version), addClassAttributes, log, ownLog), mCommon(getDefaultURI(), addClassAttributes, getDefaultURI(), log) { } @@ -1012,13 +1019,12 @@ XMLElem CPHDXMLParser::toXML(const MatchInformation& matchInfo, XMLElem parent) /* * FROM XML */ - -std::unique_ptr CPHDXMLParser::fromXML( - const xml::lite::Document* doc) +Metadata CPHDXMLParser::fromXML(const xml::lite::Document& doc, Version version) { - std::unique_ptr cphd(new Metadata()); + Metadata retval(version); + auto cphd = &retval; - const auto root = doc->getRootElement(); + const auto root = doc.getRootElement(); XMLElem collectionIDXML = getFirstAndOnly(root, "CollectionID"); XMLElem globalXML = getFirstAndOnly(root, "Global"); @@ -1084,7 +1090,13 @@ std::unique_ptr CPHDXMLParser::fromXML( fromXML(matchInfoXML, *(cphd->matchInfo)); } - return cphd; + return retval; +} +std::unique_ptr CPHDXMLParser::fromXML(const xml::lite::Document* doc) +{ + const auto version = CPHDXMLControl::uriToVersion(xml::lite::Uri(getDefaultURI())); + auto result = fromXML(*doc, version); + return std::make_unique(std::move(result)); } void CPHDXMLParser::fromXML(const xml::lite::Element* collectionIDXML, CollectionInformation& collectionID) diff --git a/six/modules/c++/cphd/source/DataWriter.cpp b/six/modules/c++/cphd/source/DataWriter.cpp index 9cc3a5393a..41516cb773 100644 --- a/six/modules/c++/cphd/source/DataWriter.cpp +++ b/six/modules/c++/cphd/source/DataWriter.cpp @@ -25,6 +25,7 @@ #include #include +#include #include #undef min @@ -53,18 +54,27 @@ DataWriterLittleEndian::DataWriterLittleEndian( size_t scratchSize) : DataWriterLittleEndian(*stream, numThreads, scratchSize) { } -void DataWriterLittleEndian::operator()(const void* pData, size_t numElements, size_t elementSize) + +static auto adjust_span(std::span data, size_t dataProcessed) { - const auto data = static_cast(pData); + const auto pData = data.data() + dataProcessed; + const auto size = data.size() - dataProcessed; + return sys::make_span(pData, size); +} +void DataWriterLittleEndian::operator()(std::span pData, size_t elementSize) +{ size_t dataProcessed = 0; - const size_t dataSize = numElements * elementSize; + const auto dataSize = pData.size(); while (dataProcessed < dataSize) { const size_t dataToProcess = std::min(mScratch.size(), dataSize - dataProcessed); - memcpy(mScratch.data(), data + dataProcessed, dataToProcess); + const auto data = adjust_span(pData, dataProcessed); + const auto begin = data.begin(); + const auto end = begin + dataToProcess; + mScratch.assign(begin, end); cphd::byteSwap(mScratch.data(), elementSize, @@ -86,9 +96,9 @@ DataWriterBigEndian::DataWriterBigEndian( size_t numThreads) : DataWriterBigEndian(*stream, numThreads) { } -void DataWriterBigEndian::operator()(const void* data, size_t numElements, size_t elementSize) +void DataWriterBigEndian::operator()(std::span pData, size_t /*elementSize*/) { - mStream.write(data, numElements * elementSize); + mStream.write(pData.data(), pData.size()); } } diff --git a/six/modules/c++/cphd/source/FileHeader.cpp b/six/modules/c++/cphd/source/FileHeader.cpp index f818aaec15..933ebcebb3 100644 --- a/six/modules/c++/cphd/source/FileHeader.cpp +++ b/six/modules/c++/cphd/source/FileHeader.cpp @@ -21,6 +21,8 @@ */ #include #include +#include +#include #include #include @@ -32,27 +34,30 @@ namespace cphd { -static const char* getDefaultVersion() +Version FileHeader::defaultVersion = Version::v1_0_1; +Version FileHeader::getDefaultVersion() { - static const auto defaultVersion = to_string(Version::v1_0_1); - return defaultVersion.c_str(); + return defaultVersion; +} +void FileHeader::setDefaultVersion(Version version) +{ + defaultVersion = version; +} +static const char* getDefaultVersion_() +{ + static std::string strDefaultVersion; // returning a pointer + strDefaultVersion = to_string(FileHeader::getDefaultVersion()); + return strDefaultVersion.c_str(); } -const char* FileHeader::DEFAULT_VERSION = getDefaultVersion(); -FileHeader::FileHeader() : - mVersion(DEFAULT_VERSION), - mXmlBlockSize(0), - mXmlBlockByteOffset(0), - mPvpBlockSize(0), - mPvpBlockByteOffset(0), - mSignalBlockSize(0), - mSignalBlockByteOffset(0), - mSupportBlockSize(0), - mSupportBlockByteOffset(0) +const char* FileHeader::DEFAULT_VERSION = getDefaultVersion_(); +FileHeader::FileHeader(Version version) : mVersion(version) { + // reinitialize in case value has changed + DEFAULT_VERSION = getDefaultVersion_(); } -void FileHeader::read(io::SeekableInputStream& inStream) +FileHeader FileHeader::read(io::SeekableInputStream& inStream) { if (!isCPHD(inStream)) { @@ -60,8 +65,16 @@ void FileHeader::read(io::SeekableInputStream& inStream) } // Read mVersion first - mVersion = readVersion(inStream); - + FileHeader retval(readVersion(inStream)); + retval.readAfterValidVersion(inStream); + return retval; +} +void FileHeader::readImpl(io::SeekableInputStream&) +{ + throw std::logic_error("Should use 'static' read()"); +} +void FileHeader::readAfterValidVersion(io::SeekableInputStream& inStream) +{ // Block read the header for more efficient IO KeyValuePair headerEntry; std::string headerBlock; @@ -162,7 +175,7 @@ std::string FileHeader::toString() const // Send the values as they are, no calculating // File type - os << FILE_TYPE << "/" << mVersion << LINE_TERMINATOR; + os << FILE_TYPE << "/" << to_string(mVersion) << LINE_TERMINATOR; // Classification fields, if present if (mSupportBlockSize > 0) @@ -193,16 +206,20 @@ std::string FileHeader::toString() const std::string FileHeader::getVersion() const { - return mVersion; + return to_string(mVersion); +} +void FileHeader::getVersion(Version& version) const +{ + version = mVersion; } -void FileHeader::setVersion(const std::string& version) +void FileHeader::setVersion(Version version) { mVersion = version; } -void FileHeader::setVersion(Version version) +void FileHeader::setVersion(const std::string& strVersion) { - setVersion(to_string(version)); + setVersion(FileHeader::toVersion(strVersion)); } size_t FileHeader::set(int64_t xmlBlockSize, @@ -286,7 +303,7 @@ int64_t FileHeader::getPvpPadBytes() const std::ostream& operator<< (std::ostream& os, const FileHeader& fh) { os << "FileHeader::\n" - << " mVersion : " << fh.mVersion << "\n" + << " mVersion : " << to_string(fh.mVersion) << "\n" << " mXmlBlockSize : " << fh.mXmlBlockSize << "\n" << " mXmlBlockByteOffset : " << fh.mXmlBlockByteOffset << "\n" << " mSupportBlockSize : " << fh.mSupportBlockSize << "\n" diff --git a/six/modules/c++/cphd/source/Metadata.cpp b/six/modules/c++/cphd/source/Metadata.cpp index 542f6407bd..fd166e64ca 100644 --- a/six/modules/c++/cphd/source/Metadata.cpp +++ b/six/modules/c++/cphd/source/Metadata.cpp @@ -26,10 +26,14 @@ namespace cphd { -Metadata::Metadata() +Metadata::Metadata(Version version) { - // Default version defined in cphd::FileHeader - setVersion(FileHeader::DEFAULT_VERSION); + setVersion(version); +} +Metadata::Metadata(Data&& data) + : Metadata(FileHeader::getDefaultVersion()) // Default version defined in cphd::FileHeader +{ + this->data = std::move(data); } size_t Metadata::getNumChannels() const @@ -75,30 +79,14 @@ void Metadata::getVersion(Version& version) const { version = mVersion; } - -void Metadata::setVersion(const std::string& version) -{ - if (version == "1.0.0") - { - setVersion(Version::v1_0_0); - } - else if (version == "1.0.1") - { - setVersion(Version::v1_0_1); - } - else if (version == "1.1.0") - { - setVersion(Version::v1_1_0); - } - else - { - throw std::invalid_argument("Unknown version string: " + version); - } -} void Metadata::setVersion(Version version) { mVersion = version; } +void Metadata::setVersion(const std::string& strVersion) +{ + setVersion(FileHeader::toVersion(strVersion)); +} bool Metadata::operator==(const Metadata& other) const { diff --git a/six/modules/c++/cphd/source/PVP.cpp b/six/modules/c++/cphd/source/PVP.cpp index ab675012aa..9b65b7396d 100644 --- a/six/modules/c++/cphd/source/PVP.cpp +++ b/six/modules/c++/cphd/source/PVP.cpp @@ -41,11 +41,6 @@ APVPType::APVPType() } Pvp::Pvp() -{ - initialize(); -} - -void Pvp::initialize() { // Default size and formats for each PVP // listed in Table 11-6 CPHD1.0 Spec @@ -256,6 +251,14 @@ std::ostream& operator<< (std::ostream& os, const Pvp& p) { os << " SIGNAL : \n" << p.signal << "\n"; } + if (has_value(p.txAntenna)) + { + os << " TxAntenna : \n" << p.txAntenna << "\n"; + } + if (has_value(p.rcvAntenna)) + { + os << " RcvAntenna : \n" << p.rcvAntenna << "\n"; + } for (auto it = p.addedPVP.begin(); it != p.addedPVP.end(); ++it) { os << " Additional Parameter : " << it->second << "\n"; diff --git a/six/modules/c++/cphd/source/SupportBlock.cpp b/six/modules/c++/cphd/source/SupportBlock.cpp index 5c72f7b52c..36d2e47bc2 100644 --- a/six/modules/c++/cphd/source/SupportBlock.cpp +++ b/six/modules/c++/cphd/source/SupportBlock.cpp @@ -42,14 +42,9 @@ SupportBlock::SupportBlock(const std::string& pathname, const cphd::Data& data, int64_t startSupport, int64_t sizeSupport) : - mInStream(std::make_shared(pathname)), - mData(data), - mSupportOffset(startSupport), - mSupportSize(sizeSupport) + SupportBlock(std::make_shared(pathname), data, startSupport, sizeSupport) { - initialize(); } - SupportBlock::SupportBlock(std::shared_ptr inStream, const cphd::Data& data, int64_t startSupport, @@ -59,23 +54,18 @@ SupportBlock::SupportBlock(std::shared_ptr inStream, mSupportOffset(startSupport), mSupportSize(sizeSupport) { - initialize(); + //! Initialize mOffsets for each array both for uncompressed and compressed data + // Trusting data has the right offsets + for (auto kv : mData.supportArrayMap) + { + mOffsets[kv.first] = mSupportOffset + kv.second.arrayByteOffset; + } } SupportBlock::SupportBlock(std::shared_ptr inStream, const cphd::Data& data, const cphd::FileHeader& fileHeader): SupportBlock(inStream, data, fileHeader.getSupportBlockByteOffset(), fileHeader.getSupportBlockSize()) { - initialize(); -} - -void SupportBlock::initialize() -{ - // Trusting data has the right offsets - for (auto it = mData.supportArrayMap.begin(); it != mData.supportArrayMap.end(); ++it) - { - mOffsets[it->first] = mSupportOffset + it->second.arrayByteOffset; - } } int64_t SupportBlock::getFileOffset(const std::string& id) const @@ -89,53 +79,57 @@ int64_t SupportBlock::getFileOffset(const std::string& id) const void SupportBlock::read(const std::string& id, size_t numThreads, - const mem::BufferView& data) const + const mem::BufferView& data_) const +{ + void* pData = data_.data; + auto data = sys::make_span(pData, data_.size); + read(id, numThreads, data); +} +void SupportBlock::read(const std::string& id, size_t numThreads, std::span data) const { const size_t minSize = mData.getSupportArrayById(id).getSize(); - if (data.size < minSize) + if (data.size() < minSize) { std::ostringstream ostr; - ostr << "Need at least " << minSize << " bytes but only got " - << data.size; + ostr << "Need at least " << minSize << " bytes but only got " << data.size(); throw except::Exception(Ctxt(ostr.str())); } + // Perform the read // Compute the byte offset into this SupportArray in the CPHD file // First to the start of the first support array we're going to read int64_t inOffset = getFileOffset(id); - auto dataPtr = data.data; + auto dataPtr = data.data(); mInStream->seek(inOffset, io::FileInputStream::START); - size_t size = mData.getSupportArrayById(id).getSize(); - mInStream->read(dataPtr, size); + size_t bytes = mData.getSupportArrayById(id).size_bytes(); + mInStream->read(dataPtr, bytes); if ((std::endian::native == std::endian::little) && mData.getElementSize(id) > 1) { cphd::byteSwap(dataPtr, mData.getElementSize(id), - mData.getSupportArrayById(id).numRows * - mData.getSupportArrayById(id).numCols, + mData.getSupportArrayById(id).size(), numThreads); } } -void SupportBlock::readAll(size_t numThreads, - std::unique_ptr& data) const +std::vector SupportBlock::readAll(size_t numThreads) const { - data = std::make_unique(mSupportSize); + std::vector retval(mSupportSize); for (auto& supportArrayMapPair : mData.supportArrayMap) { const size_t bufSize = supportArrayMapPair.second.getSize(); - read(supportArrayMapPair.first, numThreads, mem::BufferView(&data[supportArrayMapPair.second.arrayByteOffset], bufSize)); + auto pData = &retval[supportArrayMapPair.second.arrayByteOffset]; + read(supportArrayMapPair.first, numThreads, sys::make_span(pData, bufSize)); } + return retval; } -void SupportBlock::read(const std::string& id, - size_t numThreads, - std::unique_ptr& data) const +std::vector SupportBlock::read(const std::string& id, size_t numThreads) const { - const size_t bufSize = mData.getSupportArrayById(id).getSize(); - data = std::make_unique(bufSize); - read(id, numThreads, mem::BufferView(data.get(), bufSize)); + std::vector retval(mData.getSupportArrayById(id).getSize()); + read(id, numThreads, sys::make_span(retval)); + return retval; } std::ostream& operator<< (std::ostream& os, const SupportBlock& d) diff --git a/six/modules/c++/cphd/tests/test_compare_cphd.cpp b/six/modules/c++/cphd/tests/test_compare_cphd.cpp index 00a072546f..4c5d929147 100644 --- a/six/modules/c++/cphd/tests/test_compare_cphd.cpp +++ b/six/modules/c++/cphd/tests/test_compare_cphd.cpp @@ -63,10 +63,19 @@ bool compareCPHDData(const std::byte* data1, return true; } -bool compareSupportData(const std::unique_ptr& data1, - const std::unique_ptr& data2, - size_t size) +bool compareSupportData(const std::vector& data1, const std::vector& data2, size_t size) { + if (data1.size() != size) + { + std::cerr << "Support data1.size()=" << data1.size() << " should be: " << size << "\n"; + return false; + } + if (data2.size() != size) + { + std::cerr << "Support data2.size()=" << data2.size() << " should be: " << size << "\n"; + return false; + } + for (size_t ii = 0; ii < size; ++ii) { if (data1[ii] != data2[ii]) @@ -178,10 +187,8 @@ bool checkCPHD(const std::string& pathname1, const std::string& pathname2, size_ } // Check support block - std::unique_ptr readPtr1; - reader1.getSupportBlock().readAll(numThreads, readPtr1); - std::unique_ptr readPtr2; - reader2.getSupportBlock().readAll(numThreads, readPtr2); + const auto readPtr1 = reader1.getSupportBlock().readAll(numThreads); + const auto readPtr2 = reader2.getSupportBlock().readAll(numThreads); if (!compareSupportData(readPtr1, readPtr2, reader1.getMetadata().data.getAllSupportSize())) { std::cerr << "SupportBlock does not match \n"; diff --git a/six/modules/c++/cphd/tests/test_round_trip.cpp b/six/modules/c++/cphd/tests/test_round_trip.cpp index f6f43c161f..e608a7ef5d 100644 --- a/six/modules/c++/cphd/tests/test_round_trip.cpp +++ b/six/modules/c++/cphd/tests/test_round_trip.cpp @@ -59,8 +59,7 @@ void testRoundTrip(const std::string& inPathname, const std::string& outPathname // Read SupportBlock const cphd::SupportBlock& supportBlock = reader.getSupportBlock(); - std::unique_ptr readPtr; - supportBlock.readAll(numThreads, readPtr); + const auto readPtr = supportBlock.readAll(numThreads); // Read PVPBlock const cphd::PVPBlock& pvpBlock = reader.getPVPBlock(); @@ -75,8 +74,7 @@ void testRoundTrip(const std::string& inPathname, const std::string& outPathname cphd::CPHDWriter writer(reader.getMetadata(), outPathname, schemaPathnames, numThreads); // Declare and allocate the wideband data storage - std::unique_ptr data; - data.reset(new std::byte[header.getSignalBlockSize()]); + const auto data = std::make_unique(header.getSignalBlockSize()); // Check if signal data is compressed if (metadata.data.isCompressed()) @@ -91,7 +89,7 @@ void testRoundTrip(const std::string& inPathname, const std::string& outPathname writer.write( pvpBlock, data.get(), - readPtr.get()); + sys::make_span(readPtr)); } else { @@ -112,19 +110,19 @@ void testRoundTrip(const std::string& inPathname, const std::string& outPathname writer.write( pvpBlock, reinterpret_cast(data.get()), - readPtr.get()); + sys::make_span(readPtr)); break; case cphd::SignalArrayFormat::CI4: writer.write( pvpBlock, reinterpret_cast(data.get()), - readPtr.get()); + sys::make_span(readPtr)); break; case cphd::SignalArrayFormat::CF8: writer.write( pvpBlock, reinterpret_cast(data.get()), - readPtr.get()); + sys::make_span(readPtr)); break; } } diff --git a/six/modules/c++/cphd/unittests/test_compressed_signal_block_round.cpp b/six/modules/c++/cphd/unittests/test_compressed_signal_block_round.cpp index a768a0c958..b897bd57d1 100644 --- a/six/modules/c++/cphd/unittests/test_compressed_signal_block_round.cpp +++ b/six/modules/c++/cphd/unittests/test_compressed_signal_block_round.cpp @@ -97,7 +97,7 @@ std::vector checkCompressedData(const std::string& pathname, const cphd::Wideband& wideband = reader.getWideband(); std::vector readData(dims.area()); - std::span data(readData.data(), readData.size()); + auto data = sys::make_span(readData); for (size_t ii = 0; ii < reader.getMetadata().data.getNumChannels(); ++ii) { wideband.read(ii, data); @@ -124,9 +124,7 @@ bool runTest(const std::vector& writeData) io::TempFile tempfile; const size_t numThreads = std::thread::hardware_concurrency(); const types::RowCol dims(128, 256); - cphd::Metadata meta = cphd::Metadata(); - meta.data.signalCompressionID = "Huffman"; - cphd::setUpData(meta, dims, writeData); + auto meta = cphd::setUpData("Huffman", dims, writeData); cphd::setPVPXML(meta.pvp); cphd::PVPBlock pvpBlock(meta.pvp, meta.data); diff --git a/six/modules/c++/cphd/unittests/test_cphd_xml_control.cpp b/six/modules/c++/cphd/unittests/test_cphd_xml_control.cpp index d1737e76c4..16ee18daab 100644 --- a/six/modules/c++/cphd/unittests/test_cphd_xml_control.cpp +++ b/six/modules/c++/cphd/unittests/test_cphd_xml_control.cpp @@ -881,27 +881,31 @@ static std::string testCPHDXMLBody() return std::string(xmlBody); } -std::string testCPHDXML(const std::string& version) +std::string testCPHDXML_(cphd::Version version) { - auto uri = cphd::CPHDXMLControl::getVersionUriMap().at(version); + const auto map = cphd::CPHDXMLControl::getVersionUriMap(); + const auto uri = map.at(version); return "\n" + testCPHDXMLBody() + "\n"; } +std::u8string testCPHDXML(cphd::Version version) +{ + return str::u8FromString(testCPHDXML_(version)); +} -void runTest(const std::string& testName, const std::string& version) +void runTest(const std::string& testName, cphd::Version version) { - auto xmlString = testCPHDXML(version); - io::StringStream cphdStream; - cphdStream.write(xmlString.c_str(), xmlString.size()); + const auto xmlString = testCPHDXML(version); + io::U8StringStream cphdStream; + cphdStream.write(xmlString); xml::lite::MinidomParser xmlParser; xmlParser.preserveCharacterData(true); xmlParser.parse(cphdStream, cphdStream.available()); - const std::unique_ptr metadata = - cphd::CPHDXMLControl().fromXML(xmlParser.getDocument()); + const auto metadata = cphd::CPHDXMLControl().fromXML(xmlParser.getDocument()); // CollectionID TEST_ASSERT_EQ(metadata->collectionID.collectorName, "Collector"); @@ -1161,8 +1165,9 @@ void runTest(const std::string& testName, const std::string& version) TEST_CASE(testVersions) { - auto versionUriMap = cphd::CPHDXMLControl::getVersionUriMap(); - for (auto version : {"1.0.0", "1.0.1", "1.1.0"}) + const auto versionUriMap = cphd::CPHDXMLControl::getVersionUriMap(); + + for (auto version : {cphd::Version::v1_0_0, cphd::Version::v1_0_1, cphd::Version::v1_1_0 }) { TEST_ASSERT_TRUE( versionUriMap.find(version) != versionUriMap.end()); @@ -1171,10 +1176,11 @@ TEST_CASE(testVersions) TEST_CASE(testReadXML) { - for (auto pair : cphd::CPHDXMLControl::getVersionUriMap()) + const auto map = cphd::CPHDXMLControl::getVersionUriMap(); + for (auto pair : map) { auto& version = pair.first; - runTest("testReadXML" + version, version); + runTest("testReadXML" + to_string(version), version); } } diff --git a/six/modules/c++/cphd/unittests/test_file_header.cpp b/six/modules/c++/cphd/unittests/test_file_header.cpp index f56058c6db..46005c57cd 100644 --- a/six/modules/c++/cphd/unittests/test_file_header.cpp +++ b/six/modules/c++/cphd/unittests/test_file_header.cpp @@ -24,7 +24,6 @@ #include #include "TestCase.h" -const char* FILE_TYPE_HEADER = "CPHD/1.0\n"; const char* FILE_HEADER_CONTENT = "CPHD/1.0\n" "XML_BLOCK_SIZE := 3\n" "XML_BLOCK_BYTE_OFFSET := 10\n" @@ -38,19 +37,29 @@ const char* FILE_HEADER_CONTENT = "CPHD/1.0\n" "RELEASE_INFO := UNRESTRICTED\n" "\f\n"; -TEST_CASE(testReadVersion) +TEST_CASE(testReadVersion1_0) { + const char* FILE_TYPE_HEADER = "CPHD/1.0\n"; + + io::ByteStream fileTypeHeader; + fileTypeHeader.write(FILE_TYPE_HEADER, strlen(FILE_TYPE_HEADER)); + TEST_ASSERT(cphd::FileHeader::readVersion(fileTypeHeader) == cphd::Version::v1_0_0); +} + +TEST_CASE(testReadVersion1_1_0) +{ + const char* FILE_TYPE_HEADER = "CPHD/1.1.0\n"; + io::ByteStream fileTypeHeader; fileTypeHeader.write(FILE_TYPE_HEADER, strlen(FILE_TYPE_HEADER)); - TEST_ASSERT_EQ(cphd::FileHeader::readVersion(fileTypeHeader), "1.0"); + TEST_ASSERT(cphd::FileHeader::readVersion(fileTypeHeader) == cphd::Version::v1_1_0); } TEST_CASE(testCanReadHeaderWithoutBreaking) { io::ByteStream fileHeaderContentWithSupport; fileHeaderContentWithSupport.write(FILE_HEADER_CONTENT, strlen(FILE_HEADER_CONTENT)); - cphd::FileHeader headerWithSupport; - headerWithSupport.read(fileHeaderContentWithSupport); + const auto headerWithSupport = cphd::FileHeader::read(fileHeaderContentWithSupport); TEST_ASSERT_EQ(headerWithSupport.getXMLBlockSize(), 3); TEST_ASSERT_EQ(headerWithSupport.getXMLBlockByteOffset(), 10); TEST_ASSERT_EQ(headerWithSupport.getSupportBlockSize(), 4); @@ -74,8 +83,7 @@ TEST_CASE(testCanReadHeaderWithoutBreaking) "RELEASE_INFO := UNRESTRICTED\n" "\f\n"; fileHeaderContentWithoutSupport.write(fileHeaderTxtNoSupport); - cphd::FileHeader headerWithoutSupport; - headerWithoutSupport.read(fileHeaderContentWithoutSupport); + const auto headerWithoutSupport = cphd::FileHeader::read(fileHeaderContentWithoutSupport); TEST_ASSERT_EQ(headerWithoutSupport.getXMLBlockSize(), 3); TEST_ASSERT_EQ(headerWithoutSupport.getXMLBlockByteOffset(), 10); TEST_ASSERT_EQ(headerWithoutSupport.getSupportBlockSize(), 0); @@ -98,7 +106,7 @@ TEST_CASE(testCanReadHeaderWithoutBreaking) "\f\n"; io::ByteStream fileHeaderContentWithoutClassification; fileHeaderContentWithoutClassification.write(fileHeaderTxtNoClass); - TEST_THROWS(cphd::FileHeader().read(fileHeaderContentWithoutClassification)); + TEST_THROWS(cphd::FileHeader::read(fileHeaderContentWithoutClassification)); std::string fileHeaderTxtInvalid = "CPHD/1.0\n" "XML_BLOCK_SIZE := foo\n" @@ -112,21 +120,19 @@ TEST_CASE(testCanReadHeaderWithoutBreaking) "\f\n"; io::ByteStream fileHeaderContentWithInvalidValue; fileHeaderContentWithInvalidValue.write(fileHeaderTxtInvalid); - TEST_THROWS(cphd::FileHeader().read(fileHeaderContentWithInvalidValue)); + TEST_THROWS(cphd::FileHeader::read(fileHeaderContentWithInvalidValue)); } TEST_CASE(testRoundTripHeader) { io::ByteStream headerContent; headerContent.write(FILE_HEADER_CONTENT, strlen(FILE_HEADER_CONTENT)); - cphd::FileHeader header; - header.read(headerContent); + const auto header = cphd::FileHeader::read(headerContent); std::string outString = header.toString(); io::ByteStream roundTrippedContent; roundTrippedContent.write(outString); - cphd::FileHeader roundTrippedHeader; - roundTrippedHeader.read(roundTrippedContent); + const auto roundTrippedHeader = cphd::FileHeader::read(roundTrippedContent); TEST_ASSERT_EQ(header.getXMLBlockSize(), roundTrippedHeader.getXMLBlockSize()); @@ -151,7 +157,8 @@ TEST_CASE(testRoundTripHeader) } TEST_MAIN( - TEST_CHECK(testReadVersion); + TEST_CHECK(testReadVersion1_0); + TEST_CHECK(testReadVersion1_1_0); TEST_CHECK(testCanReadHeaderWithoutBreaking); TEST_CHECK(testRoundTripHeader); ) diff --git a/six/modules/c++/cphd/unittests/test_pvp_block_round.cpp b/six/modules/c++/cphd/unittests/test_pvp_block_round.cpp index 93ec99c9c6..2a7673b76c 100644 --- a/six/modules/c++/cphd/unittests/test_pvp_block_round.cpp +++ b/six/modules/c++/cphd/unittests/test_pvp_block_round.cpp @@ -174,8 +174,7 @@ TEST_CASE(testPVPBlockSimple) const types::RowCol dims(128, 256); const auto writeData = generateComplexData(dims.area()); const bool scale = false; - cphd::Metadata meta = cphd::Metadata(); - cphd::setUpData(meta, dims, writeData); + auto meta = cphd::setUpData(dims, writeData); cphd::setPVPXML(meta.pvp); cphd::PVPBlock pvpBlock(meta.pvp, meta.data); std::vector addedParams; @@ -197,8 +196,7 @@ TEST_CASE(testPVPBlockOptional) const types::RowCol dims(128, 256); const auto writeData = generateComplexData(dims.area()); const bool scale = false; - cphd::Metadata meta = cphd::Metadata(); - cphd::setUpData(meta, dims, writeData); + auto meta = cphd::setUpData(dims, writeData); cphd::setPVPXML(meta.pvp); meta.pvp.setOffset(27, meta.pvp.fxN1); meta.pvp.setOffset(28, meta.pvp.fxN2); @@ -223,8 +221,7 @@ TEST_CASE(testPVPBlockAdditional) const types::RowCol dims(128, 256); const auto writeData = generateComplexData(dims.area()); const bool scale = false; - cphd::Metadata meta = cphd::Metadata(); - cphd::setUpData(meta, dims, writeData); + auto meta = cphd::setUpData(dims, writeData); cphd::setPVPXML(meta.pvp); meta.pvp.setCustomParameter(1, 27, "F8", "param1"); meta.pvp.setCustomParameter(1, 28, "F8", "param2"); diff --git a/six/modules/c++/cphd/unittests/test_read_wideband.cpp b/six/modules/c++/cphd/unittests/test_read_wideband.cpp index e1f4007c4b..a6a59a2891 100644 --- a/six/modules/c++/cphd/unittests/test_read_wideband.cpp +++ b/six/modules/c++/cphd/unittests/test_read_wideband.cpp @@ -31,13 +31,14 @@ TEST_CASE(testReadCompressedChannel) input->write("1234"); input->seek(0, io::Seekable::START); - cphd::Metadata metadata; - metadata.data.channels.resize(1); - metadata.data.channels[0].numSamples = 4; - metadata.data.channels[0].numVectors = 8; - metadata.data.signalArrayFormat = cphd::SignalArrayFormat::CI2; - metadata.data.signalCompressionID = "Test Compression"; - metadata.data.channels[0].compressedSignalSize = 4; + cphd::Data data; + data.channels.resize(1); + data.channels[0].numSamples = 4; + data.channels[0].numVectors = 8; + data.signalArrayFormat = cphd::SignalArrayFormat::CI2; + data.signalCompressionID = "Test Compression"; + data.channels[0].compressedSignalSize = 4; + const cphd::Metadata metadata(std::move(data)); cphd::Wideband wideband(input, metadata, 0, 4); @@ -57,13 +58,13 @@ TEST_CASE(testReadUncompressedChannel) input->write("12345678"); input->seek(0, io::Seekable::START); - cphd::Metadata metadata; - metadata.data.channels.resize(1); - metadata.data.channels[0].numSamples = 1; - metadata.data.channels[0].numVectors = 4; - metadata.data.signalArrayFormat = cphd::SignalArrayFormat::CI2; - metadata.data.channels[0].compressedSignalSize = - six::Init::undefined(); + cphd::Data data; + data.channels.resize(1); + data.channels[0].numSamples = 1; + data.channels[0].numVectors = 4; + data.signalArrayFormat = cphd::SignalArrayFormat::CI2; + data.channels[0].compressedSignalSize = six::Init::undefined(); + const cphd::Metadata metadata(std::move(data)); cphd::Wideband wideband(input, metadata, 0, 4); @@ -79,11 +80,12 @@ TEST_CASE(testReadUncompressedChannel) TEST_CASE(testReadChannelSubset) { - cphd::Metadata metadata; - metadata.data.channels.resize(1); - metadata.data.channels[0].numSamples = 2; - metadata.data.channels[0].numVectors = 4; - metadata.data.signalArrayFormat = cphd::SignalArrayFormat::CI2; + cphd::Data data; + data.channels.resize(1); + data.channels[0].numSamples = 2; + data.channels[0].numVectors = 4; + data.signalArrayFormat = cphd::SignalArrayFormat::CI2; + const cphd::Metadata metadata(std::move(data)); auto input = std::make_shared(); input->write("0A1B"); @@ -147,13 +149,14 @@ TEST_CASE(testCannotDoPartialReadOfCompressedChannel) input->write("1234"); input->seek(0, io::Seekable::START); - cphd::Metadata metadata; - metadata.data.channels.resize(1); - metadata.data.channels[0].numSamples = 4; - metadata.data.channels[0].numVectors = 8; - metadata.data.signalArrayFormat = cphd::SignalArrayFormat::CI2; - metadata.data.signalCompressionID = "Test Compression"; - metadata.data.channels[0].compressedSignalSize = 4; + cphd::Data data; + data.channels.resize(1); + data.channels[0].numSamples = 4; + data.channels[0].numVectors = 8; + data.signalArrayFormat = cphd::SignalArrayFormat::CI2; + data.signalCompressionID = "Test Compression"; + data.channels[0].compressedSignalSize = 4; + const cphd::Metadata metadata(std::move(data)); cphd::Wideband wideband(input, metadata, 0, 4); diff --git a/six/modules/c++/cphd/unittests/test_signal_block_round.cpp b/six/modules/c++/cphd/unittests/test_signal_block_round.cpp index 3953c8bd63..fbf83115ae 100644 --- a/six/modules/c++/cphd/unittests/test_signal_block_round.cpp +++ b/six/modules/c++/cphd/unittests/test_signal_block_round.cpp @@ -153,8 +153,7 @@ bool runTest(bool scale, const TCxVector& writeData) const types::RowCol dims(128, 128); const std::vector scaleFactors = generateScaleFactors(dims.row, scale); - cphd::Metadata meta = cphd::Metadata(); - setUpData(meta, dims, writeData); + auto meta = cphd::setUpData(dims, writeData); cphd::setPVPXML(meta.pvp); cphd::PVPBlock pvpBlock(meta.pvp, meta.data); diff --git a/six/modules/c++/cphd/unittests/test_support_block_round.cpp b/six/modules/c++/cphd/unittests/test_support_block_round.cpp index 0e075b58b3..9dbb37eec8 100644 --- a/six/modules/c++/cphd/unittests/test_support_block_round.cpp +++ b/six/modules/c++/cphd/unittests/test_support_block_round.cpp @@ -86,7 +86,7 @@ void writeSupportData(const std::string& outPathname, size_t numThreads, } cphd::CPHDWriter writer(metadata, outPathname, std::vector(), numThreads); writer.writeMetadata(pvpBlock); - writer.writeSupportData(writeData.data()); + writer.writeSupportData(writeData); writer.writePVPData(pvpBlock); } @@ -98,10 +98,8 @@ std::vector checkSupportData( cphd::CPHDReader reader(pathname, numThreads); const cphd::SupportBlock& supportBlock = reader.getSupportBlock(); - std::unique_ptr readPtr; - supportBlock.readAll(numThreads, readPtr); - - std::vector readData(readPtr.get(), readPtr.get() + reader.getMetadata().data.getAllSupportSize()); + const auto bytes = supportBlock.readAll(numThreads); + std::vector readData(bytes.data(), bytes.data() + reader.getMetadata().data.getAllSupportSize()); return readData; } @@ -134,8 +132,7 @@ bool runTest(const std::vector& writeData) { io::TempFile tempfile; const size_t numThreads = 1; - cphd::Metadata meta = cphd::Metadata(); - cphd::setUpData(meta, types::RowCol(128,256), std::vector()); + auto meta = cphd::setUpData(types::RowCol(128,256), std::vector()); setSupport(meta.data); cphd::setPVPXML(meta.pvp); cphd::PVPBlock pvpBlock(meta.pvp, meta.data); diff --git a/six/modules/c++/cphd03/include/cphd03/FileHeader.h b/six/modules/c++/cphd03/include/cphd03/FileHeader.h index 93c91f6e9b..d0568528aa 100644 --- a/six/modules/c++/cphd03/include/cphd03/FileHeader.h +++ b/six/modules/c++/cphd03/include/cphd03/FileHeader.h @@ -43,7 +43,11 @@ class FileHeader : public cphd::BaseFileHeader { } - virtual void read(io::SeekableInputStream& inStream); + void readImpl(io::SeekableInputStream&) override; + void read(io::SeekableInputStream& inStream) + { + readImpl(inStream); + } // Convert header info to string (for writing to file) // Does not include section terminator string diff --git a/six/modules/c++/cphd03/source/FileHeader.cpp b/six/modules/c++/cphd03/source/FileHeader.cpp index 2957f435d6..f0890eac79 100644 --- a/six/modules/c++/cphd03/source/FileHeader.cpp +++ b/six/modules/c++/cphd03/source/FileHeader.cpp @@ -44,7 +44,7 @@ FileHeader::FileHeader() : { } -void FileHeader::read(io::SeekableInputStream& inStream) +void FileHeader::readImpl(io::SeekableInputStream& inStream) { if (!isCPHD(inStream)) { @@ -52,7 +52,7 @@ void FileHeader::read(io::SeekableInputStream& inStream) } // Read mVersion first - mVersion = readVersion(inStream); + mVersion = strReadVersion(inStream); // Block read the header for more efficient IO KeyValuePair headerEntry; diff --git a/six/modules/c++/samples/test_dump_images.cpp b/six/modules/c++/samples/test_dump_images.cpp index 4d7b3ca0d1..28c04934d1 100644 --- a/six/modules/c++/samples/test_dump_images.cpp +++ b/six/modules/c++/samples/test_dump_images.cpp @@ -161,7 +161,7 @@ int main(int argc, char** argv) for (size_t i = 0, total = container->size(); i < total; ++i) { const six::Data* data = container->getData(i); - std::string filename = FmtX("%s_DES_%d.xml", base.string(), i); + const auto filename = FmtX("%s_DES_%d.xml", base.string(), i); const auto xmlFile = fs::path(outputDir) / filename; io::FileOutputStream xmlStream(xmlFile.string()); diff --git a/six/modules/c++/samples/test_parse_xml.cpp b/six/modules/c++/samples/test_parse_xml.cpp index 7e4d0c2a0d..582ab937da 100644 --- a/six/modules/c++/samples/test_parse_xml.cpp +++ b/six/modules/c++/samples/test_parse_xml.cpp @@ -95,7 +95,7 @@ std::vector extractXML(std::string inputFile, nitf::Off size = deReader.getSize(); const auto typeID = subheader.typeID(); - const std::string outputFile = FmtX("%s-%s%d.xml", prefix, typeID, i); + const auto outputFile = FmtX("%s-%s%d.xml", prefix, typeID, i); const auto fileName = outputDir / outputFile; { std::vector xml(size); diff --git a/six/modules/c++/scene/tests/test_scene.cpp b/six/modules/c++/scene/tests/test_scene.cpp index a37c6c9a6a..a38ea343b4 100644 --- a/six/modules/c++/scene/tests/test_scene.cpp +++ b/six/modules/c++/scene/tests/test_scene.cpp @@ -37,11 +37,7 @@ class SceneInfo { std::map::const_iterator p = mVecs.find(k); if (p == mVecs.end()) - throw except::Exception( - Ctxt( - FmtX("Key not found: %s", k.c_str()) - ) - ); + throw except::Exception(Ctxt(FmtX("Key not found: %s", k))); return p->second; } @@ -72,11 +68,7 @@ SceneInfo loadSceneInfo(std::string infoProps) std::string v = d[k].str(); std::vector toks = str::Tokenizer(v, ","); if (toks.size() != 3) - throw except::Exception( - Ctxt( - FmtX("Expected triple, received: %s", v.c_str()) - ) - ); + throw except::Exception(Ctxt(FmtX("Expected triple, received: %s", v))); Vector3 vec; vec[0] = str::toType(toks[0]); diff --git a/six/modules/c++/six.sicd/source/ComplexXMLParser.cpp b/six/modules/c++/six.sicd/source/ComplexXMLParser.cpp index 6d1e212bea..5b4777d3ea 100644 --- a/six/modules/c++/six.sicd/source/ComplexXMLParser.cpp +++ b/six/modules/c++/six.sicd/source/ComplexXMLParser.cpp @@ -832,9 +832,7 @@ XMLElem ComplexXMLParser::convertRcvChanProcToXML( } else { - throw except::Exception(Ctxt(FmtX( - "[RcvChanProc] is a manditory field in ImageFormation in %s", - strVersion.c_str()))); + throw except::Exception(Ctxt(FmtX("[RcvChanProc] is a manditory field in ImageFormation in %s", strVersion))); } } @@ -878,9 +876,7 @@ XMLElem ComplexXMLParser::convertDistortionToXML( } else { - throw except::Exception(Ctxt(FmtX( - "[Distortion] is a maditory field of ImageFormation in %s", - strVersion.c_str()))); + throw except::Exception(Ctxt(FmtX("[Distortion] is a maditory field of ImageFormation in %s", strVersion))); } } diff --git a/six/modules/c++/six.sicd/source/ComplexXMLParser10x.cpp b/six/modules/c++/six.sicd/source/ComplexXMLParser10x.cpp index ed192d7aa2..e228777e2a 100644 --- a/six/modules/c++/six.sicd/source/ComplexXMLParser10x.cpp +++ b/six/modules/c++/six.sicd/source/ComplexXMLParser10x.cpp @@ -283,9 +283,7 @@ XMLElem ComplexXMLParser10x::convertAntennaParamArrayToXML( } else { - throw except::Exception(Ctxt(FmtX( - "[Array] is a mandatory field in AntennaParams of [%s] in 1.0", - name.c_str()))); + throw except::Exception(Ctxt(FmtX("[Array] is a mandatory field in AntennaParams of [%s] in 1.0", name))); } } diff --git a/six/modules/c++/six.sidd/source/DerivedClassification.cpp b/six/modules/c++/six.sidd/source/DerivedClassification.cpp index 5c0eb865ae..dfe850632a 100644 --- a/six/modules/c++/six.sidd/source/DerivedClassification.cpp +++ b/six/modules/c++/six.sidd/source/DerivedClassification.cpp @@ -48,8 +48,7 @@ void DerivedClassification::setSecurity(const std::string& prefix, const std::string fieldKey = NITFImageInfo::generateFieldKey(NITFImageInfo::REL, prefix); - log.debug(Ctxt(FmtX("Setting NITF [%s] from sicd/sidd: [%s]", - fieldKey.c_str(), releasableToStr.c_str()))); + log.debug(Ctxt(FmtX("Setting NITF [%s] from sicd/sidd: [%s]", fieldKey, releasableToStr))); } if (!classifiedBy.empty()) @@ -58,8 +57,7 @@ void DerivedClassification::setSecurity(const std::string& prefix, std::string fieldKey = NITFImageInfo::generateFieldKey(NITFImageInfo::CAUT, prefix); - log.debug(Ctxt(FmtX("Setting NITF [%s] from sicd/sidd: [%s]", - fieldKey.c_str(), classifiedBy.c_str()))); + log.debug(Ctxt(FmtX("Setting NITF [%s] from sicd/sidd: [%s]", fieldKey, classifiedBy))); // classifiedBy attribute represents the name of the original // classification authority @@ -68,9 +66,7 @@ void DerivedClassification::setSecurity(const std::string& prefix, fieldKey = NITFImageInfo::generateFieldKey(NITFImageInfo::CATP, prefix); - log.debug(Ctxt(FmtX("Setting NITF [%s] from sicd/sidd: [%s]", - fieldKey.c_str(), - classAuthorityType.c_str()))); + log.debug(Ctxt(FmtX("Setting NITF [%s] from sicd/sidd: [%s]", fieldKey, classAuthorityType))); } if (!classificationReason.empty()) @@ -79,9 +75,7 @@ void DerivedClassification::setSecurity(const std::string& prefix, const std::string fieldKey = NITFImageInfo::generateFieldKey(NITFImageInfo::CRSN, prefix); - log.debug(Ctxt(FmtX("Setting NITF [%s] from sicd/sidd: [%s]", - fieldKey.c_str(), - classificationReason.c_str()))); + log.debug(Ctxt(FmtX("Setting NITF [%s] from sicd/sidd: [%s]", fieldKey, classificationReason))); } // By default, mark as exempt from automatic declassification @@ -96,9 +90,7 @@ void DerivedClassification::setSecurity(const std::string& prefix, const std::string fieldKey = NITFImageInfo::generateFieldKey(NITFImageInfo::DCDT, prefix); - log.debug(Ctxt(FmtX("Setting NITF [%s] from sicd/sidd: [%s]", - fieldKey.c_str(), - declassDateStr.c_str()))); + log.debug(Ctxt(FmtX("Setting NITF [%s] from sicd/sidd: [%s]", fieldKey, declassDateStr))); // Declassify on a specific date declassType = "DD"; @@ -109,11 +101,8 @@ void DerivedClassification::setSecurity(const std::string& prefix, security.getClassificationText().set(declassEvent); const std::string fieldKey = - NITFImageInfo::generateFieldKey(NITFImageInfo::CLTX, - prefix); - log.debug(Ctxt(FmtX("Setting NITF [%s] from sicd/sidd: [%s]", - fieldKey.c_str(), - declassEvent.c_str()))); + NITFImageInfo::generateFieldKey(NITFImageInfo::CLTX, prefix); + log.debug(Ctxt(FmtX("Setting NITF [%s] from sicd/sidd: [%s]", fieldKey, declassEvent))); // Declassify upon occurrence of an event declassType = "DE"; @@ -133,11 +122,8 @@ void DerivedClassification::setSecurity(const std::string& prefix, exemptedSourceType); const std::string fieldKey = - NITFImageInfo::generateFieldKey(NITFImageInfo::DCXM, - prefix); - log.debug(Ctxt(FmtX("Setting NITF [%s] from sicd/sidd: [%s]", - fieldKey.c_str(), - exemptedSourceType.c_str()))); + NITFImageInfo::generateFieldKey(NITFImageInfo::DCXM, prefix); + log.debug(Ctxt(FmtX("Setting NITF [%s] from sicd/sidd: [%s]", fieldKey, exemptedSourceType))); // Exempt from automatic declassification declassType = "X"; @@ -172,11 +158,8 @@ void DerivedClassification::setSecurity(const std::string& prefix, security.getDeclassificationExemption().set(declassExemption); const std::string fieldKey = - NITFImageInfo::generateFieldKey(NITFImageInfo::DCXM, - prefix); - log.debug(Ctxt(FmtX("Setting NITF [%s] from sicd/sidd: [%s]", - fieldKey.c_str(), - declassExemption.c_str()))); + NITFImageInfo::generateFieldKey(NITFImageInfo::DCXM, prefix); + log.debug(Ctxt(FmtX("Setting NITF [%s] from sicd/sidd: [%s]", fieldKey, declassExemption))); // Exempt from automatic declassification declassType = "X"; @@ -186,11 +169,8 @@ void DerivedClassification::setSecurity(const std::string& prefix, // Now that we've gone through all the things that could modify the // declassification type, set it security.getDeclassificationType().set(declassType); - log.debug(Ctxt(FmtX( - "Setting NITF [%s] from sicd/sidd: [%s]", - NITFImageInfo::generateFieldKey(NITFImageInfo::DCTP, - prefix).c_str(), - declassType.c_str()))); + log.debug(Ctxt(FmtX("Setting NITF [%s] from sicd/sidd: [%s]", + NITFImageInfo::generateFieldKey(NITFImageInfo::DCTP, prefix), declassType))); } } diff --git a/six/modules/c++/six.sidd/source/DerivedXMLParser.cpp b/six/modules/c++/six.sidd/source/DerivedXMLParser.cpp index 4f88c5676c..88e01b510f 100644 --- a/six/modules/c++/six.sidd/source/DerivedXMLParser.cpp +++ b/six/modules/c++/six.sidd/source/DerivedXMLParser.cpp @@ -1960,9 +1960,7 @@ XMLElem DerivedXMLParser::convertSFAGeometryToXML( } else { - throw except::InvalidArgumentException(Ctxt(FmtX( - "Invalid geo type: [%s]", - geoType.c_str()))); + throw except::InvalidArgumentException(Ctxt(FmtX("Invalid geo type: [%s]", geoType))); } return geoElem; diff --git a/six/modules/c++/six.sidd/source/GeoTIFFWriteControl.cpp b/six/modules/c++/six.sidd/source/GeoTIFFWriteControl.cpp index b25417f69e..7dae50f656 100644 --- a/six/modules/c++/six.sidd/source/GeoTIFFWriteControl.cpp +++ b/six/modules/c++/six.sidd/source/GeoTIFFWriteControl.cpp @@ -177,9 +177,7 @@ void GeoTIFFWriteControl::setupIFD(const DerivedData* data, } ifd->addEntry(tiff::KnownTags::PHOTOMETRIC_INTERPRETATION, photoInterp); - addStringArray(ifd, - "ImageDescription", - FmtX("SIDD: %s", data->getName().c_str())); + addStringArray(ifd, "ImageDescription", FmtX("SIDD: %s", data->getName())); constexpr unsigned short orientation = 1; ifd->addEntry("Orientation", orientation); diff --git a/six/modules/c++/six/include/six/Enum.h b/six/modules/c++/six/include/six/Enum.h index a4fcfff35b..b35ca0fde7 100644 --- a/six/modules/c++/six/include/six/Enum.h +++ b/six/modules/c++/six/include/six/Enum.h @@ -67,7 +67,7 @@ namespace details inline T index(const std::map& map, const std::string& v) { const auto result = nitf::details::index(map, v); - const except::InvalidFormatException ex(Ctxt(FmtX("Invalid enum value: %s", v.c_str()))); + const except::InvalidFormatException ex(Ctxt(FmtX("Invalid enum value: %s", v))); return nitf::details::value(result, ex); } template diff --git a/six/modules/c++/six/source/Utilities.cpp b/six/modules/c++/six/source/Utilities.cpp index fd12d2838a..03746abc3d 100644 --- a/six/modules/c++/six/source/Utilities.cpp +++ b/six/modules/c++/six/source/Utilities.cpp @@ -324,8 +324,7 @@ PixelType six::toType(const std::string& s) { auto p = PixelType::toType(s); if (p == PixelType::NOT_SET) - throw except::Exception( - Ctxt(FmtX("Type not understood [%s]", s.c_str()))); + throw except::Exception(Ctxt(FmtX("Type not understood [%s]", s))); return p; } diff --git a/six/modules/c++/six/source/XMLControl.cpp b/six/modules/c++/six/source/XMLControl.cpp index f049de526b..87f0120df7 100644 --- a/six/modules/c++/six/source/XMLControl.cpp +++ b/six/modules/c++/six/source/XMLControl.cpp @@ -447,5 +447,5 @@ std::string six::getSchemaPath(std::vector& schemaPaths, bool tryTo } } - throw except::IOException(Ctxt(FmtX("Directory does not exist: '%s'", schemaPath.c_str()))); + throw except::IOException(Ctxt(FmtX("Directory does not exist: '%s'", schemaPath))); }